如果想发现并响应一个对象的变化,就应该使用监控属性(observables),如果想发现并响应一个集合的变化,就需要使用监控属性数组(observableArray)。在很多情况下,它都非常有用,比如你要在UI上需要显示/编辑的一个列表数据集合,然后对集合进行添加和删除。

  声明ObservableArray

var myObservableArray = ko.observableArray();
myObservableArray.push("some value");

  将一个对象放在observableArray里不会使这个对象本身的属性变化可监控,observable只会监控它拥有的对象,并在这些对象添加或删除的时候发出通知。

  如果想在初始化数组的时候给其赋初值,可以在构造器里加入这些初始对象。

var anotherObservableArray = ko.observableArray([
{name: "Bungle", type: "Bear" },
{name: "George", type: "Hippo" },
{name: "Zippy", type: "Unknown" }
]);

  一个observableArray其实就是一个observable的监控对象,只不过他的值是一个数组,可以用JavaScript的数组函数进行数组的访问:

alert('The length of the array is ' + myObservableArray().length);    //The length of the array is 1
alert('The first element is ' + myObservableArray()[0]); //The first element is some value
alert('The length of the array is ' + anotherObservableArray().length); //The length of the array is 3
alert('The first element is ' + anotherObservableArray()[0]); //The first element is [object Object]

  ObservableArray的常用方法

  可以观察到上面访问数组的时候,使用的是JavaScript的函数,但KO提供了更好的功能等价函数,有以下优点:

  ♦ 兼容所有浏览器。

  ♦ 在数组操作函数方面(如push和splice等),KO可以自动触发依赖跟踪,并通知所有的订阅者它的变化,然后让UI界面相应地自动更新。

  ♦ 语法更方便(如myObservableArray.push(...)比myObservableArray().push(...)来的方便吧??)

  1.indexOf()

    myObservableArray.indexOf('Blah'):返回以0为第一个索引的第一个Blah的匹配项的索引

  2.slice()

    myObservableArray.slice(...):返回给定的从开始索引到结束索引之间所有的对象集合

  3.push()

    myObservableArray.push(‘some new value’):在数组末尾添加一个新项

  4.pop()

    myObservableArray.pop():删除数组最后一项并返回返回该项

  5.unshift()

    myObservableArray.unshift(‘some new value’):在数组头部添加一个项

  6.shift()

    myObservableArray.shift():删除数组头部第一项并返回该项

  7.reverse()

    myObservableArray.reverse():翻转整个数组的顺序

  8.sort()

    myObservableArray.sort():给数组排序

  9.splice()

    myObservableArray.splice(1,3):删除指定开始索引"1"和指定数目"3"的数组对象元素(第2,3,4个元素)。

  10.remove和removeAll

    myObservableArray.remove(someItem); // 删除所有等于someItem的元素并将被删除元素作为一个数组返回
    myObservableArray.remove(function(item) { return item.age < 18 }); // 删除所有age属性小于18的元素并将被删除元素作为一个数组返回
    myObservableArray.removeAll(['Chad', 132, undefined]); // 删除所有等于'Chad', 123, or undefined的元素并将被删除元素作为一个数组返回

  11.destroy和destroyAll

    myObservableArray.destroy(someItem) 找出所有等于someItem的元素并给他们添加一个属性_destroy,并赋值为true
    myObservableArray.destroy(function(someItem) { return someItem.age < 18 }) 找出所有age属性小于18的元素并给他们添加一个属性_destroy,并赋值为true
    myObservableArray.destroyAll(['Chad', 132, undefined]) 找出所有等于'Chad', 123, 或undefined 的元素并给他们添加一个属性_destroy,并赋值为true   

  在KO render一个foreach模板的时候,会自动隐藏带有_destroy属性并且值为true的元素。
  所以如果你的"delete”按钮调用destroy(someItem) 方法的话,UI界面上的相对应的元素将自动隐藏,然后等你提交这个JSON对象到Rails上的时候,这个元素项将从数据库删除(同时其它的元素项将正常的插入或者更新)。

最新文章

  1. Struts 2的拦截器(Interceptor)总结
  2. DOM对象
  3. XML解析方案
  4. IUS
  5. C++复习-练习-1
  6. SQL 数据库 函数
  7. 006NFS与TFTP服务器
  8. linux重启oracle 各种方法
  9. jquery 文本框失去焦点显示提示信息&amp;&amp;单击置空文本框
  10. 慕课网《Android智能机器人“小慕”的实现》项目上手操作与代码解读【2】
  11. SQL Server-聚焦SNAPSHOT基于行版本隔离级别详解(三十)
  12. jmeter IP欺骗功能实现
  13. Dedecms列表页标签list/pagelist使用方法及pagelist的样式
  14. java中public private protected default的区别
  15. Bot Framework 搭建聊天机器人
  16. P1516 青蛙的约会
  17. int main(int argc,char* argv[]) 的含义和用法
  18. python中argparse模块用法实例详解
  19. 从EnableJpaRepositories说开去
  20. Implementing On Item Click / Double Click for TListView

热门文章

  1. 【NOIP】提高组2013 积木大赛
  2. Android通知栏介绍与适配总结
  3. Intersecting Lines (计算几何基础+判断两直线的位置关系)
  4. Java 将html导出word格式
  5. eclipse执行maven install命令时跳过test
  6. 2017-2018-1 20179205《Linux内核原理与设计》第六周作业
  7. Android日历开发之右上角标注红点事件
  8. Python-字符串处理 str.format()
  9. Laravel 5.2 三、中间件、视图与 Blade 模板引擎
  10. 更新T1表,要添加一个条件A,但T1表没有A字段