我有一个自定义绑定处理程序,我将其绑定到我的视图模型中的一个复杂对象。
绑定处理程序正常工作,并且update
当任何可观察的属性更新时调用该函数。但是,每个update
更新的属性都会调用该函数,这会导致奇怪的行为,因为我依赖于整个对象可用且是最新的。
我理解为什么会发生这种情况,因为每个属性都会导致调用更新,并且我想我知道如何防止这种情况发生——通过使用 Knockout 的延迟更新功能。
但是,我无法找到如何仅为自定义绑定中的 observable 启用延迟更新。我不想在应用程序范围内启用它,因为我正在将绑定编写为库函数。
我尝试了许多不同的方法,包括:
- 尝试扩展绑定处理程序本身;
- 扩展
init
功能; - 扩展
valueAccessor
; - 用
valueAccessor
新的 observable替换deferred
apply; - 创建一个计算的可观察对象并重新绑定元素;
所有这些都没有奏效。
我还没有找到任何其他自定义绑定处理程序可以远程接近这种函数,并且一直在尝试将它与其他函数拼凑在一起。
我的绑定代码本身相对简单,我将绑定对象简单地拆分出参数并将它们传递给代码镜像实例。
ko.bindingHandlers.editor = {
init: function(element, valueAccessor, allBindingsAccessor) {
var observableValue = ko.utils.unwrap(valueAccessor());
initEditor(element, observableValue, allBindingsAccessor);
},
update: function(element, valueAccessor, allBindingsAccessor) {
var observableValue = ko.unwrap(valueAccessor());
createEditor(codeEditorDiv, observableValue);
resize();
updateEditor(element, observableValue, allBindingsAccessor);
}
};
我的 HTML 代码是:
<div id="editor" data-bind="editor: EditorVM"></div>
我将Dotnetify用于 ViewModel,因此它是一个合理的复杂 C# 类,但只要说绑定正在工作和更新就足够了,但我需要它只在所有属性都更新后才调用“更新”。