三、動態屬性綁定:
動態屬性綁定,那麼這個屬性本身不確定,沿用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]]; });
}
}
}
};
代碼如下:
$(function () {
var viewModel = function () {
};
ko.applyBindings(new viewModel());
});
代碼如下:
代碼如下:
更改text值 ext中,第一個text是ko text方法,第二個text必須是字串,是context/viewModel的屬性。所以ext的動態屬性,可以用任何ko方法,例如ext:{text:'text', value:'text'} 呈現: