2

几天来,我一直在尝试让 Knockout 每次在人员列表上的“邮政编码”值发生变化时引发一个事件。我尝试了各种方法来实现这种行为,但似乎无法做到正确。目前,这是我拥有的 Html:-

<table>
    <thead>
        <tr>
            <th>First name</th>
            <th>Last Name</th>
            <th>Age</th>
            <th>Zip Code</th>
        </tr>
    </thead>
    <tbody data-bind="foreach: people">
        <tr>
            <td data-bind="text: firstName"></td>
            <td data-bind="text: lastName"></td>
            <td data-bind="text: age"></td>
            <td ><input id="zipCodInput" data-bind="value: zipCode" /></td>
        </tr>
    </tbody>
</table>
</body>

这是我拥有的填充表格的脚本: -

<script>
    jQuery(document).ready(function () {

        // Ultimately will come from an Ajax call
        //var result = $.ajax({
        //    type: "GET",
        //    url: "/api/Resource",
        //    async: false
        //}).responseText;

        // Hard coded array for testing
        var result = [{ "firstName": "Jimmy", "lastName": "Smith", "age": "43", "zipCode": "" },
        { "firstName": "John", "lastName": "Jones", "age": "23", "zipCode": "" },
        { "firstName": "Sarah", "lastName": "Palmer", "age": "26", "zipCode": "GH7HU" },
        { "firstName": "Fred", "lastName": "Smith", "age": "34", "zipCode": "" },
        { "firstName": "Simon", "lastName": "Davis", "age": "53", "zipCode": "" }];

        function viewModel() {
            var myArray = ko.observableArray(result);

            myArray.subscribe(function (changes) {
                console.log(changes);
            }, null, "arrayChange");

            people = myArray;
        };

        ko.applyBindings(new viewModel());
    });
</script>

它正确绑定了数据,但是在编辑页面上的邮政编码行时,我从未记录任何更改。知道如何修改或重写代码以捕获这些更改吗?

最终,我只想将更改的行添加到 json 数组中以回发服务器端。

谢谢你。

4

2 回答 2

5

默认情况下,您不会在此处收到 observableArray 级别的通知。observableArray 之所以只关注其目录中的项目,而不是这些项目的属性是否发生变化。

如果你想观察变化,你可以这样做 -

var myArray = ko.observableArray(result);
ko.utils.arrayForEach(myArray(), function (thisItem) {
    thisItem.subscribe(function (changes) {
        console.log(changes);
    });
});

people = myArray;

这将订阅 observableArray 中的每个单独的对象,并在该对象的属性更改时触发。

于 2013-11-11T16:28:45.747 回答
0

如果数组本身发生变化,这将起作用,但要跟踪数组内对象的变化,你应该有一个可观察的数组......

Knockout 网站上的这个示例应该可以帮助您:http:
//knockoutjs.com/examples/contactsEditor.html

于 2013-11-11T16:29:43.457 回答