Summernote Editor переводит курсор на первую строку при нажатии горячих клавиш - PullRequest
0 голосов
/ 29 декабря 2018

Я использую summenote, и недавно я применил код в summernote для изменения тегов, таких как <b> и <i> на <strong> и <em>, код работает отлично, но я начинаю сталкиваться с проблемой, которая возникает теперь, когда янажмите горячие клавиши для bold и italics, чтобы текстовый курсор снова вернулся к самой первой строке.

Ниже приведен код, который я использую для преобразования тегов:

function clean_html(editor, type, value)
        {
            if (value.indexOf("<"+type+">") >= 0)
                {
                    if(type == "b")
                        {
                            marca = /<b(?:.*?)>(?:.*?)<\/b>/g;
                            replaceIniTag = "<strong>";
                            replaceEndTag = "</strong>";
                        }
                    else
                        {
                            marca = /<i(?:.*?)>(?:.*?)<\/i>/g;
                            replaceIniTag = "<em>";
                            replaceEndTag = "</em>";
                        }
                    var matches = value.match(marca), 
                    len = matches.length,
                    i;
                    for (i = 0; i < len; i++)
                        {
                            str = $(matches[i]).text();
                            str = replaceIniTag+str+replaceEndTag;
                            value = value.replace(matches[i], str);
                        }
                    $('#post_content').summernote('code', value); //Replace the editor content
                }
        }

Ниже приведен код, который я использую для инициализации SummerNote.

$('#post_content').summernote(
        {
            height: 200,
            focus: false,
            disableDragAndDrop: true,
            popover: {
                        image: [],
                        link: [],
                        air: []
                      },
            // disableResizeEditor: true,
            placeholder: "Type Your Post Content...",
            toolbar: [
                        ['cleaner',['cleaner']], // The Button
                        ['style', ['style']],
                        // ['style', ['bold', 'italic', 'underline', 'strikethrough', 'superscript', 'subscript', 'clear']],
                        ['style', ['bold', 'italic', 'underline', 'strikethrough', 'superscript', 'subscript']],
                        // ['fontname', ['fontname']],
                        ['fontsize', ['fontsize']],
                        ['color', ['color']],
                        ['para', ['ul', 'ol', 'paragraph']],
                        ['height', ['height']],
                        ['table', ['table']],
                        ['insert', ['link', 'hr']],
                        // ['insert', ['link', 'picture', 'video', 'hr', 'readmore']],
                        ['view', ['fullscreen', 'codeview']]
                        // ['help', ['help']]
                    ],
            cleaner:{
                          action: 'both', // both|button|paste 'button' only cleans via toolbar button, 'paste' only clean when pasting content, both does both options.
                          newline: '<br>', // Summernote's default is to use '<p><br></p>'
                          notStyle: 'position:absolute;top:0;left:0;right:0', // Position of Notification
                          icon: '<i class="note-icon-row-remove"></i>',
                          keepHtml: false, // Remove all Html formats
                          keepOnlyTags: ['<p>', '<br>', '<ul>', '<li>', '<b>', '<strong>','<i>', '<a>'], // If keepHtml is true, remove all tags except these
                          keepClasses: false, // Remove Classes
                          badTags: ['style', 'script', 'applet', 'embed', 'noframes', 'noscript', 'html'], // Remove full tags with contents
                          badAttributes: ['style', 'start'], // Remove attributes from remaining tags
                          limitChars: false, // 0/false|# 0/false disables option
                          limitDisplay: 'both', // text|html|both
                          limitStop: false // true/false
                    },
                callbacks:
                    {
                        onPaste: function (e)
                            {
                                var thisNote = $(this);
                                var updatePastedText = function(someNote)
                                    {
                                        var original = someNote.code();
                                        var cleaned = CleanPastedHTML(original); //this is where to call whatever clean function you want. I have mine in a different file, called CleanPastedHTML.
                                        someNote.code('').html(cleaned); //this sets the displayed content editor to the cleaned pasted code.
                                    };
                                setTimeout(function ()
                                    {
                                        //this kinda sucks, but if you don't do a setTimeout, 
                                        //the function is called before the text is really pasted.
                                        updatePastedText(thisNote);
                                    }, 10);
                            },
                        onChange: function(contents, $editable)
                            {
                                clean_html(this, "b", contents);
                                clean_html(this, "i", contents);
                            }
                    }
        });

Кто-нибудь может дать мне знать, из-за чего этот триггер встречается?

...