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模型:
复制代码 代码如下:
$(function () {
var viewmodel = 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 = 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绑定:
复制代码 代码如下:
更改text值
ext中,第一个text是ko text方法,第二个text必须是字符串,是context/viewmodel的属性。所以ext的动态属性,可以使用于任何ko方法,比如ext:{text:'text', value:'text'}
呈现: