繁体   English   中英

带预览和删除的多张图片上传,Jquery 和 Javascript

[英]Multiple Image upload with previw and delete , Jquery and Javascript

我这里有问题。 我使用此代码多次选择和预览图像,但我需要删除选定的图像。 例如,我 select 5 图像要预览,我有预览但我不喜欢其中一张我想删除选定的图片。 在这里,当我单击删除图像时,我刚刚重置。 使用旧代码(我发表评论)我刚刚隐藏了未删除的图像。 我试图在这里找到解决方案,但它不起作用。

 $(document).ready(function() { if (window.File && window.FileList && window.FileReader) { $("#files").on("change", function(e) { var files = e.target.files, filesLength = files.length; for (var i = 0; i < filesLength; i++) { var f = files[i] var fileReader = new FileReader(); fileReader.onload = (function(e) { var file = e.target; $("<span class=\"pip\">" + "<img class=\"imageThumb\" src=\"" + e.target.result + "\" title=\"" + file.name + "\"/>" + "<br/><span class=\"remove\">Remove image</span>" + "</span>").insertAfter("#files"); $(".remove").click(function(){ $(this).parent(".pip").remove(); $('#files').val(""); }); /* $(".remove").click(function(){ $(this).parent(".pip").remove(); });*/ }); fileReader.readAsDataURL(f); } }); } else { alert("Your browser doesn't support to File API") } });
 input[type="file"] { display: block; }.imageThumb { max-height: 75px; border: 2px solid; padding: 1px; cursor: pointer; }.pip { display: inline-block; margin: 10px 10px 0 0; }.remove { display: block; background: #444; border: 1px solid black; color: white; text-align: center; cursor: pointer; }.remove:hover { background: white; color: black; }
 <script src="https://cdnjs.cloudflare.com/ajax/libs/jquery/3.3.0/jquery.min.js"></script> <div class="field" align="left"> <h3>Upload your images</h3> <input type="file" id="files" name="files[]" multiple /> </div>

首先,为$("#files").on("change"之外的删除按钮添加一个处理程序,因此处理程序的逻辑将只运行一次。在新处理程序中,您必须找到图片的索引删除,然后用过滤后的文件创建一个DataTransfer,最后用DT的文件覆盖输入的文件。

$(document).on('click', '.remove', function(){
            var pips = $('.pip').toArray();
            var $selectedPip = $(this).parent('.pip');
            var index = pips.indexOf($selectedPip[0]);

            var dt = new DataTransfer();
            var files = $("#files")[0].files;

            for (var fileIdx = 0; fileIdx < files.length; fileIdx++) {
                if (fileIdx !== index) {
                dt.items.add(files[fileIdx]);
              }
            }

            $("#files")[0].files = dt.files;

            $selectedPip.remove();
          });

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM