1

在 Backbone 视图使用的下划线模板中,我有一个图像。如果找不到原始图像,我正在尝试附加到错误事件并更改图像源。

基于这个类似的问题,我采取了以下方法:

render: function() { 
    var self = this;

    this.$el.html( this.template( { person: this.model.toJSON() } ) ); 

    this.$el.find('img.employee-image').on('error', function(evt) { this.src = "assets/images/_noimage.gif"; });

    return this;
}

这工作得很好,但是如果我尝试将 src 的更改移动到视图中的单独方法,该方法将被调用但图像不会改变。

render: function() { 
    var self = this;

    this.$el.html( this.template( { person: this.model.toJSON() } ) ); 

    this.$el.find('img.employee-image').on('error', function(evt) { self.handleMissingImage(evt); });

    return this;
},

handleMissingImage: function(evt) {
    // This by itself did not work.
    // this.src = "assets/images/_noimage.gif";

    var i = $(evt.currentTarget);
    i.src = "assets/images/_noimage.gif";
    console.log(i.src);
}

注销 src 会显示“assets/images/_noimage.gif”,但图像不会出现。我知道它存在,因为上面概述的第一种方法效果很好。

我在这里想念什么?

4

1 回答 1

0

我认为你的问题就在这里:

i.src = "assets/images/_noimage.gif";

在您的handleMissingImage功能中,您说:

i = $(evt.currentTarget);

jQuery 对象也是如此i,而不是原始 DOM 元素。这意味着您想说i.attr('src', ...)更改src属性或根本不打扰包装evt.currentTarget

于 2013-11-07T21:26:07.930 回答