Knockout可观察绑定仅在第一次ajax调用后更新
Knockout observable binding only update after first ajax call
使用Knockout via Durandal(v.1.2)Knockout Observable在作为AJAX调用的结果更新后不会更新绑定,第一次除外。
ViewModel:
define(["require", "exports"], function(require, exports) {
var About = (function () {
function About() {
var _this = this;
this.Code = ko.observable("Initial Content");
$.get("MyXml.xml", function (data) {
return _this.DataLoaded(data);
}, "text");
}
About.prototype.DataLoaded = function (data) {
this.Code(data.toString());
};
return About;
})();
return About;
});
视图:
<div>
<h2>About</h2>
<p data-bind="text: Code"></p>
</div>
视图模型通过Durandals composer绑定到视图,但我在香草淘汰赛中遇到了同样的问题。第一次合成视图时会正确显示文件的内容,但之后再次合成视图时,绑定在初始值之后不会更新。加载文件,并调用用于更新可观察的代码,不会引发错误。以前,我只是通过使用setInterval延迟更新来解决这个问题。再加上它第一次工作的事实,对我来说,这表明它是一个种族条件错误。但我不知道问题出在哪里。
有没有什么时间段不应该更新可观察到的?有没有一个好的模式可以避免这种情况?
编辑
目前,我正在使用viewAttached方法(Durandal)来了解何时可以安全更新,但我仍然想知道根本原因,以及任何更好的解决方案。
初始化东西应该是安全的。我也使用激活钩子,并在那里返回一个承诺。不确定哪一个是首选活动。根本问题可能是因为Ajax调用缺少承诺。尝试至少将$.Ajax
与async: false
一起使用。
相关文章:
- 另一个ajax调用中的Jquery ajax调用在for循环中没有按预期工作
- Javascript/jQuery中的并行Ajax调用
- 任何方式使AJAX调用Gmail API,而无需通过JS库
- node.js请求数据事件未在CORS ajax调用中触发
- 如何从ajax调用返回.wrap()元素
- Ajax调用在Firefox中不会自动响应
- AJAX调用中的非法调用
- 使用AJAX调用将GeoJSON数据拉入传单
- 在MVC 4中,对Controller的Ajax调用为空
- Jquery:对返回JSON数据的php脚本的Ajax调用
- 在ajax调用中阻止来自JS对象的函数
- 如何在MVC5中ajax调用的部分视图中引用外部javascript
- 页面加载后的Ajax调用
- 如何使用Ajax调用特定的控制器和操作来重定向用户
- curl和fileget_contents在ajax调用后不起作用
- 在任何AJAX调用之前触发一个javascript函数
- 无法在mvc视图中使用ajax调用获取操作返回的模型对象列表
- Ajax调用ERror Cross Origin REquest:在rails中自动完成大学列表
- ASP.NET MVC 3-在ajax调用后,重定向到新页面或生成页面刷新
- 点击功能没有'ajax调用动态元素(Backbone)后无法工作