作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 stackoverflow 和 knockout 的新手,我有一个问题。我想通过索引访问一个 JSON 对象。如果我在我的代码中添加虚拟数据,它工作正常,但如果我从 JSON 添加数据并停止,它会给我一个错误。
错误未捕获的类型错误:无法处理绑定(bind)“text: function (){return Ads()[0].AdContent }”消息:无法读取未定义的属性“AdContent”
我的 View 模型:
function AdListModel () {
var self = this;
self.Ads = ko.observableArray([]);
$.ajax({
type: "GET",
url: '/Home/GetAllAds',
contentType: "application/json; charset=utf-8",
dataType: "json",
success: function (data) {
self.Ads(data);
},
error: function (err) {
alert(err.status + " : " + err.statusText);
}
});
}
ko.applyBindings(new AdListModel());
我收到的 JSON
[{"AdId":6,"AdContent":"sadasdasdsad","CategoryId":1,"CategoryNameRU":"Дом, стройка, ремонт"},{"AdId":12,"AdContent":"asdasd","CategoryId":1,"CategoryNameRU":"Дом, стройка, ремонт"}]
我的 HTML
<div data-bind="text: Ads()[0].AdContent"></div>
<div data-bind="foreach: Ads">
<p data-bind="text: AdId"></p>
<p data-bind="text: AdContent"></p>
<p data-bind="text: CategoryId"></p>
<p data-bind="text: CategoryNameRU"></p>
</div>
所以,基本上我只想读取索引为 0 的 JSON 对象中的一个属性,然后显示所有数组。
最佳答案
“广告”数组为空,直到您在 ajax 调用上没有得到响应。因此“Ads()[0]”是未定义的。
您可以在绑定(bind)中使用额外的检查:
<!-- ko if: Ads().length > 0 -->
<div data-bind="text: Ads()[0].AdContent"></div>
<!-- /ko -->
注意:“foreach”绑定(bind)正确处理空数组。
关于javascript - 如何在 knockout observablearray 中按索引访问对象?无法处理绑定(bind),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/35126105/
我是一名优秀的程序员,十分优秀!