如何从文件系统加载图片并使用Jquery进行预览

如何从文件系统加载图片并使用Jquery进行预览,jquery,image,Jquery,Image,在Add pageadd.aspx中使用输入文件控件来预览使用Jquery并上载图像效果非常好 使用不同的url参数时,Add Pageadd.aspx用于从上载的文件路径加载图像,并在加载时预览图像 我被困住了,不知道如何实现它?任何帮助都将不胜感激 如果我使用相同的input:file来使用jquery代码动态加载图片,那么会容易得多,因为我在页面中加载了大量图像 要预览的Jquery代码 图像预览快照 所有示例都来自添加图片时的页面?我想使用相同的页面从文件系统加载上传的图像?最好是相同

在Add pageadd.aspx中使用输入文件控件来预览使用Jquery并上载图像效果非常好

使用不同的url参数时,Add Pageadd.aspx用于从上载的文件路径加载图像,并在加载时预览图像

我被困住了,不知道如何实现它?任何帮助都将不胜感激

如果我使用相同的input:file来使用jquery代码动态加载图片,那么会容易得多,因为我在页面中加载了大量图像

要预览的Jquery代码

图像预览快照

所有示例都来自添加图片时的页面?我想使用相同的页面从文件系统加载上传的图像?最好是相同的控件和代码中的细微调整?

最终实现了它

现在我可以加载图片并在页面加载时预览

在代码中做了一些调整

这是工作代码

Jquery

Aspx


在页面加载中更新了serversidec中ImageimgLogo的url值。

