标签:
纵观KO的所有应用场景,基本上这2个属性至少会用到一个。个人认为这是KO最常使用的东西。他们用法如下:
*这里提2点:
- 虽然本文称之为“属性”,但是本质上他们是js的function对象,所以访问的时候需要加()号
- 默认情况下Computed的同步发生在任意的Observable变化的时候,可是某些情况下我们可能不希望它更新的如此频繁,比如用户正在输入的过程中。KO有其他办法来延迟更新,在本系列后面会有专门文章介绍。
本章的重点就是讲解这2个基本属性的用法,在后面的“实例讲解”中会详细说明。
KO中,绑定是需要激活的,可以理解为把viewModel的数据与Html文档的DOM元素进行分析和关联。
通常是在页面元素、viewModel数据加载完毕之后,就可以激活绑定了。当然你可以在任何时候你想进行绑定的时候来激活。
只需要下面的代码:
var model = new AppViewModel();//实例化一个viewModel ko.applyBindings(model); //绑定到整个页面
这样KO会在整个Body中寻找需要进行绑定的元素,与viewModel进行绑定。当然你也可以指定绑定的根节点,这样的好处:
很简单,加一个参数即可:
var model = new AppViewModel(); ko.applyBindings(model, document.getElementById("Demo1")); //Demo1可能是一个Div
1、定义
var myViewModel = { personName: ko.observable(‘Bob‘),//定义叫做personName的监控属性 personAge: ko.observable(123)//定义叫做personAge的监控属性 };
2、读取
var a=myViewModel.personName();//a为‘Bob‘
3、写入、连续写入(链式调用)
myViewModel.personName(‘Mary‘).personAge(50);//同时修改了2个属性值
4、订阅属性修改事件
myViewModel.personName.subscribe(function(newValue) { alert("The person‘s new name is " + newValue); }); myViewModel.personName(‘换个名字‘);//这时候会弹出alert
Knockout-了解Observable与computed
标签:
原文地址:http://www.cnblogs.com/niusys/p/4265695.html