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

來源:互聯網
上載者:User

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綁定:
複製代碼 代碼如下:
<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>

三、動態屬性綁定:
動態屬性綁定,那麼這個屬性本身不確定,沿用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的動態屬性,可以使用於任何ko方法,比如ext:{text:'text', value:'text'}
呈現:

相關關鍵詞:
相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.