关于更改回调问题的Summernote v0.7.0

问题描述 投票:0回答:2

有一个简单的设置为summernote。

<div id="summernote">data-here</div>


$('#summernote').summernote({
  height: 200,                 // set editor height
  focus: true,
  callbacks // any callbacks didn't worked, onChange, onBlur etc..(any tip on how to add proper callbacks here)
});

我试图制作jquery代码以捕捉我的summernote的更改事件,例如:

$('#summernote').on("summernote.change", function (e) {
 # Problem here when deleting (keyboard backspace, calls twice)
 -some code here-
}

我对summernote.change的问题是,当使用keybord的退格键删除文本/内容时,回调(在更改时)会触发两次。因此我的内部函数也会运行两次。

对这个家伙有任何想法,提前谢谢。

javascript jquery summernote
2个回答
0
投票

据我所知,这是一个已知问题(https://github.com/summernote/summernote/issues/2888),但没有人试图修复它。

所以,我这样使用它:

        var mySec = 100;
        var myEvent;

        $('#summernote').on("summernote.change", function (e) {
            clearTimeout(myEvent);

            myEvent = setTimeout(function(){
                console.log(e) // do something!
            }, mySec);
        });

我希望这能帮到您 :)


1
投票

我试图重新创建这个问题。但它对我来说很好。

$(document).ready(function() {
  $('#summernote').summernote({
    height: 200, // set editor height
    focus: true,
    callbacks: {
      onInit: function() {
        console.log('Summernote is launched');
      },
      onChange: function(contents, $editable) {
        console.log('onChange:', contents, $editable);
      }
    }
  });
  $('#summernote').on('summernote.change', function(we, contents, $editable) {
    console.log('summernote.change', contents, $editable);
  });
});
<!-- include libraries(jQuery, bootstrap) -->
<link href="http://netdna.bootstrapcdn.com/bootstrap/3.3.5/css/bootstrap.css" rel="stylesheet">
<script src="http://cdnjs.cloudflare.com/ajax/libs/jquery/3.2.1/jquery.js"></script>
<script src="http://netdna.bootstrapcdn.com/bootstrap/3.3.5/js/bootstrap.js"></script>

<!-- include summernote css/js -->
<link href="http://cdnjs.cloudflare.com/ajax/libs/summernote/0.8.11/summernote.css" rel="stylesheet">
<script src="http://cdnjs.cloudflare.com/ajax/libs/summernote/0.8.11/summernote.js"></script>

<div id="summernote">data-here</div>

注意:您应该在回调中使用onChange事件,或者在两者中使用summernote.change

© www.soinside.com 2019 - 2024. All rights reserved.