Javascript FileReader多个图像

She*_*shi 4 html javascript jquery image filereader

我正在尝试在我的项目中实现javascript的FileReader接口。

要求:有一个启用了“多个”的文件输入字段,我希望用户应该选择一些图像,甚至在单击提交之前,也应该在页面上看到这些图像,这样,如果(s )他要!)。但是问题在于屏幕上仅显示一张图像。标签已创建,但src为空,除了最后一个图像。

代码:

<html>
<head>
    <meta charset="windows-1252">
    <title></title>
</head>
<body>
    <div>
        <form action="upload.php" method="post" enctype="multipart/form-data">
            <input type="file" name="abc[]" multiple/>
            <input type="submit"/>
        </form>
    </div>
<img id="image0"/>
</body>

<script src="resources/js/jquery-2.1.3.min.js" type="text/javascript"></script>
<script>
    $('document').ready(function () {
        $("input[name='abc[]']").change(function (e) {
            console.log(e.originalEvent.srcElement.files.length);
            for (var i = 1; i <= e.originalEvent.srcElement.files.length; i++) {

                var file = e.originalEvent.srcElement.files[i-1];
                var img = document.createElement("img");
                img.id = "image"+i;
                var reader = new FileReader();
                reader.onloadend = function () {
                    img.src = reader.result;
                }
                reader.readAsDataURL(file);
                $("#image"+(i-1)).after(img);
            }
        });
    });
</script>
Run Code Online (Sandbox Code Playgroud)

例如,如果我选择了img1,则在图像选择弹出窗口中。img2和img3,仅显示img3。但是,在点击提交时,我确实在服务器端获得了所有图像: 在此处输入图片说明

我在这里想念什么?

Mus*_*usa 5

看一下JavaScript闭包如何工作?

for onloadend回调将在for循环完成后触发,因此img将为您onloadend为每个FileReader创建的对象触发时创建的最后一个图像元素。解决此关闭问题的一种简单方法是使用IIFE返回一个函数,该函数使用循环中该时刻的img变量的值作为处理程序。

            reader.onloadend = (function (img) {
                return function(){
                    img.src = reader.result;
                };
            })(img)
Run Code Online (Sandbox Code Playgroud)

或使用每个 JQuery

        $.each(e.originalEvent.srcElement.files, function(i, file) {

            var img = document.createElement("img");
            img.id = "image"+(i+1);
            var reader = new FileReader();
            reader.onloadend = function () {
                img.src = reader.result;
            }
            reader.readAsDataURL(file);
            $("#image"+i).after(img);
        });
Run Code Online (Sandbox Code Playgroud)