我正在尝试设置可以根据数据类型在编辑和只读模式之间切换的通用 Knockout 模板。如果您曾经使用过 ASP.NET 的动态数据:就像他们的字段模板一样。例如:
<script type="text/html" id="text">
<!-- ko if: $root.editable -->
<input type="text" data-bind="value: $data" />
<!-- /ko -->
<!-- ko ifnot: $root.editable -->
<span data-bind="text: $data"></span>
<!-- /ko -->
</script>
这是这样使用的:
<label><input type="checkbox" data-bind="checked: editable" /> Editable</label>
<p>Name: <input data-bind="value: name" /></p>
<p>Name2: <span data-bind="template: { name: 'text', data: name }"></span></p>
使用以下视图模型:
var viewModel = {
name: ko.observable("Brian"),
editable: ko.observable(true)
};
这个想法是能够像在“Name2”示例中那样在字段级别使用模板,而不是显式的元素/控件。这允许整个表单在编辑和阅读模式之间轻松切换,而不会出现大部分重复的标记。这也允许重用常见的数据类型编辑/显示标记,例如对日期字段使用日期选择器等。
问题
模板内
的$data
伪变量没有双向绑定。它将反映可观察对象中的当前值,但输入控件的更改不会设置该值。
我怎样才能获得两种方式绑定$data
?
另请参阅此 jsfiddle