Source绑定可以把ViewModel的值和由Kendo模板定义的目标元素绑定,如果ViewModel的值发生变化,被绑定的目标元素也随之发生变化。
模板由属性data-template指定,它的值为某个script定义的模板的id.如果没有指明模板,则根据元素的标记使用缺省的模版。

Source绑定到数组

当ViewModel的值 为一数组时,那么通过Source绑定到模板时,会把数组中每个元素逐个应用到模板,最后的输出为应用这些模板的结果的综合。 添加删除数组中的内容,显示的内容也随之变化。

注:绑定到ViewModel数组时,Source指明的为单个跟元素名称,例如:

1 <ul data-template="ul-template" data-bind="source: products">
2 </ul>
3 <script id="ul-template" type="text/x-kendo-template">
4     <li>
5         id: <span data-bind="text: id"></span>
6         name: <span data-bind="text: name"></span>
7     </li>
8 </script>
9 <script>
10 var viewModel = kendo.observable({
11     products: [
12         { id: 1, name: "Coffee" },
13         { id: 2, name: "Tea" },
14         { id: 3, name: "Juice" }
15     ]
16 });
17  
18 kendo.bind($("ul"), viewModel);
19 </script>

这个例子会输出三个li元素–每个对应到products数组中一个元素,下面为输出的HTML内容:

1 <ul>
2     <li>
3         id: <span>1</span>
4         name: <span>Coffee</span>
5     </li>
6     <li>
7         id: <span>2</span>
8         name: <span>Tea</span>
9     </li>
10     <li>
11         id: <span>3</span>
12         name: <span>Juice</span>
13     </li>
14 </ul>

如果ViewModel绑定的数组的内容为简单类型(如数字,字符串,日期),这时在模板中需要使用”this”关键字来引用当前数组项:

1 <ul data-template="ul-template" data-bind="source: products">
2 </ul>
3 <script id="ul-template" type="text/x-kendo-template">
4     <li data-bind="text: this"></li>
5 </script>
6 <script>
7 var viewModel = kendo.observable({
8     products: [ "Coffee", "Tea", "Juice" ]
9 });
10  
11 kendo.bind($("ul"), viewModel);
12 </script>

输出内容如下:

1 <ul>
2     <li>Coffee</li>
3     <li>Tea</li>
4     <li>Juice</li>
5 </ul>

Source绑定到非数组

source绑定也支持绑定到非数组值,此时在模板中引用到ViewModel的某个属性,最终的结果为模板使用ViewModel后的结果。

1 <div data-template="div-template" data-bind="source: person">
2     <script id="div-template" type="text/x-kendo-template">
3     Name: <span data-bind="text: name"></span>
4     </script>
5 </div>
6 <script>
7 var viewModel = kendo.observable({
8     person: {
9         name: "John Doe"
10     }
11 });
12  
13 kendo.bind($("div"), viewModel);
14 </script>

输出:

1 <div>
2     Name: <span>John Doe</span>
3 </div>

你也可以直接绑定到ViewModel对象本身,此时可以使用把source 的值设置为“this”,例如:

1 <div data-template="div-template" data-bind="source: this">
2     <script id="div-template" type="text/x-kendo-template">
3     Name: <span data-bind="text: name"></span>
4     </script>
5 </div>
6 <script>
7 var viewModel = kendo.observable({
8     name: "John Doe"
9 });
10  
11 kendo.bind($("div"), viewModel);
12 </script>

结果如下:

1 <div>
2 Name: <span>John Doe</span>
3 </div>

Source绑定Select元素

当数组绑定到select元素时,就创建多个option元素。

1 <select data-bind="source: colors"></select>
2 <script>
3 var viewModel = kendo.observable({
4     colors: [ "Red", "Green", "Blue" ]
5 });
6  
7 kendo.bind($("select"), viewModel);
8 </script>

输出的HTML元素如下:

1 <select>
2     <option>Red</option>
3     <option>Green</option>
4     <option>Blue</option>
5 </select>

select元素也可以绑定到JavaScript对象数组(非简单类型),此时可以同时指定data-text-field,data-value-field 用来指定option元素的value和text属性,例如:

1 <select data-text-field="name" data-value-field="id"
2        data-bind="source: products"></select>
3 <script>
4 var viewModel = kendo.observable({
5     products: [
6         { id: 1, name: "Coffee" },
7         { id: 2, name: "Tea" },
8         { id: 3, name: "Juice" }
9     ]
10 });
11  
12 kendo.bind($("select"), viewModel);
13 </script>

输出如下:

1 <select>
2     <option value="1">Coffee</option>
3     <option value="2">Tea</option>
4     <option value="3">Juice</option>
5 </select>

 

