当前位置:首页 > 科技  > 软件

Vue3问题:如何使用WangEditor富文本?能自定义才是真的会用!

来源: 责编: 时间:2023-12-01 17:14:34 161观看
导读一、需求分析,问题描述1、需求使用富文本进行内容编辑,要求自定义工具栏菜单顺序及其分组,并且要求自定义选择图片、自定义选择视频。2、问题如何配置开始使用?如何自定义工具栏菜单的展示?如何自定义工具栏内置菜单的功能

OFx28资讯网——每日最新资讯28at.com

一、需求分析,问题描述

1、需求

使用富文本进行内容编辑,要求自定义工具栏菜单顺序及其分组,并且要求自定义选择图片、自定义选择视频。OFx28资讯网——每日最新资讯28at.com

OFx28资讯网——每日最新资讯28at.com

2、问题

  • 如何配置开始使用?
  • 如何自定义工具栏菜单的展示?
  • 如何自定义工具栏内置菜单的功能?
  • 如何自定义扩展新功能菜单?

二、解决问题,答案速览

实现代码如下,复制粘贴即可直接使用。OFx28资讯网——每日最新资讯28at.com

如果你有时间,具体问题梳理、代码分析、知识总结,可见第三部分。OFx28资讯网——每日最新资讯28at.com

1、配置开始使用

(1)下载依赖

npm i @wangeditor/editor @wangeditor/editor-for-vue

(2)引入css和内置组件

// 引入 cssimport '@wangeditor/editor/dist/css/style.css' // 引入 组件import { Editor, Toolbar } from '@wangeditor/editor-for-vue'// 引入 接口类型import { IDomEditor, IEditorConfig } from "@wangeditor/editor";

(3)使用

<template><div style="border: 1px solid #ccc"><Toolbarstyle="border-bottom: 1px solid #ccc":editor="editorRef":defaultConfig="toolbarConfig":mode="mode"/><Editorstyle="height: 500px; overflow-y: hidden;"v-model="valueHtml":defaultConfig="editorConfig":mode="mode"@onCreated="handleCreated"/></div></template><script lang="ts" setup>import "@wangeditor/editor/dist/css/style.css";import { Editor, Toolbar } from "@wangeditor/editor-for-vue";import { IDomEditor, IEditorConfig } from "@wangeditor/editor";import { onBeforeUnmount, ref, shallowRef, onMounted } from 'vue'// 编辑器实例,必须用 shallowRefconst editorRef = shallowRef()// 内容 HTMLconst valueHtml = ref('<p>hello</p>')// 模拟 ajax 异步获取内容onMounted(() => {setTimeout(() => {valueHtml.value = '<p>模拟 Ajax 异步设置内容</p>'}, 1500)})// 工具栏配置const toolbarConfig = {toolbarKeys: []}// 编辑器配置const editorConfig = { placeholder: '请输入内容...',MENU_CONF: {}}// 组件销毁时,也及时销毁编辑器onBeforeUnmount(() => {const editor = editorRef.valueif (editor == null) returneditor.destroy()})// 组件创建时const handleCreated = (editor) => {editorRef.value = editor // 记录 editor 实例,重要!}</script>

2、自定义工具栏菜单的展示

工具栏菜单的展示,如菜单的顺序和分组、添加删除。OFx28资讯网——每日最新资讯28at.com

如果想要自定义,只需修改工具栏配置对象的toolbarKeys属性。toolbarKeys属性值是一个数组,内部填写菜单的key,使用官方API接口editor.getAllMenuKeys()可查询全部内置菜单的key。OFx28资讯网——每日最新资讯28at.com

// 工具栏配置const toolbarConfig = {toolbarKeys: [// 一些常用的菜单 key'bold', // 加粗'italic', // 斜体'through', // 删除线'underline', // 下划线'bulletedList', // 无序列表'numberedList', // 有序列表'color', // 文字颜色'insertLink', // 插入链接'fontSize', // 字体大小'lineHeight', // 行高'uploadImage', // 上传图片'uploadVideo',//上传视频'delIndent', // 缩进'indent', // 增进'deleteImage',//删除图片'divider', // 分割线'insertTable', // 插入表格'justifyCenter', // 居中对齐'justifyJustify', // 两端对齐'justifyLeft', // 左对齐'justifyRight', // 右对齐'undo', // 撤销'redo', // 重做'clearStyle', // 清除格式'fullScreen' // 全屏]}

