Rem*_*Ros 6 html javascript jwysiwyg knockout.js
所以我注意到淘汰js与jQuery jwysiwyg插件不兼容.
阅读这篇博客后:http://www.knockmeout.net/2011/07/another-look-at-custom-bindings-for.html 这SO回答:如何检测到的内容与jQuery的变化使用jWYSIWYG插件的textarea?
我编写了以下绑定处理程序:
ko.bindingHandlers.wysiwyg = {
init: function (element, valueAccessor, allBindingsAccessor) {
var options = allBindingsAccessor().wysiwygOptions || {};
var value = ko.utils.unwrapObservable(valueAccessor());
var $e = $(element);
$.extend(true, {
initialContent : value
}, options);
$e.wysiwyg(options);
//handle the field changing
function detectFn() {
var observable = valueAccessor();
var newvalue = $e.wysiwyg("getContent");
observable(newvalue);
}
var current = $e.wysiwyg('document');
var timer;
current.bind({
keyup: function(){
clearTimeout(timer);
timer = setTimeout(detectFn, 1000);
}
});
//handle disposal (if KO removes by the template binding)
ko.utils.domNodeDisposal.addDisposeCallback(element, function() {
$e.wysiwyg('destroy');
});
},
update: function (element, valueAccessor) {
var value = ko.utils.unwrapObservable(valueAccessor());
$(element).wysiwyg("setContent", value);
ko.bindingHandlers.value.update(element, valueAccessor);
}
};
Run Code Online (Sandbox Code Playgroud)
使用这样:
<textarea data-bind="wysiwyg: yourViewModelValue"></textarea>
Run Code Online (Sandbox Code Playgroud)
到目前为止,它对我有用,任何意见将不胜感激.
我认为这对任何想要将kockout js和jwysiwyg一起工作以绑定textarea元素的人都有用.
| 归档时间: |
|
| 查看次数: |
1821 次 |
| 最近记录: |