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