我正在尝试使用自定义绑定显示通知 DIV,同时还通过 2 个 observables 调整该 DIV 的 CSS 和 HTML。
问题是,当我更改这两个可观察对象的值时,它也会出于某种原因触发自定义绑定。
模板:
<div class="alert top-alert" data-bind="fade: topMessageShow, css: topMessageType, html: topMessage"></div>
自定义处理程序:
ko.bindingHandlers.fade = {
update: function resolveFade(element, valueAccessor, allBindingsAccessor) {
if (ko.utils.unwrapObservable( valueAccessor() )) {
$(element).hide().delay(300).fadeIn('slow');
} else {
// fade out the notification and reset it
$(element).fadeOut('slow', function() {
// reset those 2 observables that set class and HTML of the notification DIV
MyClass.topMessageType('');
MyClass.topMessage('');
});
}
}
};
触发代码:
MyClass.topMessageType('alert-info');
MyClass.topMessage(msg);
MyClass.topMessageShow(true);
JSFiddle:http: //jsfiddle.net/UrxXF/1/