2. 监控

1.通过监控创建视图模型

1. 监控

Knockout是基于以下三个核心特性:

  1. 监控和依赖跟踪
  2. 声明式绑定
  3. 模板

在本节,你将第一次了解这三个特性,在这之前,我们先来了解以下MVVM模式视图模型的概念。

2. MVVM和视图模型

Model-View-View Model (MVVM)是一种构建用户界面的设计模式。它描述了如何将存在复杂性的UI简单地分成三个部分:

  • 模型:用于你的应用程序存储数据。数据被表现为对象在你的业务逻辑里面进行操作(比如,银行账户可以进行转账业务)而且是和任何UI无关联。当你使用KO,你通常会使用Ajax调用一些服务端的代码来读写用于存储的数据模型。
  • 视图模型:在UI上的数据和操作的纯代码表示,比如,如果你想实现一个列表编辑器,你的视图模型会是一个带有一个列表项的对象,而且会暴露出添加项和移除项的方法。
  • 视图:一个表示视图模型状态的可视化的、可交互的UI界面。它显示来自视图模型的信息,传递命令给视图模型(比如,当用户点击按钮的时候),同时当视图模型无论何时发生改变的时候自动更新。

使用了KO以后,你的视图即HTML文档通过声明式绑定语法关联到视图模型,因此看起来很简单。另外,你可以通过模板使用来自视图模型的数据生成HTML。

要用KO创建一个视图模型,只要任意定义个一个javascript对象,比如

var myViewModel = {
personName: 'Bob',
personAge: 123
};

然后你可以使用声明式绑定语法创建一个非常简单的视图模型的视图。比如,下面的标记显示personName的值:

The name is <span data-bind="text: personName"></span>

3. 激活Knockout绑定

data-bind属性并不是html原生属性,尽管它是完全正确的(它是完全兼容HTML5,在HTML4里面也没有问题,尽管会被语法验证器指出这是未被规范承认的属性)。正因为浏览器不知道它代表什么,你需要激活Knockout来让该属性生效。

要激活Knockout,在<script>标签块之间添加如下内容:

ko.applyBindings(myViewModel);

你既可以把js代码放在你的html文档的底部,也可以通过DOM-ready处理函数如jQuery的$函数来包裹内容,然后放在顶部。

就是这样,现在你的视图看起来就像你写了下面的html内容后呈现的一样:

The name is <span>Bob</span>

这个时候如果你肯定很好奇要给 ko.applyBindings 传递什么参数

  • 第一个参数表示你要用什么视图模型对象来激活声明式绑定。
  • 你可以传递第二个可选参数来定义你想绑定文档中哪一部分的data-bind属性。比如,ko.applyBindings(myViewModel, document.getElementById('someElementId'))。这个限定了只激活ID为someElementId元素和子元素,当你想要多个视图模型关联页面中不同区域的时候非常有用。

很简单,真滴。

4. Observable方法

好了,你已经明白怎样创建一个基本的视图模型和怎样使用绑定来显示其中的一个属性。但是KO一个重要的好处是当你的视图模型改变的时候自动更新UI内容。KO怎么知道你的视图模型什么时候改变?答案是你需要通过observable来定义你的模型属性,因为这些特殊的javascript对象可以通知订阅者发生了什么改变,并能自动检测依赖。

比如,把前面的视图模型改为如下:

var myViewModel = {
personName: ko.observable('Bob'),
personAge: ko.observable(123)
};

你完全不需要改变视图,一样的data-bind语法会正常工作。不同在于现在有能力检测改变,当发生了改变,会自动改变视图。

5. 读写observable的值

不是所有的浏览器支持javascript的getters和setters(比如,IE)属性,为了兼容性,ko.observable返回的对象实际上是函数。

  • 获取监控对象当前值,只要无参调用observable方法即可。比如,myViewModel.personName() 会返回'Bob', 而 myViewModel.personAge()会返回123.
  • 设置监控对象的值,调用observable方法同时把要设置的值作为参数传入。比如,calling myViewModel.personName('Mary')会改变name的值为'Mary'
  • 设置模型对象上的多个监控属性值,你可以使用链式语法。比如,myViewModel.personName('Mary').personAge(50) 会改变name值为'Mary'age值为50.

observables的整个关键点就是他们可以被监控,换句话说,其他的代码想要被告知它发生了变化。这就是许多KO内置绑定实际上做的事情。所以,当我们写data-bind="text: personName",text绑定注册自己可被通知,当personName改变( 假设它现在是一个监控值)。

