tinymce富文本支持word内容同时粘贴文字图片上传 vue2

效果图

先放文件


文件自取tinymce: tinymce富文本简单配置及word内容粘贴图片上传
封装tinymce

文件自取:tinymce: tinymce富文本简单配置及word内容粘贴图片上传
页面引用组件

javascript 复制代码
          <TinymceSimplify ref='TinymceSimplify'   v-model="knowledgeBlockItem.content" :disabled="disable" :height="530" class="filter-item" />


  import TinymceSimplify from '@/components/TinymceSimplify'

    components: {

      TinymceSimplify,
    },



  searchData(res) {
         this.knowledgeBlockItem.content=res.data
 this.$refs.TinymceSimplify.changeVaulue(res.data)
        },

简单解释一下封装文件的内容

总体思路就是,找到粘贴的内容将img的src转换成Blob URI,这样页面可以正常展示图片了
src/components/TinymceSimplify/index

复制代码
data() {
    return {
      //初始化配置
      myValue: this.value,
      init: {
       
        init_instance_callback: editor => {
          editor.on("paste", evt => {
            // 监听粘贴事件
            this.onPaste(evt);
          });
        },
 
    };
  },

提取图片信息,转换成Blob URI,再在监听事件中获取页面元素,将img src转换

javascript 复制代码
  editor.on("NodeChange Change KeyUp SetContent", () => {
            this.hasChange = true;
            this.$nextTick(() => {
              console.log("输入?zhelieditor.getContent()");
              console.log("this.pasteChange", this.pasteChange);

              if (this.pasteChange) {
                // HTML字符串
                let htmlString = editor.getContent();
                // Blob URL数组
                let urls = this.blobUrlArr;

                // 使用DOMParser解析HTML字符串
                let parser = new DOMParser();
                let doc = parser.parseFromString(htmlString, "text/html");

                // 获取所有的<img>标签
                let imgs = doc.querySelectorAll("img");

                // 遍历imgs和urls数组,设置每个img的src属性
                imgs.forEach((img, index) => {
                  if (index < urls.length) {
                    // 确保不会越界
                    img.src = urls[index];
                  }
                });

                // 现在doc包含了修改后的DOM,但如果你需要将其转换回字符串,可以这样做:
                let modifiedHtmlString = doc.body.innerHTML;

                console.log("htmlContent8999", modifiedHtmlString);
                this.pasteChange = false;

                this.$nextTick(() => {
                  editor.setContent(modifiedHtmlString);
                });
              }

              this.$emit("input", editor.getContent());
            });
          });
          editor.on("paste", (evt) => {
            // 监听粘贴事件
            this.onPaste(evt, editor);
          });

        },
相关推荐
earthzhang20215 小时前
【1039】判断数正负
开发语言·数据结构·c++·算法·青少年编程
蕓晨5 小时前
auto 自动类型推导以及注意事项
开发语言·c++·算法
mjhcsp6 小时前
C++ 递推与递归:两种算法思想的深度解析与实战
开发语言·c++·算法
m0_748248026 小时前
《详解 C++ Date 类的设计与实现:从运算符重载到功能测试》
java·开发语言·c++·算法
张人玉6 小时前
TCP 的三次握手和四次挥手
网络·tcp/ip·c#
我命由我123456 小时前
Java 并发编程 - Delay(Delayed 概述、Delayed 实现、Delayed 使用、Delay 缓存实现、Delayed 延迟获取数据实现)
java·开发语言·后端·缓存·java-ee·intellij-idea·intellij idea
HLJ洛神千羽6 小时前
C++程序设计实验(黑龙江大学)
开发语言·c++·软件工程
kyle~6 小时前
算法数学---差分数组(Difference Array)
java·开发语言·算法
曹牧6 小时前
C#:三元运算符
开发语言·c#
Jonathan Star7 小时前
MediaPipe 在Python中实现人体运动识别,最常用且高效的方案是结合**姿态估计**(提取人体关键点)和**动作分类**(识别具体运动)
开发语言·python·分类