我需要显示来自其他站点的图像,并拥有一个具有imgsrc
引用图像 URL 的属性的视图模型。然后我有以下 HTML 绑定:
<img data-bind="attr: { src : imgsrc }" />
问题是绑定图像是外部的,如果外部站点出现问题,我可能会得到 404 或 500 响应;因此,我想显示一个后备图像,以防我们无法加载图像。
如何使用 KnockoutJS 实现这一点?
我需要显示来自其他站点的图像,并拥有一个具有imgsrc
引用图像 URL 的属性的视图模型。然后我有以下 HTML 绑定:
<img data-bind="attr: { src : imgsrc }" />
问题是绑定图像是外部的,如果外部站点出现问题,我可能会得到 404 或 500 响应;因此,我想显示一个后备图像,以防我们无法加载图像。
如何使用 KnockoutJS 实现这一点?
您可以使用该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/