6

そのため、ノックアウトjsがjQueryjwysiwygプラグインでうまく機能しないことに気づきました。

このブログ投稿を読んだ後: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);
    }
};

このように使用します:

<textarea data-bind="wysiwyg: yourViewModelValue"></textarea>

これまでのところ、それは私のために働いています、どんなコメントでもありがたいです。

これは、kockoutjsとjwysiwygが一緒にtextarea要素をバインドすることを検討している人には役立つと思います。

4

0 に答える 0