【Vue】集成富文本编辑器

这文章使用的是wangeditor插件,官网地址:wangEditor,这个比较简单

安装

复制代码
npm i wangeditor --save

使用

复制代码
<div id="editor"></div>

import E from "wangeditor"

const editor = new E("#editor")
editor.create()

//或者
export default {
data() {
   return {
     editor: null
   }
}
this.editor = new E(`#editor`)//设置参数
this.editor.create() //创建

报错:

原因是在打开表单的时候元素还没创建好,所以找不到

解决方法:

使用NextTick:在下次 DOM 更新循环结束之后执行延迟回调。在修改数据之后立即使用这个方法,获取更新后的 DOM。

复制代码
this.$nextTick(() => {
        this.editor = new E(`#editor`)//设置参数
        this.editor.create() //创建
      })

销毁编辑器

关闭时销毁,不然下次打开内容还在编辑器中

复制代码
//在dialog销毁时调用
beforeDestroy() {
this.editor.destroy ()
this.editor = null
}

// 获取编辑器内容
this.editor.txt.html()

配置图片上传

配置图片上传接口

java 复制代码
 @PostMapping("/editor/upload")
    public Dict editorUpload(MultipartFile file) throws IOException {
        String originaFilename = file.getOriginalFilename();//文件原始名 a.jpg
        String mainname = FileUtil.mainName(originaFilename);//a
        String extname = FileUtil.extName(originaFilename);//jpg
        File parentFile = new File(ROOT_PATH);
        if (!FileUtil.exist(ROOT_PATH)) {
            //若当前父级目录不存在就创建一个
            FileUtil.mkdir(ROOT_PATH);
        }
        if (FileUtil.exist(ROOT_PATH + File.separator + originaFilename)) {
            //若当前上传的文件名已存在,则重命名
            originaFilename = System.currentTimeMillis() + "_" + mainname + "." + extname;//124234_a.jpg
        }
        File saveFile = new File(ROOT_PATH + File.separator + originaFilename);
        file.transferTo(saveFile);//存储到本地
        String url = "http://localhost:8080/file/download/" + originaFilename;
        Dict dict=Dict.create().set("errno",0).set("data", CollUtil.newArrayList(Dict.create().set("url",url)));
        //返回
        return dict;
    }

前端使用接口:

TypeScript 复制代码
this.editor.config.uploadImgServer = this.$baseUrl + '/file/editor/upload'
this.editor.config.uploadFileName = 'file'
this.editor.config.uploadImgHeaders = {
     token: this.user.token
}

server 接口返回格式,重要!!!

复制代码
{
"errno": 0,
"data":[
    {url:"图片地址"}
 ]
}

视频上传

TypeScript 复制代码
this.editor.config.uploadVideoServer = this.$baseUrl + '/file/editor/upload'
        this.editor.config.uploadVideoName = 'file'
        this.editor.config.uploadVideoHeaders = {
          token: this.user.token
        }

写到这里报错了,最后发现视频的格式和图片格式要求不一样,视频格式:

所以需要改一下后端接口,判断是视频还是图片,最后完整代码:

接口:

java 复制代码
@PostMapping("/editor/upload")
    public Dict editorUpload(@RequestParam MultipartFile file, @RequestParam String type) throws IOException {
        String originaFilename = file.getOriginalFilename();
        String mainname = FileUtil.mainName(originaFilename);
        String extname = FileUtil.extName(originaFilename);
        if (!FileUtil.exist(ROOT_PATH)) {
            FileUtil.mkdir(ROOT_PATH);
        }
        if (FileUtil.exist(ROOT_PATH + File.separator + originaFilename)) {
            //若当前上传的文件名已存在,则重命名
            originaFilename = System.currentTimeMillis() + "_" + mainname + "." + extname;//124234_a.jpg
        }
        File saveFile = new File(ROOT_PATH + File.separator + originaFilename);
        file.transferTo(saveFile);//存储到本地
        String url = "http://localhost:8080/file/download/" + originaFilename;
        Dict dict = Dict.create().set("errno", 0);
        if ("img".equals(type)) {
            dict = Dict.create().set("errno", 0).set("data", CollUtil.newArrayList(Dict.create().set("url", url)));
        } else if ("video".equals(type)) {
            dict = Dict.create().set("errno", 0).set("data", Dict.create().set("url", url));
        }
        //返回
        return dict;
    }

前端:

javascript 复制代码
//编辑显示
this.$nextTick(() => {
        this.editor = new E(`#editor`)//设置参数

        this.editor.config.uploadImgServer = this.$baseUrl + '/file/editor/upload'
        this.editor.config.uploadFileName = 'file'
        this.editor.config.uploadImgHeaders = {
          token: this.user.token
        }
        this.editor.config.uploadImgParams = {
          type: 'img'
        }
        this.editor.config.uploadVideoServer = this.$baseUrl + '/file/editor/upload'
        this.editor.config.uploadVideoName = 'file'
        this.editor.config.uploadVideoHeaders = {
          token: this.user.token
        }
        this.editor.config.uploadVideoParams = {
          type: 'video'
        }
        this.editor.create() //创建
        this.editor.txt.html(row.content)
      })
相关推荐
百锦再3 分钟前
国产数据库的平替亮点——关系型数据库架构适配
android·java·前端·数据库·sql·算法·数据库架构
旺仔Sec3 分钟前
2025年海南省职业院校技能大赛“应用软件系统开发“赛项竞赛样题
前端·应用软件系统开发
码界奇点6 分钟前
基于SpringBoot和Vue的Fuint门店会员营销系统设计与实现
vue.js·spring boot·后端·毕业设计·springboot·源代码管理
爱笑的眼睛1111 分钟前
文本分类的范式演进:从统计概率到语言模型提示工程
java·人工智能·python·ai
周杰伦_Jay24 分钟前
【Go/Python/Java】基础语法+核心特性对比
java·python·golang
sszdlbw26 分钟前
后端springboot框架入门学习--第一篇
java·spring boot·学习
FakeOccupational26 分钟前
【树莓派 002】 RP2040 实现示波器 PIO来驱动 ADC10080 并抓取数据方案+ 内置12-bitADC&DMA&网页前端可视化方案
前端
小鹿学程序29 分钟前
jdk配置完之后java -version还是默认的jdk版本如何更改
java·开发语言·python
至善迎风30 分钟前
Bun:下一代 JavaScript 运行时与工具链
开发语言·javascript·ecmascript·bun