2

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 秒間停止すると、カーソルがリセットされることに注意してください。

4

1 に答える 1

3

これがあなたが見ているものです:

  1. ユーザーが WYSIWYG エディターにテキストを入力します。
  2. ユーザーが入力を停止し、1 秒後にタイムアウトになり、detectFn がトリガーされます
  3. detectFn は、WYSIWYG エディターから新しい値を取得し、オブザーバブルを更新します
  4. 更新中のオブザーバブルは、カスタムバインダーで update メソッドをトリガーします
  5. カスタム バインダーの update メソッドは、オブザーバブルから値を取得し、WYSIWYG エディターに設定します。
  6. 新しい値が設定された WYSIWYG エディターは、カーソルを一番上の行に移動します。

これを修正するには、手順 5 の途中で処理を停止し、WYSIWYG エディターの値が監視対象の値と異なる場合 (つまり、監視対象が WYSIWYG エディターの外部から更新された場合) にのみ値を更新します。

更新方法を次のように変更します。

update: function (element, valueAccessor) {
    var newValue = ko.utils.unwrapObservable(valueAccessor());
    var oldValue = $(element).wysiwyg("getContent");
    if (newValue !== oldValue) {
        $(element).wysiwyg("setContent", newValue);
    }
    // ko.bindingHandlers.value.update(element, valueAccessor);
}

そのメソッドの最後の行をコメントアウトしました...無関係のようで、なぜそこにあるのかよくわかりません。

また、これらのコード行も何もしていないようです:

$.extend(true, {
    initialContent : value
}, options);

あなたがしようとしているのは、initialContent プロパティを options オブジェクトに追加することだと思います。これは次の方法で実行できます。

$.extend(options, {initialContent: value});

ただし、init メソッドの後に update メソッドが呼び出され、オブザーバブルからの値がその時点で WYSIWYG エディターに読み込まれるため、それも必要ありません。

更新されたコードのフィドルは次のとおりです。http://jsfiddle.net/tlarson/797ZL/2/

于 2013-05-15T03:13:15.127 に答える