wangEditor 是一款基于原生 JavaScript 封装开源免费的富文本编辑器,支持常规的文字排版操作插入图片插入视频插入代码功能,同时提供多样化的扩展功能(如字体、颜色、表情、代码、地图插件),支持插件开发自定义配置。该编辑简洁易用,功能齐全,可广泛应用于各种 Web 项目中。

以下实战记录基于wangEditor V5版,说明文档传送门

一、编辑基本配置

在这里插入图片描述
wangEditor 从 V5 版本开始,工具栏配置菜单配置(如配置颜色、字体、链接校验上传图片等)分离了。

1.编辑器自适应CSS

        #editorwrapper {
            border: 1px solid #ccc;
            z-index: 100; /* 按需定义 */
        }

        #toolbar-container {
            border-bottom: 1px solid #ccc;
        }

        #editor-container {
            height: 500px;
        }

2.构建编辑容器

<div id="editorwrapper"&gt;
    <div id="toolbar-container"&gt;<!-- 工具栏 --></div>
    <div id="editor-container"><!-- 编辑器 --></div>
</div>

3.配置项设置

    //配置项
    const {createEditor, createToolbar} = window.wangEditor
    const editorConfig = {
        MENU_CONF: {},
        placeholder: 'Type here...',
        onChange(editor) {
            const html = editor.getHtml()
            //console.log(html)
        }
    }
    
 const editor = createEditor({
        selector: '#editor-container',
        html: '',//预置内容
        config: editorConfig,
        mode: 'default', // or 'simple'
    })

    const toolbarConfig = {}
    const toolbar = createToolbar({
        editor,
        selector: '#toolbar-container',
        config: toolbarConfig,
        uploadVideoShow: false,
        mode: 'default', // or 'simple'
    })

4.获取内容

   $("#btn").click(function () {
        const html1 = editor.getHtml()
        console.log(html1);
    });

【注意】 HTML 内容必须是 wangEditor 生成的(即 editor.getHtml() 返回的) HTML 格式不可自己随意写。HTML 格式非常灵活,wangEditor 无法兼容所有的 HTML 格式例如wangEditor 可以识别 hello加粗,但无法识别 hello 等其他加粗方式

二、上传图片配置

1.前端配置

    //上传图片
    editorConfig.MENU_CONF['uploadImage'] = {
        server: 'up.php',
        maxFileSize: 1 * 1024 * 1024, // 1M
        allowedFileTypes: ['image/*'],
        // 单个文件上传失败
        onFailed(file, res) {
            console.log('上传失败', res)
        },
    }

2.后台API接口配置

up.php文件(未做上传逻辑展示

$res = ["errno" => 0,
    "data" => [
        "url" => "20230613110558393.jpg"
    ]
];
die(json_encode($res));
$res = [
    "errno" => 1,
    "message" => "失败信息"
];

die(json_encode($res));

三、隐藏上传视频

在这里插入图片描述

1.获取工具栏按钮

    console.log(toolbar.getConfig().toolbarKeys);

2.排除菜单

在这里插入图片描述

    //工具栏配置项
    const toolbarConfig = {}

    //排除菜单
    toolbarConfig.excludeKeys = [
        'uploadVideo' // 排除菜单组,写菜单组 key 的值即可
    ]

    const toolbar = createToolbar({
        editor,
        selector: '#toolbar-container',
        config: toolbarConfig,
        uploadVideoShow: false,
        mode: 'default', // or 'simple'
    })

总结

一直使用layui作为前端的配合组件,但是随着功能需求的不断增加。layedit富文本编辑器在2.8版本中彻底放弃了,只好寻找其他的富文本编辑器。

  1. wangEditor 从 V5 版本开始,有较大的技术更新
  2. wangEditor 有详细中文文档,以及中文交流环境
  3. wangEditor 内置了所有常见的富文本操作功能,能满足绝大部分使用需求直接配置使用即可,无需再二次开发
  4. wangEditor 有丰富的 API 和足够的扩展性,允许你自定义开发菜单、模块插件等;
  5. wangEditor 开源多年,大量用户使用和反馈,已经解决了很多问题

@漏刻有时

原文地址:https://blog.csdn.net/weixin_41290949/article/details/131206335

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任

如若转载,请注明出处:http://www.7code.cn/show_38134.html

如若内容造成侵权/违法违规/事实不符,请联系代码007邮箱suwngjj01@126.com进行投诉反馈,一经查实,立即删除

发表回复

您的电子邮箱地址不会被公开。 必填项已用 * 标注