首頁 >web前端 >js教程 >ko knockoutjs動態屬性綁定技巧應用_javascript技巧

ko knockoutjs動態屬性綁定技巧應用_javascript技巧

WBOY
WBOY原創
2016-05-16 17:48:101603瀏覽

knockoutjs 簡稱 ko
ko的動態屬性是指,ViewModel不確定的屬性,而後期卻需要的屬性。
什麼是不確定屬性,例如ListModel如果 編輯某一項,想把這項的狀態變更為Edit。資料不包括Edit屬性,mvvm綁定時,會發現報錯。
那麼一定需要拓展ko才能達到我們的目的。
首先來認識有值屬性綁定,和無值屬性綁定:
一、有值屬性綁定
JS模型:

複製程式碼 程式碼如下:

$(function () {
var viewModel = function () {
var self = this;
self.text = ko.observable(1);
};
ko.applyBindings(new viewModel());
});

UI綁定:
複製程式碼 程式碼如下:



呈現:
 
二、無值屬性綁定
JS模型:
複製程式碼 程式碼如下:

$unc(function () {
var self = this;
self.text = ko.observable();
};
ko.applyBindings(new viewModel());
});

當然text是一般值類型,用法和有值屬性綁定一樣,如果非值類型,而屬性是一個對象,而需要使用with:
UI綁定:
複製程式碼 程式碼如下:








三、動態屬性綁定: 動態屬性綁定,那麼這個屬性本身不確定,沿用ko的方法是很難去實現,所以需要拓展。 JS拓展:
複製程式碼


程式碼如下:


/霧裡看花> Q:397386036
ko.bindingHandlers.ext = {
update: function (element, valueAccessor, allBindingsAccessor, viewModel, bindingContext) {
var value = mooop. >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綁定: 複製代碼

代碼如下:


代碼如下:


更改text值
ext中,第一個text是ko text方法,第二個text必須是字串,是context/viewModel的屬性。所以ext的動態屬性,可以用任何ko方法,例如ext:{text:'text', value:'text'} 呈現:
陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn