任何viewmodel dom更新的Knockout JS事件

Rod*_*257 8 javascript events knockout.js

每当通过Knockout.JS更新DOM时,我需要运行一个jquery ui位代码.我意识到这可以使用自定义绑定来完成,但这似乎与特定的视图模型有关,我想全局地这样做,所以每当它发生在它触发的任何viewmodel上时?

假设我总是希望在所有带有'needsdate'类的文本框上使用JQuery日期选择器,而不是将其添加到我的每个视图模型中,如果我可以在全局范围内完成它将会很棒.

这可能吗?

RP *_*yer 7

如果您不打算动态添加/删除元素,那么您可以正常连接它们.但是,如果您正在使用动态内容(例如使用修改了其项目的observableArray),那么您有几个选项:

1-像这里的答案一样,您可以创建自定义绑定.如果您不想将值绑定到视图模型上的属性,则可以将绑定简化为:

ko.bindingHandlers.datepicker = {
    init: function(element, valueAccessor) {
        //initialize datepicker with some optional options
        var options = ko.utils.unwrapObservable(valueAccessor());
        $(element).datepicker(options);

        //handle disposal (if KO removes by the template binding)
        ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
            $(element).datepicker("destroy");
        });
    }
}; 
Run Code Online (Sandbox Code Playgroud)

你可以把它放在一个元素上:

<input data-bind="datepicker: { minDate: new Date() }" />

2-另一种选择是使用afterRender 功能template(和foreach它使用template)新内容之后被渲染到线了您的datepickers.