Image.onload() 的 JavaScript 循环/作用域问题

标签 javascript image loops scope

我正在尝试使用 JavaScript 遍历对象并将该对象的所有子对象添加到 HTML5 Canvas 。

canvas-bit 正在工作,这没问题,但出于某种原因,我所有的图像最终都是相同的大小——最后一个子对象“背景”的大小。我假设它与我的循环和“this”的范围有关,但我真的看不出要改变什么;

var stage;
var items = {
    head: {image: null, path: "images/avatar-elements/head01.png", w:200, h:200},
    hair: {image: null, path: "images/avatar-elements/hair01.png", w:200, h:200},
    nose: {image: null, path: "images/avatar-elements/nose01.png", w:200, h:200},
    eyes: {image: null, path: "images/avatar-elements/eyes01.png", w:200, h:200},
    eyebrows: {image: null, path: "images/avatar-elements/eyebrows01.png", w:200, h:200},
    ears: {image: null, path: "images/avatar-elements/ears01.png", w:200, h:200},
    background: {image: null, path: "images/avatar-elements/background01.png", w:500, h:370}
};

function initCanvas() {
    stage = new Kinetic.Stage("canvas", 500, 370);
    makeBasis();
}


function makeBasis() {
    for(i in items) {
        var img = new Image();
        img.onload = function() {
            items[i].image = makeCanvasImage(this, items[i].w, items[i].h);
        }
        img.src = items[i].path;
    }


}

function makeCanvasImage(tar, w, h) {
    var theImage = new Kinetic.Image({
        imageObj: tar,
        x: 250 - (w / 2),
        y: 185 - (h / 2),
        width: w,
        height: h
    });
    stage.add(theImage);
    return theImage;
}

initCanvas();

最佳答案

错误在 makeBasis() 中。在循环所有图像后 i 被设置为 last - 经典的闭包问题。尝试使用这个:

function makeBasis() {
    for(i in items) {
        var img = new Image();
        img.onload = (function (nr) {
            return function() {
                items[nr].image = makeCanvasImage(this, items[nr].w, items[nr].h);
            }
        }(i));      
        img.src = items[i].path;
    }
}

关于Image.onload() 的 JavaScript 循环/作用域问题,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/8741023/

相关文章:

javascript - 如何为不同的对象切换相同的对象?

javascript - 使用 jQuery 更改 img src 而不多次加载图像?

java - Spring MVC,Java : Creating URL for image saved on FileSystem

css - 无法让我的元素符号列表正确显示

java - 数据库中的循环与应用程序中的循环

java - 环游世界寻找最低点开始

grails - Grails如何遍历参数和设置值

javascript - Transcrypt 在导入 json 时出现无法导入编解码器错误

c# - 将 jquery 引用移动到 asp.net 母版页时出现 java 脚本错误

javascript - jQuery UI 可排序和可拖动问题