vue2.0项目中使用Ueditor富文本编辑器应用中出现的问题

Posted 菜鸟的梦想*

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了vue2.0项目中使用Ueditor富文本编辑器应用中出现的问题相关的知识,希望对你有一定的参考价值。

1、如何设置config中的内容

readonly:true,//只读模式
wordCount:false,//是否开启字数统计
enableAutoSave: false,//自动保存功能

重点:enableAutoSave不一定生效,怎么办?

ueditor.config.js文件中设置enableAutoSave参数为false就可以关闭本地保存功能。

 //启用自动保存
 ,enableAutoSave: false

ueditor1.4.3版本是没有效果的,需要修改代码,在ueditor1.5.0版本已经得到修复。

修改方法
ueditor.all.js文件

找到

// plugins/autosave.js
UE.plugin.register(‘autosave‘, function (){

    var me = this,
        //无限循环保护
        lastSaveTime = new Date(),
        //最小保存间隔时间
        MIN_TIME = 20,
        //auto save key
        saveKey = null;

    function save ( editor ) {

        var saveData;

        if ( new Date() – lastSaveTime < MIN_TIME ) {
            return;
        }

        if ( !editor.hasContents() ) {
            //这里不能调用命令来删除, 会造成事件死循环
            saveKey && me.removePreferences( saveKey );
            return;
        }

        lastSaveTime = new Date();

        editor._saveFlag = null;

        saveData = me.body.innerhtml;

        if ( editor.fireEvent( "beforeautosave", {
            content: saveData
        } ) === false ) {
            return;
        }

        me.setPreferences( saveKey, saveData );

        editor.fireEvent( "afterautosave", {
            content: saveData
        } );

    }

    return {
        defaultOptions: {
            //默认间隔时间
            saveInterval: 500
        },
        bindEvents:{
            ‘ready‘:function(){

                var _suffix = "-drafts-data",
                    key = null;

                if ( me.key ) {
                    key = me.key + _suffix;
                } else {
                    key = ( me.container.parentNode.id || ‘ue-common‘ ) + _suffix;
                }

                //页面地址+编辑器ID 保持唯一
                saveKey = ( location.protocol + location.host + location.pathname ).replace( /[.:\/]/g, ‘_‘ ) + key;

            },

            ‘contentchange‘: function () {
               //新增加的代码
                if (!me.getOpt(‘enableAutoSave‘)) {
                    return;
                }

                if ( !saveKey ) {
                    return;
                }

                if ( me._saveFlag ) {
                    window.clearTimeout( me._saveFlag );
                }

                if ( me.options.saveInterval > 0 ) {

                    me._saveFlag = window.setTimeout( function () {

                        save( me );

                    }, me.options.saveInterval );

                } else {

                    save(me);

                }

            }
        },
        commands:{
            ‘clearlocaldata‘:{
                execCommand:function (cmd, name) {
                    if ( saveKey && me.getPreferences( saveKey ) ) {
                        me.removePreferences( saveKey )
                    }
                },
                notNeedUndo: true,
                ignoreContentChange:true
            },

            ‘getlocaldata‘:{
                execCommand:function (cmd, name) {
                    return saveKey ? me.getPreferences( saveKey ) || ‘‘ : ‘‘;
                },
                notNeedUndo: true,
                ignoreContentChange:true
            },

            ‘drafts‘:{
                execCommand:function (cmd, name) {
                    if ( saveKey ) {
                        me.body.innerHTML = me.getPreferences( saveKey ) || ‘<p>‘+domUtils.fillHtml+‘</p>‘;
                        me.focus(true);
                    }
                },
                queryCommandState: function () {
                    return saveKey ? ( me.getPreferences( saveKey ) === null ? -1 : 0 ) : -1;
                },
                notNeedUndo: true,
                ignoreContentChange:true
            }
        }
    }

});

以下是新增加的代码
if (!me.getOpt(‘enableAutoSave‘)) {
    return;
}

ueditor1.4.3版本自动保存关闭不了
https://github.com/fex-team/ueditor/issues/470

已在1.5.0分支修改
https://github.com/fex-team/ueditor/blob/dev-1.5.0/_src/plugins/autosave.js#L71-73

以上是关于vue2.0项目中使用Ueditor富文本编辑器应用中出现的问题的主要内容,如果未能解决你的问题,请参考以下文章

在Vue2.0中集成UEditor 富文本编辑器

ckeditor-vue2.0 接入富文本框

WEB项目中使用UEditor(富文本编辑器)

百度富文本编辑器UEDITOR

新手如何在Vue项目中优雅的使用UEditor(百度富文本编辑器)

vue 使用Ueditor富文本的配置