国产开源富文本编辑器 wangEditor,本姓编辑器

关注我的公众号:【编程朝花夕拾】,可获取首发内容。

01 引言

上一节介绍了轻量级的富文本编辑器,基本上已经可以满足了日常的使用。又发现一款国产的编辑器wangEditor,因为我也姓wang,本姓的富文本编辑器必须了解一下。

02 简介

wangEditor 是国产开源富文本编辑器,专为国内开发者设计。

GitHubstar数高达18.3k

03 快速开始

2.1 引入JS和CSS

javascript 复制代码
<link href="https://unpkg.com/@wangeditor/editor@latest/dist/css/style.css" rel="stylesheet"/>
  <style>
	  #editor---wrapper {
		border: 1px solid #ccc;
		z-index: 100; /* 按需定义 */
	  }
	  #toolbar-container {
		border-bottom: 1px solid #ccc;
	  }
	  #editor-container {
		height: 500px;
	  }
  </style>

<!-- 引入 JS -->
<script src="https://unpkg.com/@wangeditor/editor@latest/dist/index.js"></script>

2.2 Html结构

html 复制代码
<div id="editor---wrapper">
	<div id="toolbar-container"><!-- 工具栏 --></div>
	<div id="editor-container"><!-- 编辑器 --></div>
</div>

2.3 初始化

javascript 复制代码
  const { createEditor, createToolbar } = window.wangEditor

  const editorConfig = {
    placeholder: '<p>请输入内容...</p>',
    onChange(editor) {
      const html = editor.getHtml()
      console.log('editor content', html)
      // 也可以同步到 <textarea>
    },
    MENU_CONF: {
      // 配置图片上传  
      uploadImage: {
        server: '/api/upload-image',
        fieldName: 'file',
        maxFileSize: 5 * 1024 * 1024,
        onSuccess(file, res) {
          console.log('上传成功')
        },
        onFailed(file, res) {
          alert('上传失败')
        }
      }
    }
  }

  const editor = createEditor({
    selector: '#editor-container',
    html: '<p><br></p>',
    config: editorConfig,
    mode: 'default', // or 'simple'
  })

  const toolbarConfig = {}

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

工具栏的模式有两种:

  • default:默认模式 - 集成了 wangEditor 所有功能
  • simple: 简洁模式 - 仅有部分常见功能,但更加简洁易用

2.4 效果

默认模式

简介模式

图片上传

请求已发出

04 常用API

4.1 获取/设置内容

javascript 复制代码
// 获取 HTML 内容
const html = editor.getHtml()

// 获取纯文本
const text = editor.getText()

// 设置 HTML 内容
editor.setHtml('<p>新内容</p>')

// 清空内容
editor.clear()

// 获取 JSON 内容(用于保存)
const content = editor.children

4.2 焦点与禁用

javascript 复制代码
// 获取焦点
editor.focus()

// 失去焦点
editor.blur()

// 是否可编辑
editor.enable()
editor.disable()

4.3 内容监听

javascript 复制代码
// 内容变化时触发
editor.on('change', () => {
  console.log('内容变化', editor.getHtml())
})

05 常见问题

5.1 图片上传后不显示

  • 检查返回格式:{ errno: 0, data: { url: '图片地址' } }
  • 确认图片地址可访问
  • 检查静态资源映射是否正确

5.2 工具栏不显示

  • 确认 CSS 已引入
  • 检查容器 ID 是否正确

5.3 获取内容为空

  • 确保编辑器已初始化完成
  • 使用 editor.getHtml() 获取

06 版本说明

版本 说明
v4 旧版本,不推荐新项目使用
v5 当前版本,基于 slate.js 重写,推荐使用
相关推荐
Cosolar3 分钟前
72小时生死时速:一文读懂引爆Fable模型禁令的越狱技术风暴
人工智能·后端·程序员
我登哥MVP5 分钟前
SpringCloud 核心组件解析:分布式配置管理
java·spring boot·分布式·spring·spring cloud·java-ee·maven
lihao lihao6 分钟前
linux线程
java·开发语言·jvm
满怀冰雪7 分钟前
第13篇-栈算法入门-括号匹配-表达式与单调栈基础
java·算法
我是一颗柠檬11 分钟前
【Java项目技术亮点】Redis Lua脚本原子化操作:高并发场景下的终极武器
java·redis·lua
swg32132112 分钟前
Redis实现主从选举
java·前端·redis
砍材农夫14 分钟前
python环境|pip|uv|venv|Conda区别
后端·python·conda·pip·uv
Java 码思客14 分钟前
【ElasticSearch 从入门到架构师】第6章_分词器与文本检索
java·elasticsearch
Flittly14 分钟前
【AgentScope Java新手村系列】(6)Hook与Middleware
java·spring boot·笔记·spring·ai
向量引擎14 分钟前
AI API 正在进入“请求生命周期治理”阶段:从模型迁移、Agent 接入到成本与安全排错的工程化方法
java·人工智能·python·aigc·ai编程·ai写作·gpu算力