只是为了澄清一下,您希望这是一个单独的前端解决方案吗?前端将是首选,因为我正在使用jquery预览它,我现在不介意c/vb.net解决方案。本文应该对您进行分类:在我看来,任何服务器端解决方案都是重复的。如果您打算使用ajax将文件发送到服务器,例如纯粹为了显示预览,那么您也可以上传该文件。它可以工作,但如果我没有记错的话,只能使用IE10格式。本文中提到的这些解决方案在受支持时是跨浏览器的。老实说,预览不是必须的,它是一个好东西!当我们能够解决自己的问题时,这是很好的。真正的伴侣,这是一种愉快的感觉
 $(function () {
        // Create the close button
        var closebtn = $('<button/>', {
            type: "button",
            text: 'x',
            id: 'close-preview',
            style: 'font-size: initial;',
        });
        closebtn.attr("class", "close pull-right");
        // Set the popover default content
        $('#div_email_logo').popover({
            trigger: 'manual',
            html: true,
            title: "<strong>Preview</strong>" + $(closebtn)[0].outerHTML,
            content: "There's no image",
            placement: 'bottom'
        });
        // Clear event
        $('#btn_email_logo').click(function () {
            $('#div_email_logo').attr("data-content", "").popover('hide');
            $('#txb_email_logo').val("");
            $('#btn_email_logo').hide();
            $('#div_email_logo_preview input:file').val("");
            $("#sp_email_logo").text("Browse");
        });
        // Create the preview image
        $("#div_email_logo_preview input:file").change(function () {
            var img = $('<img/>', {
                id: 'dynamic',
                width: 250,
                height: 200
            });
            var file = this.files[0];
            var reader = new FileReader();
            // Set preview image into the popover data-content
            reader.onload = function (e) {
                $("#sp_email_logo").text("Change");
                $("#btn_email_logo").show();
                $("#txb_email_logo").val(file.name);
                img.attr('src', e.target.result);
                $("#div_email_logo").attr("data-content", $(img)[0].outerHTML).popover("show");
            }
            reader.readAsDataURL(file);
        });

 <div class=" image-preview form-group  col-lg-6" id="div_email_logo" style="display: table">
                                <input type="text" class="form-control image-preview-filename" runat="server" disabled="disabled" placeholder="email Logo" id="txb_email_logo">
                                <!-- don't give a name === doesn't send on POST/GET -->
                                <span class="input-group-btn">
                                    <!-- image-preview-clear button -->
                                    <button type="button" class="btn btn-default image-preview-clear" id="btn_email_logo" style="display: none;">
                                        <span class="glyphicon glyphicon-remove"></span>Clear
                                    </button>
                                    <!-- image-preview-input -->
                                    <div class="btn btn-default image-preview-input" id="div_email_logo_preview">
                                        <span class="glyphicon glyphicon-folder-open"></span>
                                        <span class="image-preview-input-title" id="sp_email_logo">Browse</span>
                                        <%--  <input type="file" accept="image/png, image/jpeg, image/gif" name="input-file-preview" />--%>
                                        <asp:FileUpload ID="uplemail_Logo" runat="server" class="image-logo" err="required" filetype="image" accept=".jpg , .gif ,.png ,.jpeg" required="True" />
                                        <!-- rename it -->
                                    </div>
                                </span>
                            </div>
// Create the close button
            var closebtn = $('<button/>', {
                type: "button",
                text: 'x',
                id: 'print-close-preview',
                style: 'font-size: initial;',
            });
            closebtn.attr("class", "close pull-right");
            // Set the popover default content
            $('#div_print_logo').popover({
                trigger: 'manual',
                html: true,
                title: "<strong>Preview</strong>" + $(closebtn)[0].outerHTML,
                content: "There's no image",
                placement: 'bottom'
            });
            // Clear event
            $('#btn_print_logo').click(function () {
                $('#div_print_logo').attr("data-content", "").popover('hide');
                $('#txb_print_logo').val("");
                $('#btn_print_logo').hide();
                $('#div_print_logo_preview input:file').val("");
                $("#sp_print_logo").text("Browse");
            });
            // Create the preview image
            $("#div_print_logo_preview input:file").change(function () {
                var img = $('<img/>', {
                    id: 'dynamic',
                    width: 250,
                    height: 200
                });
                var file = this.files[0];
                var reader = new FileReader();
                // Set preview image into the popover data-content
                reader.onload = function (e) {
                    $("#sp_print_logo").text("Change");
                    $("#btn_print_logo").show();
                    $("#txb_print_logo").val(file.name);
                    img.attr('src', e.target.result);
                    $("#div_print_logo").attr("data-content", $(img)[0].outerHTML).popover("show");
                }
// New tweaks
                if (file) {
                    reader.readAsDataURL(file);
                }
                else {
                    $("#sp_print_logo").text("Change");
                    $("#btn_print_logo").show();
                    var src = $('#<%= imgPrintLogo.ClientID%>').attr("src");
                    img.attr('src', src);
                    $("#div_print_logo").attr("data-content", $(img)[0].outerHTML).popover("show");
                }
            });  
div class=" image-preview form-group  col-lg-6" id="div_email_logo" style="display: table">
                                <input type="text" class="form-control image-preview-filename" runat="server" disabled="disabled" placeholder="email Logo" id="txb_email_logo">
                                <!-- don't give a name === doesn't send on POST/GET -->
                                <span class="input-group-btn">
                                    <!-- image-preview-clear button -->
                                    <button type="button" class="btn btn-default image-preview-clear" id="btn_email_logo" style="display: none;">
                                        <span class="glyphicon glyphicon-remove"></span>Clear
                                    </button>
                                    <!-- image-preview-input -->
                                    <div class="btn btn-default image-preview-input" id="div_email_logo_preview">
                                        <span class="glyphicon glyphicon-folder-open"></span>
                                        <span class="image-preview-input-title" id="sp_email_logo">Browse</span>

                                        <asp:FileUpload ID="uplemail_Logo" runat="server" class="image-logo" err="required" filetype="image" accept=".jpg , .gif ,.png ,.jpeg" required="True" />
 <%-- Added Tweaks--%>
                                        <asp:Image ID="imgLogo" runat="server" Width="250" height="200" style="display: none;"/>
                                        <!-- rename it -->
                                    </div>
                                </span>
                            </div>