ko knockoutjs動態(tài)屬性綁定技巧應用
更新時間:2012年11月14日 11:27:20 作者:
ko的動態(tài)屬性是指,ViewModel不確定的屬性,而后期卻需要的屬性,本文將詳細介紹,需要的朋友參考下
knockoutjs 簡稱 ko
ko的動態(tài)屬性是指,ViewModel不確定的屬性,而后期卻需要的屬性。
什么是不確定屬性,比如ListModel如果 編輯某一項,想把這一項的狀態(tài)變更為Edit。數據并不包括Edit屬性,mvvm綁定時,會發(fā)現報錯。
那么一定需要拓展ko才能達到我們的目的。
首先來認識有值屬性綁定,和 無值屬性綁定:
一、有值屬性綁定:
JS模型:
$(function () {
var viewModel = function () {
var self = this;
self.text = ko.observable(1);
};
ko.applyBindings(new viewModel());
});
UI綁定:
<div data-bind='text:text'></div>
呈現:
二、無值屬性綁定:
JS模型:
$(function () {
var viewModel = function () {
var self = this;
self.text = ko.observable();
};
ko.applyBindings(new viewModel());
});
當然text是一般值類型,用法 和 有值屬性綁定一樣,如果非值類型,而屬性是一個對象,而需要使用with:
UI綁定:
<div data-bind='with:text'>
<div data-bind="text:property"></div>
</div>
三、動態(tài)屬性綁定:
動態(tài)屬性綁定,那么這個屬性本身不確定,沿用ko的方法是很難去實現,所以 需要進行拓展。
JS拓展:
//霧里看花 Q:397386036
ko.bindingHandlers.ext = {
update: function (element, valueAccessor, allBindingsAccessor, viewModel, bindingContext) {
var value = ko.utils.unwrapObservable(valueAccessor());
for (var handler in value) {
if (value.hasOwnProperty(handler)) {
if (typeof viewModel[value[handler]] == 'undefined') {
viewModel[value[handler]] = ko.observable();
}
ko.bindingHandlers[handler].update(element, function () { return viewModel[value[handler]]; });
}
}
}
};
JS模型:
$(function () {
var viewModel = function () {
};
ko.applyBindings(new viewModel());
});
UI綁定:
<div data-bind="ext:{text: 'text'}"></div>
<!--事件 便于 測試-->
<a href="javascript:void(0)" data-bind="click:function(){$data.text(1);}">更改text值</a>
ext中,第一個text是ko text方法,第二個text必須是字符串,是context/viewModel的屬性。所以ext的動態(tài)屬性,可以使用于任何ko方法,比如ext:{text:'text', value:'text'}
呈現:
ko的動態(tài)屬性是指,ViewModel不確定的屬性,而后期卻需要的屬性。
什么是不確定屬性,比如ListModel如果 編輯某一項,想把這一項的狀態(tài)變更為Edit。數據并不包括Edit屬性,mvvm綁定時,會發(fā)現報錯。
那么一定需要拓展ko才能達到我們的目的。
首先來認識有值屬性綁定,和 無值屬性綁定:
一、有值屬性綁定:
JS模型:
復制代碼 代碼如下:
$(function () {
var viewModel = function () {
var self = this;
self.text = ko.observable(1);
};
ko.applyBindings(new viewModel());
});
UI綁定:
復制代碼 代碼如下:
<div data-bind='text:text'></div>
呈現:

二、無值屬性綁定:
JS模型:
復制代碼 代碼如下:
$(function () {
var viewModel = function () {
var self = this;
self.text = ko.observable();
};
ko.applyBindings(new viewModel());
});
當然text是一般值類型,用法 和 有值屬性綁定一樣,如果非值類型,而屬性是一個對象,而需要使用with:
UI綁定:
復制代碼 代碼如下:
<div data-bind='with:text'>
<div data-bind="text:property"></div>
</div>
三、動態(tài)屬性綁定:
動態(tài)屬性綁定,那么這個屬性本身不確定,沿用ko的方法是很難去實現,所以 需要進行拓展。
JS拓展:
復制代碼 代碼如下:
//霧里看花 Q:397386036
ko.bindingHandlers.ext = {
update: function (element, valueAccessor, allBindingsAccessor, viewModel, bindingContext) {
var value = ko.utils.unwrapObservable(valueAccessor());
for (var handler in value) {
if (value.hasOwnProperty(handler)) {
if (typeof viewModel[value[handler]] == 'undefined') {
viewModel[value[handler]] = ko.observable();
}
ko.bindingHandlers[handler].update(element, function () { return viewModel[value[handler]]; });
}
}
}
};
JS模型:
復制代碼 代碼如下:
$(function () {
var viewModel = function () {
};
ko.applyBindings(new viewModel());
});
UI綁定:
復制代碼 代碼如下:
<div data-bind="ext:{text: 'text'}"></div>
<!--事件 便于 測試-->
<a href="javascript:void(0)" data-bind="click:function(){$data.text(1);}">更改text值</a>
ext中,第一個text是ko text方法,第二個text必須是字符串,是context/viewModel的屬性。所以ext的動態(tài)屬性,可以使用于任何ko方法,比如ext:{text:'text', value:'text'}
呈現:

相關文章
用nodejs訪問ActiveX對象,以操作Access數據庫為例。
有人提問“如果用nodejs訪問sql server?” 找了找資料,發(fā)現有兩類解決方法,使用第三方nodejs插件2011-12-12如何在Mozilla Gecko 用Javascript加載XSL
如何在Mozilla Gecko 用Javascript加載XSL...2007-01-01解決layui中table異步數據請求不支持自定義返回數據格式的問題
今天小編就為大家分享一篇解決layui中table異步數據請求不支持自定義返回數據格式的問題,具有很好的參考價值,希望對大家有所幫助。一起跟隨小編過來看看吧2018-08-08