在viewmodel中我试图动态地将项目推送到observableArray。 ajax正确返回数据。
html :
<li class="liTagulTagsChild" data-bind="click:$root.GetEmissions">/li>
的javascript:
var TagDetail = function (di_titre, di_diffusion) {
this.di_titre = ko.observable(di_titre);
this.di_diffusion = ko.observable(di_diffusion);
}
var testA = [];
this.test = ko.observableArray(testA);
this.GetEmissions = function (c, event) {
var element = event.target;
var tag_id = element.getAttribute('tag_id');
$.AjaxAntiforgery({
url: 'Emission/GetDetailsByTagID/',
data: {
tag_id: tag_id
},
success: function (result) {
for (var i = 0; i < result.length; i++) {
var tD = new TagDetail(result[i].DI_TITRE, result[i].DI_DIFFUSION);
this.test.push(tD);
}
}
});
}
问题: 在GetEmissions函数中,我无法将项目推送到this.test,因为this.test为null(未定义)。
换句话说,
this.test.push(tD);
失败。 (空引用或未定义) 任何解决方案?
答案 0 :(得分:2)
在Javascript中,“this”并不代表您认为的含义。查看How to access the correct `this` context inside a callback?