KnockoutJS と jwysiwyg プラグイン ( https://github.com/jwysiwyg/jwysiwyg ) が関係する状況があります。以下に示すカスタムバインディングを使用しています。ただし、ユーザーがテキストを 2 行目に更新するたびに、バインディングを介してコンテンツを更新すると、カーソルがエディターの一番最初にリセットされます。そのため、ユーザーが更新後に 1 秒以上入力を一時停止すると、続行するには以前の場所に戻る必要があります。
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);
}
};
(バインディングはこれによって使用されます)
<textarea data-bind="wysiwyg: yourViewModelValue"></textarea>
更新が完了したら、キャレット位置を取得してカーソルを復元するにはどうすればよいですか? または、更新時にカーソルが動かないようにする他の解決策はありますか?
編集:問題を示すためのjsfiddle。 http://jsfiddle.net/797ZL/ 2 行目以降に入力してから 1 秒間停止すると、カーソルがリセットされることに注意してください。