ko(knockoutjs)动态属性绑定

ko(knockoutjs)动态属性绑定

 
knockoutjs 简称 koko的动态属性是指,ViewModel不确定的属性,而后期却需要的属性。什么是不确定属性,比如ListModel如果 编辑某一项,想把这一项的状态变更为Edit。数据并不包括Edit属性,mvvm绑定时,会发现报错。那么一定需要拓展ko才能达到我们的目的。
首先来认识有值属性绑定,和 无值属性绑定:
一、有值属性绑定:JS模型:
复制代码
1  $(function () {
2              var viewModel = function () {
3                  var self = this;
4  
5                  self.text = ko.observable(1);
6              };
7              ko.applyBindings(new viewModel());
8          });
复制代码
UI绑定:
<div data-bind='text:text'></div>
呈现:
二、无值属性绑定: JS模型:
复制代码
1         $(function () {
2              var viewModel = function () {
3                  var self = this;
4  
5                  self.text = ko.observable();
6              };
7              ko.applyBindings(new viewModel());
8          });
复制代码
当然text是一般值类型,用法 和 有值属性绑定一样,如果非值类型,而属性是一个对象,而需要使用with:UI绑定:
1     <div data-bind='with:text'>
2         <div data-bind="text:property"></div>
3     </div>
三、动态属性绑定:动态属性绑定,那么这个属性本身不确定,沿用ko的方法是很难去实现,所以 需要进行拓展。JS拓展:
复制代码
 1 //雾里看花 Q:397386036
 2          ko.bindingHandlers.ext = {
 3              update: function (element, valueAccessor, allBindingsAccessor, viewModel, bindingContext) {
 4                  var value = ko.utils.unwrapObservable(valueAccessor());
 5                  for (var handler in value) {
 6                      if (value.hasOwnProperty(handler)) {
 7                          if (typeof viewModel[value[handler]] == 'undefined') {
 8                              viewModel[value[handler]] = ko.observable();
 9                          }
10  
11                          ko.bindingHandlers[handler].update(element, function () { return viewModel[value[handler]]; });
12                      }
13                  }
14              }
15          };
复制代码
JS模型:
1         $(function () {
2              var viewModel = function () {
3              };
4              ko.applyBindings(new viewModel());
5          });
UI绑定:
1 <div data-bind="ext:{text: 'text'}"></div>
2 <!--事件 便于 测试-->
3 <a href="javascript:void(0)" data-bind="click:function(){$data.text(1);}">更改text值</a>
ext中,第一个text是ko text方法,第二个text必须是字符串,是context/viewModel的属性。所以ext的动态属性,可以使用于任何ko方法,比如ext:{text:'text', value:'text'}呈现:
转自:博客园 雾里kanhua 《 ko(knockoutjs)动态属性绑定
url:http://www.cnblogs.com/g_397386036/archive/2012/11/13/2768990.html
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值