首页
学习
活动
专区
工具
TVP
发布
社区首页 >问答首页 >从.ajax()调用加载knockout.js observableArray()

从.ajax()调用加载knockout.js observableArray()
EN

Stack Overflow用户
提问于 2012-03-16 09:09:26
回答 5查看 46K关注 0票数 20

这让我困惑不解。一定是我没看到的小东西。我正在尝试使用ajax调用在knockout中加载一个非常简单的observableArray

javascript

代码语言:javascript
复制
// we bind the array to the view model property with an empty array.
var data = [];   
var viewModel = {
    vendors: ko.observableArray(data)
};
ko.applyBindings(viewModel);

$(function () {
    // on this click event, we popular the observable array
    $('#load').click(function () {
        // WORKS. Html is updated appropriately.
        viewModel.vendors([{ "Id": "01" },{ "Id": "02" },{ "Id": "03" }]);

        // DOES NOT WORK. Fiddler2 shows the same exact json string come back 
        // as in the example above, and the success function is being called.
        $.ajax({
            url: '/vendors/10',
            dataType: 'json',
            success: function (data) {
                viewModel.vendors(data);
            }
        });
    });
});

html

代码语言:javascript
复制
<button id="load">Load</button>
<ul data-bind="template: { foreach: vendors }">
    <li><span data-bind="text: Id"></span></li>
</ul>

问题:为什么成功的ajax调用,谁的data变量值与硬类型的值完全匹配,却没有触发html刷新?

EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/9730496

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档