来自外部网站的图像的后备img src

时间:2013-09-08 15:23:06

标签: javascript knockout.js

我需要显示来自其他网站的图片,并且具有引用图片网址的imgsrc属性的视图模型。然后我有以下HTML绑定:

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

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

如何使用KnockoutJS实现这一目标?

1 个答案:

答案 0 :(得分: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/