3、自定义工具栏内置菜单的功能

工具栏菜单的功能,如链接、上传图片、上传视频。OFx28资讯网——每日最新资讯28at.com

如果想要自定义,只需修改编辑器配置对象的MENU_CONF属性。不同的功能都对应着不同的MENU_CONF属性值,这里我以问题提出者的问题为示例,具体请参考官方文档,写的非常不错的,放下面吧。OFx28资讯网——每日最新资讯28at.com

OFx28资讯网——每日最新资讯28at.com

https://www.wangeditor.com/v5/menu-config.html.OFx28资讯网——每日最新资讯28at.com

// 编辑器配置const editorConfig = { placeholder: '请输入内容...',MENU_CONF: {// 上传图片uploadImage: {// 自定义选择图片async customBrowseAndUpload(insertFn: InsertFnType) {// 打开图片素材库photoGalleryDialogVisible.value = true},},// 上传视频uploadVideo: {// 自定义选择视频async customBrowseAndUpload(insertFn: InsertFnType) {// 打开视频素材库videoGalleryDialogVisible.value = true},}, }}

4、自定义扩展新功能菜单

(1)定义菜单class

目前可以自定义扩展的功能菜单有按钮、下拉、下拉面板、模态框。OFx28资讯网——每日最新资讯28at.com

新建myButtonMenu.ts文件,把下面代码放进去。OFx28资讯网——每日最新资讯28at.com

