JavaScript:如何按顺序加载图像

时间:2018-10-09 23:02:28

标签: javascript jquery image

对不起,我的英语不是我的母语。

我正在尝试从一个输入文件压缩多个图像。但是当我尝试放

img.onload = function() {}

在包含文件序列的for循环中,附加结果完全乱序。

Load sequence out of order

我需要按顺序排列图像,因为我正在安装包含图像,公交车号和照片日期的PDF。

原始图像太大,超过3MB。生成的.pdf文件为62MB。无法使用。

var filesInput = $("#file"); filesInput.on("change", function(e) {

$("#divImagesFrame").show();

/* Manipulação das fotos */ 
var files = e.target.files;
var result = $("#divImagesFrame");
var filesLength = this.files.length;

var page = 1;
var count = 6;

$("#blur, #pageName").html($("#txtCliente").val());

result.append("<div class='pageTitle'><div class='pageBox'>" + page + "</div><span>" + $("#txtCliente").val() + "<span class='localName'>" + $("#txtCampanha").val() + "</span></span></div>");

for (let i = 0; i < this.files.length; i++) {

    qtdFotos++;
    let url = URL.createObjectURL(this.files[i]);
    let img =  new Image();
    img.src = url;

    console.log("ID outside img.load: " + i);

    img.onload = function(){

    console.log("ID inside img.load: " + i);

    var busNumber = files[i].name.toString().split(".")[0]; 
        var dataFoto = files[i].lastModified;
        var d = new Date(dataFoto);
        d.toLocaleString(); 

    var canvas = document.createElement('canvas');
    canvas.width = 460;
    canvas.height = 360;
    ctx = canvas.getContext('2d');
    ctx.drawImage(img, 0,0, canvas.width, canvas.height);

    var imageFile = canvas.toDataURL("image/JPEG", 1.0);

    /* In this result.append, if I put the image source = img.src the order of images stay ok, but the size is much larger */
    result.append("<div class='imageFrame' style='width:460px; border-radius:10px; height:360px; float:left; margin:14.01px 20px; box-shadow:1px 1px 3px 0.8px #999;'>" +
            "<div style='float:left;border-radius:10px 10px 0 0; background:linear-gradient(-90deg,#105e86,#125e86); display:block; width:450px; height:40px; font-weight:550; font-size:23px; line-height:40px; padding-left:10px; color:#FFF;'>" + busNumber + "<span style='font-size:18px; float:right; margin-right:20px;'>" + d.toLocaleDateString() + "</span></div>" +
            "<img width='460px' height='320px' style='border-radius:0 0 10px 10px; margin-bottom:5px;' src='" + imageFile + "'/></div>");

    }


}

sammiCreateBook();
});

这是必须的:

I want the result like this

这是img.load的结果,完全乱了。

Result of img.load

希望您能帮助我,非常感谢。

问题已解决

大家好谢谢。该问题已通过使用JavaScript承诺来验证每个功能是否已完成来解决。再次感谢!

1 个答案:

答案 0 :(得分:1)

  1. 将图像的URL存储在数组中
  2. 定义一个执行加载行为的函数(for循环内的块)
    • 在函数开始时,您需要从该数组中获取第一个URL并将其删除
    • 在函数主体的末尾,您需要再次调用该函数。
  3. 调用该功能。

这是一个例子:

var images = [
    '1.jpg',
    '2.jpg',
    '3.jpg',
];

var loadImage = function() {
    if (!images.length) {
        // Will be executed when all images are loaded
        return;
    }

    var image = images.shift();

    console.log('loading image ' + image);

    // Your for-loop logic here

    ...

    img.onload = function() {
        console.log('image loaded ' + image);
        // Your onload logic here ...

        // -> important!
        loadImage();
    };
}

loadImage();