Kendo UI开发教程(21): Kendo MVVM 数据绑定(十) Source的更多相关文章

  1. Kendo UI开发教程(16): Kendo MVVM 数据绑定(五) Events

    本篇和Kendo UI开发教程(14): Kendo MVVM 数据绑定(三) Click类似,为事件绑定的一般形式.Events绑定支持将ViewModel的方法绑定到DOM元素的事件处理(如鼠标事 ...

  2. Kendo UI开发教程(9): Kendo UI Validator 概述

    Kendo UI Validator 支持了客户端校验的便捷方法,它基于HTML 5 的表单校验功能,支持很多内置的校验规则,同时也提供了自定义规则的便捷方法. 完整的Kendo UI 的Valida ...

  3. Kendo UI开发教程(6): Kendo DataSource 概述

    Kendo 的数据源支持本地数据源(JavaScript 对象数组),或者远程数据源(XML, JSON, JSONP),支持CRUD操作(创建,读取,更新和删除操作),并支持排序,分页,过滤,分组和 ...

  4. Kendo UI开发教程(7): Kendo UI 模板概述

    Kendo UI 框架提供了一个易用,高性能的JavaScript模板引擎.通过模板可以创建一个HTML片段然后可以和JavaScript数据合并成最终的HTML元素. Kendo 模板侧重于UI显示 ...

  5. Kendo UI开发教程(8): Kendo UI 特效概述

    Kendo UI Fx 提供了一个丰富,可扩展,性能经过优化的工具集合用来完成HTML元素的过渡显示.每种特效近可能的使用CSS Transition ,对于一些老版本浏览器使用修改属性的方法作为补充 ...

  6. Kendo UI开发教程(22): Kendo MVVM 数据绑定(十一) Value

    Value绑定可以把ViewModel的某个属性绑定到DOM元素或某个UI组件的Value属性.当用户修改DOM元素或UI组件的值时,绑定的ViewModel的值也随之发生改名.同样,如果ViewMo ...

  7. Kendo UI开发教程(14): Kendo MVVM 数据绑定(三) Click

    Click绑定可以把由ViewModel定义的方法不绑定到目标DOM的click事件.当点击目标DOM元素时触发ViewModel的对应方法.例如: 使用Click绑定 1 <div id=&q ...

  8. Kendo UI开发教程(20): Kendo MVVM 数据绑定(九) Text

    Text绑定可以使用ViewModel来设置DOM元素的文本属性,如果需要设置input,textarea,或select的显示,需要使用value属性. 1 <span data-bind=& ...

  9. [置顶] Kendo UI开发教程: Kendo UI 示例及总结

    前面基本介绍完Kendo UI开发的基本概念和开发步骤,Kendo UI的示例网站为http://demos.kendoui.com/ ,包含了三个部分 Web DemoMobile DemoData ...

随机推荐

  1. AFNetworking3.0的基本使用方法

    前一段时间在做项目的时候发现AFNetworking3.0已经被大众所接受,所以以后肯定会有很多程序猿朋友必须了解和转移至3.0了,这是我这段时间使用和学习总结出来的一些常用的知识点,希望对大家有用. ...

  2. 欧拉函数K - Relatives

    欧拉函数是积性函数——若m,n互质,φ(mn)=φ(m)φ(n). 特殊性质:当n为奇数时,φ(2n)=φ(n), φ(x)=x(1-1/p1)(1-1/p2)(1-1/p3)(1-1/p4)…..( ...

  3. oracle_SQL中ROWID与ROWNUM的使用(转)

    转自:http://www.360doc.com/content/12/0802/11/219024_227802569.shtml rownum: ROWNUM是对结果集加的一个伪列, 即先查到结果 ...

  4. MVC 扩展 Html.ImageFor

    Asp.Net MVC 扩展 Html.ImageFor 方法详解 背景: 在Asp.net MVC中定义模型的时候,DataType有DataType.ImageUrl这个类型,但htmlhelpe ...

  5. WCF Publisher/Subscriber 订阅-发布模式

    本博后续将陆续整理这些年做的一些预研demo,及一些前沿技术的研究,与大家共研技术,共同进步. 关于发布订阅有很多种实现方式,下面主要介绍WCF中的发布订阅,主要参考书籍<Programming ...

  6. Jquery的text()和html()方法在li与div取值结果解析

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/ ...

  7. [置顶] hdu3018解题报告--也是白话几笔画学习总结

    1.题意 2.分析难点(结合图形) 1.首先说说题意吧...题意很简单...但是一开始很菜的我就很迷惑..在想啊...题目怎么就会有没有连接边的点呢....因为你每次给出一条边..就把 a,b连接啦. ...

  8. Android中如何查找内存泄露

    1.首先确定是否有内存泄露及哪个程序造成. 1.1.内存泄露已弹出out of memory对话框的情况. 这种情况很简单,直接看对话框就知道是哪个应用的问题了.然后再分析该应用是否是因为内存泄露造成 ...

  9. [转载]IOS项目打包除去NSLog和NSAssert处理之阿堂教程

    原文链接地址:http://blog.sina.com.cn/s/blog_81136c2d0102v1ck.html 原文地址:IOS项目打包除去NSLog和NSAssert处理之阿堂教程作者:时空 ...

  10. Qt 智能指针学习(7种QT智能指针和4种std智能指针)

    从内存泄露开始? 很简单的入门程序,应该比较熟悉吧 ^_^ #include <QApplication> #include <QLabel> int main(int arg ...