import { IButtonMenu, IDomEditor } from '@wangeditor/editor'class MyButtonMenu implements IButtonMenu { // TS 语法// class MyButtonMenu { // JS 语法constructor() {this.title = 'My menu title' // 自定义菜单标题// this.iconSvg = '<svg>...</svg>' // 可选this.tag = 'button'}// 获取菜单执行时的 value ,用不到则返回空 字符串或 falsegetValue(editor: IDomEditor): string | boolean { // TS 语法// getValue(editor) { // JS 语法return ' hello '}// 菜单是否需要激活(如选中加粗文本,“加粗”菜单会激活),用不到则返回 falseisActive(editor: IDomEditor): boolean { // TS 语法// isActive(editor) { // JS 语法return false}// 菜单是否需要禁用(如选中 H1 ,“引用”菜单被禁用),用不到则返回 falseisDisabled(editor: IDomEditor): boolean { // TS 语法// isDisabled(editor) { // JS 语法return false}// 点击菜单时触发的函数exec(editor: IDomEditor, value: string | boolean) { // TS 语法// exec(editor, value) { // JS 语法if (this.isDisabled(editor)) returneditor.insertText(value) // value 即 this.value(editor) 的返回值}}

(2)注册和插入菜单

定义菜单key时,要保证key唯一,不能和内置菜单key重复。插入菜单时,将对应的菜单key放在toolbarKeys想要的顺序位置即可。OFx28资讯网——每日最新资讯28at.com

import { Boot } from '@wangeditor/editor'import MyButtonMenu from './myButtonMenu'// 工具栏配置const toolbarConfig = {toolbarKeys: [// 插入菜单key'menu1',]}// 组件创建时const handleCreated = (editor: IDomEditor) => {editorRef.value = editor;const menu1Conf = {key: 'menu1', // 定义 menu key :要保证唯一、不重复(重要)factory() {return new MyButtonMenu() // 替换为你菜单的 class},}// 注册菜单Boot.registerMenu(menu1Conf)};

三、问题解析,知识总结

1、如何配置开始使用?

补充几点注意事项吧,这也是官方提醒:OFx28资讯网——每日最新资讯28at.com

  • editorRef 必须用 shallowRef定义。具体原因待研究,用ref似乎也行。
  • 组件销毁时,要及时销毁编辑器。

2、如何自定义工具栏菜单的展示?

这里补充几个官方API:OFx28资讯网——每日最新资讯28at.com

  • editor.getAllMenuKeys() 查询编辑器注册的所有菜单 key (可能有的不在工具栏上)
  • toolbar.getConfig().toolbarKeys 查看当前菜单排序和分组
  • 这块其它API挺鸡肋的,不用看了就,写上搞得代码很乱,直接在工具栏配置对象里操作就好了,比较清晰,自我感觉哈。
import { DomEditor } from '@wangeditor/editor'const toolbar = DomEditor.getToolbar(editor)const toolbarConfig = toolbar.getConfig()// 查看当前菜单排序和分组console.log( toolbarConfig.toolbarKeys )

3、如何自定义工具栏内置菜单的功能?

这里有通用的操作,参考官方,分两步实现:OFx28资讯网——每日最新资讯28at.com

OFx28资讯网——每日最新资讯28at.com

4、如何自定义扩展新功能菜单?

这里官方提供了三处参考:定义新菜单、定义插件、定义新元素。OFx28资讯网——每日最新资讯28at.com

我认为定义新菜单是比较常用的,这样其实已经就很灵活了。至于其他两项有需求的朋友,可以自行研究一番,可能比较烧哈。OFx28资讯网——每日最新资讯28at.com

OFx28资讯网——每日最新资讯28at.com

最后插一句,WangEditor这个库,写的真是挺不错的!OFx28资讯网——每日最新资讯28at.com

本文链接:http://www.28at.com/showinfo-26-35876-0.htmlVue3问题:如何使用WangEditor富文本?能自定义才是真的会用!

声明:本网页内容旨在传播知识,若有侵权等问题请及时与本网联系,我们将在第一时间删除处理。邮件:2376512515@qq.com

上一篇: 深入了解 React Fiber:应用与源码实现

下一篇: 如何有效使用Java并发Atomic包的原子类型

标签:
  • 热门焦点
  • 跑分安卓第一!Redmi K60至尊版8月发布!卢伟冰:目标年度性能之王

    跑分安卓第一!Redmi K60至尊版8月发布!卢伟冰:目标年度性能之王

    8月5日消息,Redmi K60至尊版将于8月发布,在此前举行的战略发布会上,官方该机将搭载搭载天玑9200+处理器,安兔兔V10跑分超177万分,是目前安卓阵营最高的分数
  • JavaScript 混淆及反混淆代码工具

    JavaScript 混淆及反混淆代码工具

    介绍在我们开始学习反混淆之前,我们首先要了解一下代码混淆。如果不了解代码是如何混淆的,我们可能无法成功对代码进行反混淆,尤其是使用自定义混淆器对其进行混淆时。什么是混
  • 从 Pulsar Client 的原理到它的监控面板

    从 Pulsar Client 的原理到它的监控面板

    背景前段时间业务团队偶尔会碰到一些 Pulsar 使用的问题,比如消息阻塞不消费了、生产者消息发送缓慢等各种问题。虽然我们有个监控页面可以根据 topic 维度查看他的发送状态,
  • 如何正确使用:Has和:Nth-Last-Child

    如何正确使用:Has和:Nth-Last-Child

    我们可以用CSS检查,以了解一组元素的数量是否小于或等于一个数字。例如,一个拥有三个或更多子项的grid。你可能会想,为什么需要这样做呢?在某些情况下,一个组件或一个布局可能会
  • 一篇聊聊Go错误封装机制

    一篇聊聊Go错误封装机制

    %w 是用于错误包装(Error Wrapping)的格式化动词。它是用于 fmt.Errorf 和 fmt.Sprintf 函数中的一个特殊格式化动词,用于将一个错误(或其他可打印的值)包装在一个新的错误中。使
  • 三言两语说透柯里化和反柯里化

    三言两语说透柯里化和反柯里化

    JavaScript中的柯里化(Currying)和反柯里化(Uncurrying)是两种很有用的技术,可以帮助我们写出更加优雅、泛用的函数。本文将首先介绍柯里化和反柯里化的概念、实现原理和应用
  • iQOO Neo8系列或定档5月23日:首发天玑9200+ 安卓跑分王者

    iQOO Neo8系列或定档5月23日:首发天玑9200+ 安卓跑分王者

    去年10月,iQOO推出了iQOO Neo7系列机型,不仅搭载了天玑9000+,而且是同价位唯一一款天玑9000+直屏旗舰,一经上市便受到了用户的广泛关注。在时隔半年后,
  • 微软发布Windows 11新版 引入全新任务栏状态

    微软发布Windows 11新版 引入全新任务栏状态

    近日,微软发布了Windows 11新版,而Build 22563更新主要引入了几周前曝光的平板模式任务栏等,系统更流畅了。更新中,Windows 11加入了专门针对平板优化的任务栏
  • 北京:科技教育体验基地开始登记

    北京:科技教育体验基地开始登记

      北京“科技馆之城”科技教育体验基地登记和认证工作日前启动。首批北京科技教育体验基地拟于2023年全国科普日期间挂牌,后续还将开展常态化登记。  北京科技教育体验基
Top