jQuery Cleditor get textarea value on keyup

前端 未结 3 1999
被撕碎了的回忆
被撕碎了的回忆 2021-02-08 10:19

I\'m using Cleditor http://premiumsoftware.net/cleditor/docs/GettingStarted.html. I want to get the value on keyup and insert the text into another div. cleditor comes with chan

相关标签:
3条回答
  • 2021-02-08 10:41

    It appears that cleditor hides the textarea and replaces it with an iframe (see line 203 of cleditor source).

    So to achieve what you want, you just need to access the resulting iframe contents:

    $("#input").cleditor();
    
    $(".cleditorMain iframe").contents().find('body').bind('keyup', function(){
        var v = $(this).text(); // or .html() if desired
        $('#x').html(v);
    });
    

    Updated jsFiddle

    UPDATE to address Tim's comment

    This works in Chrome and Firefox (I don't have access to IE):

    $("#input").cleditor();
    
    $( $(".cleditorMain iframe")[0].contentWindow.document ).bind('keyup', function(){
        var v = $(this).text(); // or .html() if desired
        $('#x').html(v);
    });
    

    Updated jsFiddle

    UPDATE 2

    User ima007 was able to find a better cross-browser solution: jQuery Cleditor wysiwyg text editor: keyup() works in webkit browsers but not Firefox or IE

    0 讨论(0)
  • 2021-02-08 10:54

    I was able to achieve this by slightly modifying the source code of the editor - in refresh method (line 801) I modified the blur event handler of iframe doc.

    Previous

    // Update the textarea when the iframe loses focus
        ($.browser.mozilla ? $doc : $(contentWindow)).blur(function() {
          updateTextArea(editor, true);
        });
    

    Modified to

    // Update the textarea when the iframe loses focus or keyup happens
            ($.browser.mozilla ? $doc : $(contentWindow)).bind('blur keyup', function (e) {
                updateTextArea(editor, true);
    
                if (options.keyup && e.type === 'keyup')
                    options.keyup(editor.$area.val());
            });
    

    and in the options that are passed at the time of initialisation, you can define

    $("#element").cleditor({
    keyup : function (text) {
     alert(text);
     // do something
    }
    });
    

    Hope this helps anyone.

    Regards

    0 讨论(0)
  • 2021-02-08 10:58

    Have you tried using of CLEditor '.doc' property?

    doc - The document object currently being edited in the iframe. cleditor documentation

    var inputDoc = $("#input").cleditor().doc;
    
    $(inputDoc).keyup(function(){
        var v = $('#input').val();
       $('#x').html(v);
    })
    
    0 讨论(0)
提交回复
热议问题