5

我需要显示来自其他站点的图像,并拥有一个具有imgsrc引用图像 URL 的属性的视图模型。然后我有以下 HTML 绑定:

<img data-bind="attr: { src : imgsrc }" />

问题是绑定图像是外部的,如果外部站点出现问题,我可能会得到 404 或 500 响应;因此,我想显示一个后备图像,以防我们无法加载图像。

如何使用 KnockoutJS 实现这一点?

4

1 回答 1

4

您可以使用该onerror事件。

HTML:

<img id="pic" data-bind="attr: { src : imgsrc }" />

JavaScript:

var myViewModel = {
    imgsrc: ko.computed(function () {
        var pic = document.getElementById('pic');
        pic.onerror = function () {
            pic.src = 'fallback image url';
        };
        return 'image url';
    }, this)
};

ko.applyBindings(myViewModel);

示例:http: //jsfiddle.net/R4SV7/1/

于 2013-09-08T18:08:37.540 回答