无法获得淘汰对象的财产价值

时间:2012-07-13 17:33:44

标签: knockout.js

当我尝试在I get函数文本'函数b(){if(0 ...'。需要更改为什么)中的click事件(removeAFoo - > removeFoo)中获取foo.Id的值时获取foo的属性值.Id?另一个奇怪的事情是当我在viewModel.foos数组上调用indexOf()时,它返回索引,即使该数组表示它的长度为零。

function getFoos() {
    viewModel.foos([]);
    var data = [{
        Id: 1,
        Name: 'Joe' },
    {
        Id: 2,
        Name: 'Jon' },
    {
        Id: 3,
        Name: 'Jim' }        
    ]

    for (var i = 0; i < data.length; i++) {
        var f = new foo();
        f.Id(data[i].Id);
        f.Name(data[i].Name);

        viewModel.foos.push(f);
    }
};

var viewModel = {
    foos: ko.observableArray([]),

    reloadFoos: function() {
        getFoos();
    },

    removeAFoo: function(foo) {
        removeFoo(foo);
    }
};

var foo = function() {
    this.Id = ko.observable();
    this.Name = ko.observable();
};

function removeFoo(foo) {
    alert(viewModel.foos.indexOf(foo));
    alert(foo.Id);
    viewModel.foos.splice(viewModel.foos.indexOf(foo), 1);
}

ko.applyBindings(viewModel);

getFoos();
​

<div data-bind="foreach: foos">
    <div style="float: left">
        <button data-bind="click : $parent.removeAFoo, attr: { id: Id }">
        </button>
        <label data-bind="text: Name">
        </label>
    </div>
</div>​

http://jsfiddle.net/suedeuno/gAUgV/12/

1 个答案:

答案 0 :(得分:6)

要获取foo.id的值,您需要记住使用括号:

像这样:

文件撰写(foo.Id());