knockout简单实用教程3
在之前的文章里面介绍了一些KO的基本用法。包括基本的绑定方式,基本的ko的绑定语法包括text绑定,html绑定等等(如有不明请参照上两篇文章),下面呢介绍一下关于ko的其他方面的知识。包括比较特殊绑定方式和语法还有KO官方mapping插件的使用等等。对了在前面的文章中好像漏掉了属性绑定的的介绍。那就先简单介绍下。属性绑定吧。直接上代码。
<a data-bind="attr: { href: url, title: details }">
Report
</a> <script type="text/javascript">
var viewModel = {
url: ko.observable("year-end.html"),
details: ko.observable("Report including final year-end statistics")
};
</script>
这段代码不做过多解释了相信看过之前的文章就能明白.(支持所有的dom属性的绑定)。
下面重点说说比较特殊的几种绑定方式。
1uniquename 绑定(用的不多)
uniquename绑定确保了某一个dom元素有一个唯一的名称属性(name属性),如果你没有设置那么会默认给一个唯一的字符串
绑定方式如下
<input data-bind="value: someModelProperty, uniqueName: true" />
在一些特殊的情况下可能用的上比如在IE6下 单选按钮必须要有name属性。还有就是在 jQuery Validation 验证能能避免验证的和ko绑定的混淆.
2模板绑定 temple 绑定
可以指定一个模版。然后把模版绑定到指定的dom元素中 ,先给出代码下面在进行解释
<h2>Participants</h2>
Here are the participants:
<div data-bind="template: { name: 'person-template', data: buyer }"></div>
<div data-bind="template: { name: 'person-template', data: seller }"></div> <script type="text/html" id="person-template">
<h3 data-bind="text: name"></h3>
<p>Credits: <span data-bind="text: credits"></span></p>
</script> <script type="text/javascript">
function MyViewModel() {
this.buyer = { name: 'Franklin', credits: 250 };
this.seller = { name: 'Mario', credits: 5800 };
}
ko.applyBindings(new MyViewModel());
</script>
在script 里面的就是模板。在模板中也可以跟普通的绑定方式一样的去绑定。在确定模板后。我们就可以在具体的dom元素中去绑定了。
name 代表模板的id data 则是指定具体的vm里面的数据对象。(这里也可以用foreach,后面来说明)。
在模板绑定中也可以用foreach来循环数据.下面给出代码
<h2>Participants</h2>
Here are the participants:
<div data-bind="template: { name: 'person-template', foreach: people }"></div> <script type="text/html" id="person-template">
<h3 data-bind="text: name"></h3>
<p>Credits: <span data-bind="text: credits"></span></p>
</script> function MyViewModel() {
this.people = [
{ name: 'Franklin', credits: 250 },
{ name: 'Mario', credits: 5800 }
]
}
ko.applyBindings(new MyViewModel());
其实它和普通的绑定没什么太大差别就等同于下面的绑定
<div data-bind="foreach: people">
<h3 data-bind="text: name"></h3>
<p>Credits: <span data-bind="text: credits"></span></p>
</div>
在模板绑定中还可以用嵌套的方式来进行绑定,一般来配合多层次的数据结构。并且可以用as 语法来指定模型上下文中 的你要循环绑定的数据字段父级或者子级的别名, 下面给出代码.
<ul data-bind="template: { name: 'seasonTemplate', foreach: seasons, as: 'season' }"></ul> <script type="text/html" id="seasonTemplate">
<li>
<strong data-bind="text: name"></strong>
<ul data-bind="template: { name: 'monthTemplate', foreach: months, as: 'month' }"></ul>
</li>
</script> <script type="text/html" id="monthTemplate">
<li>
<span data-bind="text: month"></span>
is in
<span data-bind="text: season.name"></span>
</li>
</script> <script>
var viewModel = {
seasons: ko.observableArray([
{ name: 'Spring', months: [ 'March', 'April', 'May' ] },
{ name: 'Summer', months: [ 'June', 'July', 'August' ] },
{ name: 'Autumn', months: [ 'September', 'October', 'November' ] },
{ name: 'Winter', months: [ 'December', 'January', 'February' ] }
])
};
ko.applyBindings(viewModel);
</script>
基本常用的模型绑定的方式已经给出了。还有几种特殊的但是不常用的比如 afterRender ,afteradd ,beforeremove绑定等等这些并不常用,有想了解的朋友可以参考官方文档 http://knockoutjs.com/documentation/template-binding.html
文章的最后在介绍一下 ko 里面mapping插件的使用。
这个插件用起来非常简单。
下面给个例子
在普通的绑定中我们会这样做。先给出普通绑定的代码.
先创建模型绑定模型
var viewModel = {
serverTime: ko.observable(),
numUsers: ko.observable()
}
ko.applyBindings(viewModel);
绑定dom
The time on the server is: <span data-bind='text: serverTime'></span>
and <span data-bind='text: numUsers'></span> user(s) are connected.
异步或者同步获取数据
var data = getDataUsingAjax(); // 从服务器获取数据
//假如返回的数据格式如下
{
serverTime:
'2010-01-07'
,
numUsers: 3
}
那么我们只要这样把数据填充到模型里面就完成了
// 填充模型
viewModel.serverTime(data.serverTime);
viewModel.numUsers(data.numUsers);
那么我们在是用ko.mapping插件的时候怎么操作呢?先介绍mapping 插件是干什么的,简单来说就是用来模型转换的。可以把js对象和json对象互相转换。
下面给出代码示例:
var viewModel = ko.mapping.fromJS(data);//data可以是空的js对象 这样可以创建一个vm模型
// data是从服务器接收到的数据
ko.mapping.fromJS(data, viewModel);//更新模型数据var
unmapped = ko.mapping.toJS(viewModel);//模型转换为js对象
那么我们如何使用它来绑定数据呢假设有这样一个json对象
var data = {
name: 'Scot',
children: [
{ id : 1, name : 'Alicw' }
]
}
我们可以通过它来创建一个viewmodel对象
var viewModel = ko.mapping.fromJS(data);
当有新的数据是我们可以这样来更新数据模型
var data = {
name: 'Scott',
children: [
{ id : 1, name : 'Alice' }
]
}
ko.mapping.fromJS(data, viewModel);//更新模型
当然。你也可以创建一个vm模型然后用mapping来更新你模型的数据
var data = {
name: 'Graham',
} var mapping = {
'name': {
update: function(options) {
return options.data + 'foo!';
}
}
}
var viewModel = ko.mapping.fromJS(data, mapping);
alert(viewModel.name());
像这样最后输出的结果是 Grahamfoo! mapping插件还有一些其他的语法比如,你想忽略一些js对象的属性不绑定到模型上的话可以这样写。
var mapping = {
'ignore': ["propertyToIgnore", "alsoIgnoreThis"]
}
var viewModel = ko.mapping.fromJS(data, mapping); var oldOptions = ko.mapping.defaultOptions().ignore;
ko.mapping.defaultOptions().ignore = ["alwaysIgnoreThis"];
和它对应的是include 语法。你可以单独添加一些属性到js对象里
var mapping = {
'include': ["propertyToInclude", "alsoIncludeThis"]
}
var viewModel = ko.mapping.fromJS(data, mapping); var oldOptions = ko.mapping.defaultOptions().include;
ko.mapping.defaultOptions().include = ["alwaysIncludeThis"];
上面已经介绍了大部分的mapping语法了相信大家看完之后呢,应该就能够使用它了。
还有一些细节的东西大家可以去官网查看。mapping 插件下面的地址我也一并给出 http://knockoutjs.com/documentation/plugins-mapping.html
到这里。关于ko的系列简单入门教程就算是告一段落了。谢谢代价的阅读。如有疑问可以给我留言。
knockout简单实用教程3的更多相关文章
- knockout简单实用教程2
在上一篇文章中简单了介绍了下什么ko(后文中都已ko来代替knockout.js)和一些简单的ko的使用方法下面我将介绍在实际的项目中常用到的几种绑定方式和方法. 在开始之前先拿一个dome来回顾下k ...
- knockout.js简单实用教程1
第一次接触knockout是在一年多之前吧.当时是接手了一个别人的项目,在项目中有用到knockout来进行数据的绑定.也就开始学习起来knockout.在之后的项目中也多次用到了这个.在第一次开始学 ...
- maven 简单实用教程
1. Maven介绍 1.1. 简介 java编写的用于构建系统的自动化工具. 目前版本是2.0.9,注意maven2和maven1有很大区别,阅读第三方文档时需要区分版本. 1.2. Maven资源 ...
- wireshark简单实用教程
转自:https://jingyan.baidu.com/article/c35dbcb0866b698916fcbc81.html wireshark是非常流行的网络封包分析软件,功能十分强大.可以 ...
- zw版_Halcon图像交换、数据格式、以及超级简单实用的DIY全内存计算.TXT
zw版_Halcon图像交换.数据格式.以及超级简单实用的DIY全内存计算.TXT Halcon由于效率和其他原因,内部图像采用了很多自有格式,提高运行速度,但在数据交换方面非常麻烦. 特别是基于co ...
- 简单实用的PHP验证码类
一个简单实用的php验证码类,分享出来 ,供大家参考. 代码如下: <?php /** @ php 验证码类 @ http://www.jbxue.com */ Class code { var ...
- 学习笔记之Java程序设计实用教程
Java程序设计实用教程 by 朱战立 & 沈伟 学习笔记之JAVA多线程(http://www.cnblogs.com/pegasus923/p/3995855.html) 国庆休假前学习了 ...
- 基于jQuery简单实用的Tabs选项卡插件
jQuery庞大的插件库总是让人欢喜让人忧,如何从庞大的插件库里挑出适合自己的插件,总是让很多缺少经验的朋友头疼的事!今天为大家推荐几款简单实用的Tabs选项卡插件,推荐理由:简单易用灵活,样式美观, ...
- js模版引擎handlebars.js实用教程
js模版引擎handlebars.js实用教程 阅读本文需要了解基本的Handlebars.js概念,本文并不是Handlebars.js基础教程,而是注重于实际应用,为读者阐述使用过程中可能会遇到的 ...
随机推荐
- Laravel 模板引擎Blade中标签详细介绍
这篇文章主要介绍了Laravel模板引擎Blade中section的一些标签的区别介绍,需要的朋友可以来看看. Laravel 框架中的Blade模板引擎很好用,但是官方文档介绍的并不详细,我接下来将 ...
- Android 中常用代码片段
一:AsyncTask 的使用 (1)activity_main.xml <TextView android:id="@+id/tvInfo" android:layout_ ...
- 查看mysql 服务器上的连接进程
SHOW PROCESSLIST #展示全部的连接进程 select * from information_schema.processlist where db='qwuliu' #可以进行筛选查 ...
- Best Time to Buy and Sell Stock I II III
Best Time to Buy and Sell Stock Say you have an array for which the ith element is the price of a gi ...
- initial pointer [expert c]
initial differece between pointer and array Both arrays and pointers can be initialized with a liter ...
- MyEclipse通过JDBC连接MySQL数据库基本介绍
转载自:http://www.jb51.net/article/31876.htm 1.前提是MyEclipse已经能正常开发Java工程 2.安装MySQL 个人使用的是版本是 mysql-5.0. ...
- 怎样查询SCI和EI检索号
为了年终考核,花了一个早上才搞清楚,里面有非常多小问题.以下具体说明具体过程: SCI检索号 1.进入图书馆主页: 2.选择"电子数据库": 3.选择外文数据库中的"We ...
- Sublime Text 2 介紹
代码编辑器或者文本编辑器,对于程序猿来说,就像剑与战士一样,谁都想拥有一把能够随心驾驭且瑞丽无比的宝剑,而每一位程序猿,相同会去追求最适合自己的强大.灵活的编辑器,相信你和我一样,都不会例外. 我用过 ...
- 怎样使用jetty
一直都听说jetty跟Tomcat一样,是一个web容器.之前做项目的时候,也使用过jetty,只是当时jetty是作为一个插件,跟maven集成使用的.那个时候,因为是第一次使用jetty,感觉je ...
- 【二分答案】【POJ3122】【Northwestern Europe 2006】Pie
Pie Time Limit: 1000MS Memory Limit: 65536K Total Submissions: 10629 Accepted: 3744 Special Ju ...