contenteditable change events

前端 未结 19 2335
粉色の甜心
粉色の甜心 2020-11-22 01:36

I want to run a function when a user edits the content of a div with contenteditable attribute. What\'s the equivalent of an onchange

相关标签:
19条回答
  • 2020-11-22 01:43

    Based on @balupton's answer:

    $(document).on('focus', '[contenteditable]', e => {
    	const self = $(e.target)
    	self.data('before', self.html())
    })
    $(document).on('blur', '[contenteditable]', e => {
    	const self = $(e.target)
    	if (self.data('before') !== self.html()) {
    	  self.trigger('change')
    	}
    })
    <script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>

    0 讨论(0)
  • 2020-11-22 01:44

    I built a jQuery plugin to do this.

    (function ($) {
        $.fn.wysiwygEvt = function () {
            return this.each(function () {
                var $this = $(this);
                var htmlold = $this.html();
                $this.bind('blur keyup paste copy cut mouseup', function () {
                    var htmlnew = $this.html();
                    if (htmlold !== htmlnew) {
                        $this.trigger('change')
                    }
                })
            })
        }
    })(jQuery);
    

    You can simply call $('.wysiwyg').wysiwygEvt();

    You can also remove / add events if you wish

    0 讨论(0)
  • 2020-11-22 01:45

    Here's what worked for me:

       var clicked = {} 
       $("[contenteditable='true']").each(function(){       
            var id = $(this).attr("id");
            $(this).bind('focus', function() {
                // store the original value of element first time it gets focus
                if(!(id in clicked)){
                    clicked[id] = $(this).html()
                }
            });
       });
    
       // then once the user clicks on save
       $("#save").click(function(){
                for(var id in clicked){
                    var original = clicked[id];
                    var current = $("#"+id).html();
                    // check if value changed
                    if(original != current) save(id,current);
                }
       });
    
    0 讨论(0)
  • 2020-11-22 01:48

    non jQuery quick and dirty answer:

    function setChangeListener (div, listener) {
    
        div.addEventListener("blur", listener);
        div.addEventListener("keyup", listener);
        div.addEventListener("paste", listener);
        div.addEventListener("copy", listener);
        div.addEventListener("cut", listener);
        div.addEventListener("delete", listener);
        div.addEventListener("mouseup", listener);
    
    }
    
    var div = document.querySelector("someDiv");
    
    setChangeListener(div, function(event){
        console.log(event);
    });
    
    0 讨论(0)
  • 2020-11-22 01:48

    To avoid timers and "save" buttons, you may use blur event wich fires when the element loses focus. but to be sure that the element was actually changed (not just focused and defocused), its content should be compared against its last version. or use keydown event to set some "dirty" flag on this element.

    0 讨论(0)
  • 2020-11-22 01:49

    I'd suggest attaching listeners to key events fired by the editable element, though you need to be aware that keydown and keypress events are fired before the content itself is changed. This won't cover every possible means of changing the content: the user can also use cut, copy and paste from the Edit or context browser menus, so you may want to handle the cut copy and paste events too. Also, the user can drop text or other content, so there are more events there (mouseup, for example). You may want to poll the element's contents as a fallback.

    UPDATE 29 October 2014

    The HTML5 input event is the answer in the long term. At the time of writing, it is supported for contenteditable elements in current Mozilla (from Firefox 14) and WebKit/Blink browsers, but not IE.

    Demo:

    document.getElementById("editor").addEventListener("input", function() {
        console.log("input event fired");
    }, false);
    <div contenteditable="true" id="editor">Please type something in here</div>

    Demo: http://jsfiddle.net/ch6yn/2691/

    0 讨论(0)
提交回复
热议问题