为什么这个knockoutjs observableArray不会导致UI更新?

Posted

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了为什么这个knockoutjs observableArray不会导致UI更新?相关的知识,希望对你有一定的参考价值。

我有一种感觉,我在这里错过了一些简单的东西,但是我不能理解这一点。这是我的脚本:

function FormDefinition()
{
    var self = this;
    self.Fields = ko.observableArray([new FieldDefinition()]);    
}

function FieldDefinition()
{
    var self = this;
    self.Name = "Test";
}
function ViewModel()
{
    var self = this;
    self.formDef = ko.observable(new FormDefinition());
    self.Name = "bob"
    self.addField = function(){
        this.formDef().Fields().push(new FieldDefinition());                    
    }            
}

ko.applyBindings(new ViewModel());

这是我的标记:

<a data-bind="click: addField">Add</a><br/>
<span data-bind="text: Name"></span>
<ul data-bind="foreach: formDef().Fields">
    <li data-bind="text: Name"></li>
</ul>​

这是一个jsFiddle:http://jsfiddle.net/5xSmr/

预期的行为是单击“添加”将导致ui更新。调试显示addfield被调用。

答案

修正了你的小提琴:http://jsfiddle.net/5xSmr/2/

<a data-bind="click: AddField">Add</a><br/>
<span data-bind="text: Name"></span>
<ul data-bind="foreach: formDef().Fields()">
    <li data-bind="text: Name"></li>
</ul>
function FormDefinition()
{
    var self = this;
    self.Fields = ko.observableArray();    
}

function FieldDefinition()
{
    var self = this;
    self.Name = "Test";
}
function ViewModel()
{
    var self = this;
    self.formDef = ko.observable(new FormDefinition());
    self.Name = "bob"
    self.AddField = function(){
        this.formDef().Fields.push({Name:"test"});
    }            
}

ko.applyBindings(new ViewModel());

主要问题是你调用Fields()而不仅仅是Fields。 Fields()返回展开的数组并直接推送到它,ko永远不会知道它。

另一答案

干得好 :-)

http://jsfiddle.net/JasonMore/Q6J6a/3/

视图

<a href='#' data-bind="click: AddField">Add</a><br/>
<span data-bind="text: Name"></span>
<ul data-bind="foreach: formDef.Fields">
    <li data-bind="text: Name"></li>
</ul>​

使用javascript

var FormDefinition = function ()
{
    var self = this;
    self.Fields = ko.observableArray();    
}

var ViewModel = function()
{
    var self = this;
    self.formDef = new FormDefinition();
    self.Name = ko.observable("bob");
    self.AddField = function(){
        self.formDef.Fields.push({Name:"test"});            
    }            
}

ko.applyBindings(new ViewModel());

以上是关于为什么这个knockoutjs observableArray不会导致UI更新?的主要内容,如果未能解决你的问题,请参考以下文章

html 使用AJAX POST请求来调用控制器操作(在页面加载时和在下拉列表中选择项目时),获取返回的布尔值,设置observabl

KnockoutJS:设置 optionValue 打破“与”绑定

KnockoutJS调用可观察的属性

KnockoutJs - 为啥初始化绑定处理程序只被调用一次?

KnockoutJs - 计算数据库评级

使用 Knockoutjs 获取设置值属性