Knockout v3.4.0 中文版教程-2-监控-通过监控创建视图模型(上)的更多相关文章

  1. Knockout v3.4.0 中文版教程-3-监控-通过监控创建视图模型(下)

    6. 显式订阅监控 你通常不需要手动设置订阅,所以初学者应该跳过这一节. 对于高级用户,如果你想注册自己的订阅来监控通知变化,你可以使用 subscribe函数,比如: myViewModel.per ...

  2. Knockout v3.4.0 中文版教程-6-计算监控-可写的计算监控

    2.可写的计算监控 初学者可能想要跳过本节 - 可写的计算监控是相当高级的部分,在大多数情况下不是必需的. 通常,计算监控是一个通过其他监控值计算出的值,因此是只读的. 令人惊讶的是,可以使计算监控值 ...

  3. Knockout v3.4.0 中文版教程-8-计算监控-纯计算属性

    4.纯计算属性 纯计算监控在KO 3.2.0中开始引入,比大多数应用程序使计算监控有更大的性能提升和内存优化.这是因为在自身没有订阅的时候不会保持订阅状态.特性如下 阻止内存泄露 - 避免在应用程序里 ...

  4. Knockout v3.4.0 中文版教程-16-控制流-foreach绑定

    2. 控制流 1. foreach绑定 目的 foreach绑定会遍历一个数组,为每个数组项生成重复的元素标记结构并做关联.这在渲染列表或表格的时候特别有用. 假设你的数组是一个监控数组,之后无论你进 ...

  5. Knockout v3.4.0 中文版教程-14-控制文本内容和外观-style绑定

    5. style绑定 目的 style绑定用来给关联的DOM元素添加或移除一个或多个样式值.在如下情况很有用,比如,当某些值为负时,高亮显示,或者设置容器元素的宽度来匹配数值的改变. (注意:如果你不 ...

  6. Knockout v3.4.0 中文版教程-13-控制文本内容和外观-css绑定

    4. css绑定 目的 css绑定可以给关联的DOM元素添加或移除一个或多个CSS类.该绑定很有用,比如,当一些值为负数时高亮这些值为红色. (注意:如果你不想使用一个CSS类选择器来附加样式而想直接 ...

  7. Knockout v3.4.0 中文版教程-15-控制文本内容和外观-attr绑定

    6. attr绑定 目的 attr绑定可以给关联DOM元素的任何属性赋值.这个绑定很棒,比如,当你想要设置通过视图模型给元素的title属性.img标签的src属性或超链接的href值,当视图模型对应 ...

  8. Knockout v3.4.0 中文版教程-12-控制文本内容和外观-html绑定

    3. html绑定 目的 html绑定会使关联的DOM元素显示你参数指定的html内容. 当你的视图模型里面的值是HTML标记字符串,而你想要呈现它,这时候用html绑定特别合适. 例子 <di ...

  9. Knockout v3.4.0 中文版教程-5-计算监控-使用计算监控

    3. 计算监控 1.使用计算监控 如果你有一个监控的属性firstName和另一个lastName,但你想显示全名怎么办? 这就是引入计算监控的原因-这是依赖于一个或多个其他的observables函 ...

随机推荐

  1. VMware下OSSIM 4.1.0的下载、安装和初步使用(图文详解)

    不多说,直接上干货! 为什么,我写了一篇OSSIM 5.2.0的,还要再来写OSSIM 4.1.0呢,是因为,OSSIM 5.2.0所需内存较大,8G甚至16G,但是,肯定性能和里面集成组件越高级.也 ...

  2. (转载)Unity 优化总结

    Unity 优化总结 2017-03-10 | 发布 大海明月  zengfeng75@qq.com  | 分类 Unity  | 标签 Unity  优化 相关文档 UGUI 降低填充率技巧两则 U ...

  3. [windows]设置使用空白密码进行远程登录

    前提:系统用户设置了空白密码 方法1步骤: 开始菜单--〉运行--〉输入:gpedit.msc--> 计算机配置--〉Windows设置--〉安全设置--〉本地策略--〉安全选项:帐户:使用空白 ...

  4. JS 一个页面关闭多个页面

    <!DOCTYPE html><html xmlns="http://www.w3.org/1999/xhtml"><head><meta ...

  5. Kubernetes里的ConfigMap的用途

    顾名思义,ConfigMap用于保存配置数据的键值对,可以用来保存单个属性,也可以用来保存配置文件. ConfigMap同Kubernetes的另一个概念secret类似,区别是ConfigMap主要 ...

  6. ARC和MRC混合模式下的编译问题

    在一个支持ARC (Automatic Reference Counting)的项目中,有时候需要禁止其中几个文件使用ARC模式编译(比如你用了第三方不支持ARC的类库).这时就要点击工程文件,在ta ...

  7. 安卓统一推送联盟融云成唯一IM云服务企业

    10月16日,安卓统一推送联盟在北京正式成立,来自中国信息通信研究院,华为.小米.OPPO等手机厂商,BAT等互联网巨头公司等75家机构及企业代表参加了联盟成立大会,融云也受邀参会并成为首批成员单位中 ...

  8. Python学习日志_2017/09/09

    今天早晨学习<Head First HTML and CSS>.随着内容逐渐深入,知识量逐渐增加,今天早晨三个小时学习了一章:<Html的基本元素>,学到了不少的东西.比如,什 ...

  9. 转载:使用Auto Layout中的VFL(Visual format language)--代码实现自动布局

    本文将通过简单的UI来说明如何用VFL来实现自动布局.在自动布局的时候避免不了使用代码来加以优化以及根据内容来实现不同的UI. 一:API介绍 NSLayoutConstraint API 1 2 3 ...

  10. HDU 6166 Senior Pan(多校第九场 二进制分组最短路)

    题意:给出n个点和m条有向边(有向边!!!!我还以为是无向查了半天),然后给出K个点,问这k个点中最近的两点的距离 思路:比赛时以为有询问,就直接丢了,然后这题感觉思路很棒,加入把所有点分成起点和终点 ...