Problemas encontrados al usar el cuadro de texto enriquecido tinymce en el proyecto vue 2.0

Instalar Tinymce

Ahora, la última versión de tinymce-vue es 4.0 y se usa vue3.0, por lo que el proyecto vue2.0 creado debe usar la versión anterior (instale la versión especificada).

Primero instale el componente vue de tinymce, porque no hay un servicio registrado:

npm install @tinymce/tinymce-vue@2.0.0 -S

Luego instala tinymce:

npm install tinymce@5.0.3 -S

Por supuesto, también se pueden instalar otras versiones.Mi
inserte la descripción de la imagen aquí
proyecto vue2.0 usó directamente el siguiente comando para instalar la última versión de tinymce al principio, y luego informó un error.Si es un proyecto vue3, debería poder ser instalado así.

npm install @tinymce/tinymce-vue -S
npm install tinymce -S

Descargar paquete de idioma chino

tinymce está en inglés, por lo que debe descargar el paquete chino del sitio web oficial:
Dirección: https://www.tiny.cloud/get-tiny/language-packages/
inserte la descripción de la imagen aquí
inserte la descripción de la imagen aquí

configuración

Cree una carpeta tinymce debajo de la carpeta pública para almacenar archivos tinymce.
inserte la descripción de la imagen aquí

Cree una nueva carpeta langs en la carpeta tinymce para paquetes de idiomas,
luego copie la carpeta de máscaras de node_modules y colóquela en la carpeta tinymce.

Tenga en cuenta que hay dos carpetas relacionadas con tinymce en la carpeta node_modules, una es @tinymce y la otra es tinymce. No se equivoque. Los íconos se
inserte la descripción de la imagen aquí
usan para mostrar íconos para cuadros de texto enriquecido. Amigos que no tienen los íconos La carpeta se puede descargar directamente desde Hacer una copia en otro lugar.

<Baidu Netdisk>: paquete comprimido de toda la carpeta tinymce
Enlace: https://pan.baidu.com/s/1ADkod4auWdwEFhXy9ndIjg
Código de extracción: nrq1

La estructura en iconos se muestra en la figura:
inserte la descripción de la imagen aquí

usar tinymce

Primero escriba un componente tinymce y luego importe este componente

componente tinymce (solo como referencia)

En el siguiente código, la parte de la imagen está disponible, pero la parte del video no está disponible.

<template>
  <div>
    <div class="tinymce-box">
      <!--      <el-button @click="clickHandler">上传视频</el-button>-->
      <Editor
        v-model="contentValue"
        :init="init"
        :disabled="disabled"
        @onClick="onClick"
      />
    </div>
  </div>
</template>

<script>
//引入tinymce编辑器
import Editor from "@tinymce/tinymce-vue";

//引入node_modules里的tinymce相关文件文件
import tinymce from "tinymce/tinymce"; //tinymce默认hidden,不引入则不显示编辑器
import "tinymce/themes/silver"; //编辑器主题,不引入则报错
import "tinymce/icons/default"; //引入编辑器图标icon,不引入则不显示对应图标

// 引入编辑器插件(基本免费插件都在这儿了)
import "tinymce/icons/default/icons";
import "tinymce/plugins/advlist"; //高级列表
import "tinymce/plugins/anchor"; //锚点
import "tinymce/plugins/autolink"; //自动链接
import "tinymce/plugins/autoresize"; //编辑器高度自适应,注:plugins里引入此插件时,Init里设置的height将失效
import "tinymce/plugins/autosave"; //自动存稿
import "tinymce/plugins/charmap"; //特殊字符
import "tinymce/plugins/code"; //编辑源码
import "tinymce/plugins/codesample"; //代码示例
import "tinymce/plugins/directionality"; //文字方向
import "tinymce/plugins/emoticons"; //表情
import "tinymce/plugins/fullpage"; //文档属性
// import "tinymce/plugins/fullscreen"; //全屏
import "tinymce/plugins/help"; //帮助
import "tinymce/plugins/hr"; //水平分割线
import "tinymce/plugins/importcss"; //引入css
import "tinymce/plugins/insertdatetime"; //插入日期时间
import "tinymce/plugins/link"; //超链接
import "tinymce/plugins/lists"; //列表插件
import "tinymce/plugins/media"; //插入编辑媒体
import 'tinymce/plugins/image'; // 插入图片
import "tinymce/plugins/nonbreaking"; //插入不间断空格
import "tinymce/plugins/pagebreak"; //插入分页符
import "tinymce/plugins/paste"; //粘贴插件
import "tinymce/plugins/preview"; //预览
import "tinymce/plugins/print"; //打印
import "tinymce/plugins/quickbars"; //快速工具栏
import "tinymce/plugins/save"; //保存
import "tinymce/plugins/searchreplace"; //查找替换
// import 'tinymce/plugins/spellchecker'  //拼写检查,未加入汉化,不建议使用
import "tinymce/plugins/tabfocus"; //切入切出,按tab键切出编辑器,切入页面其他输入框中
import "tinymce/plugins/table"; //表格
import "tinymce/plugins/template"; //内容模板
import "tinymce/plugins/textcolor"; //文字颜色
import "tinymce/plugins/textpattern"; //快速排版
import "tinymce/plugins/toc"; //目录生成器
import "tinymce/plugins/visualblocks"; //显示元素范围
import "tinymce/plugins/visualchars"; //显示不可见字符
import "tinymce/plugins/wordcount"; //字数统计
import {
    
     uploadImage, uploadVideo } from "@/api/fileApi"; 

export default {
    
    
  name: "TEditor",
  components: {
    
    
    Editor,
  },
  props: {
    
    
    value: {
    
    
      type: String,
      default: "",
    },
    disabled: {
    
    
      type: Boolean,
      default: false,
    },
    plugins: {
    
    
      type: [String, Array],
      default:
        "print preview searchreplace autolink directionality visualblocks visualchars fullscreen template code codesample table charmap hr pagebreak nonbreaking anchor insertdatetime advlist lists image media wordcount textpattern autosave ",
    },
    toolbar: {
    
    
      type: [String, Array],
      default:
        "undo redo restoredraft | cut copy paste pastetext | forecolor backcolor bold italic underline strikethrough link anchor | alignleft aligncenter alignright alignjustify outdent indent | \
                styleselect formatselect fontselect fontsizeselect | bullist numlist | lists image table | blockquote subscript superscript removeformat | \
                table hr pagebreak insertdatetime print preview | code selectall searchreplace visualblocks | indent2em lineheight formatpainter axupimgs",
    },
  },
  data() {
    
    
    return {
    
    
      dialogVisible: false,
      video: {
    
    },
      init: {
    
    
        language_url: "tinymce/langs/zh_CN.js", //引入语言包文件
        language: "zh_CN", //语言类型

        skin_url: "tinymce/skins/ui/oxide", //皮肤:浅色
        // skin_url: '/tinymce/skins/ui/oxide-dark',//皮肤:暗色

        plugins: this.plugins, //插件配置
        toolbar: this.toolbar, //工具栏配置,设为false则隐藏
        // menubar: 'file edit',  //菜单栏配置,设为false则隐藏,不配置则默认显示全部菜单,也可自定义配置--查看 http://tinymce.ax-z.cn/configure/editor-appearance.php --搜索“自定义菜单”

        fontsize_formats:
          "12px 14px 16px 18px 20px 22px 24px 28px 32px 36px 48px 56px 72px", //字体大小
        font_formats:
          "微软雅黑=Microsoft YaHei,Helvetica Neue,PingFang SC,sans-serif;苹果苹方=PingFang SC,Microsoft YaHei,sans-serif;宋体=simsun,serif;仿宋体=FangSong,serif;黑体=SimHei,sans-serif;Arial=arial,helvetica,sans-serif;Arial Black=arial black,avant garde;Book Antiqua=book antiqua,palatino;", //字体样式
        lineheight_formats: "0.5 0.8 1 1.2 1.5 1.75 2 2.5 3 4 5", //行高配置,也可配置成"12px 14px 16px 20px"这种形式

        height: 275, //注:引入autoresize插件时,此属性失效
        placeholder: "在这里输入文字",
        branding: false, //tiny技术支持信息是否显示
        resize: "both", //编辑器宽高是否可变,false-否,true-高可变,'both'-宽高均可,注意引号
        // statusbar: false,  //最下方的元素路径和字数统计那一栏是否显示
        elementpath: false, //元素路径是否显示

        content_style: "img {max-width:100%;}", //直接自定义可编辑区域的css样式
        // content_css: '/tinycontent.css',  //以css文件方式自定义可编辑区域的css样式,css文件需自己创建并引入

        // images_upload_url: '/apib/api-upload/uploadimg',  //后端处理程序的url,建议直接自定义上传函数image_upload_handler,这个就可以不用了
        // images_upload_base_path: '/demo',  //相对基本路径--关于图片上传建议查看--http://tinymce.ax-z.cn/general/upload-images.php
        paste_data_images: true, //图片是否可粘贴

        images_upload_handler: (blobInfo, success, failure) => {
    
    
          if (blobInfo.blob().size / 1024 / 1024 > 20) {
    
    
            failure("上传失败,图片大小请控制在 20M 以内");
          } else {
    
    
            let formData = new FormData();
            formData.append("picture", blobInfo.blob());
            formData.append("action", "add")

            uploadImage({
    
     formData })
              .then((res) => {
    
    
                console.log(res)
                console.log('/media/' + res.pic)
                success('/media/' + res.pic);
              })
              .catch(() => {
    
    
                failure("上传出错,服务器开小差了呢");
              });
          }
        },
      },
      contentValue: this.value,
    };
  },
  watch: {
    
    
    value(newValue) {
    
    
      this.contentValue = newValue;
    },
    contentValue(newValue) {
    
    
      this.$emit("input", newValue);
    },
  },
  created() {
    
    },
  mounted() {
    
    
    tinymce.init({
    
    });
  },
  methods: {
    
    
    /**获取文件 */
    getFile(event) {
    
    
      this.video = event.target.files;
      this.$message.success("成功选择文件");
    },

    /** 提交添加视频请求*/
    addVideo() {
    
    
      var formData = new FormData();
      formData.append("file", this.video);
      console.log(formData.get("file"));
      uploadVideo(formData)
        .then((res) => {
    
    
          if (this.contentValue === undefined) {
    
    
            tinymce.activeEditor.setContent(
              `<p>
               <span class="mce-preview-object mce-object-video" contenteditable="false" data-mce-object="video" data-mce-p-allowfullscreen="allowfullscreen" data-mce-p-frameborder="no" data-mce-p-scrolling="no" data-mce-p-src=${
      
      res.location} "data-mce-html="%20">
                 <video src=${
      
      res.location} width="100%" controls="controls"></video>
               </span>
            </p>`
            );
          } else {
    
    
            tinymce.activeEditor.setContent(
              this.contentValue +
                `<p>
               <span class="mce-preview-object mce-object-video" contenteditable="false" data-mce-object="video" data-mce-p-allowfullscreen="allowfullscreen" data-mce-p-frameborder="no" data-mce-p-scrolling="no" data-mce-p-src=${
      
      res.location} "data-mce-html="%20">
                 <video src=${
      
      res.location} width="100%" controls="controls"></video>
               </span>
            </p>`
            );
          }
          this.$message({
    
    
            type: "success",
            message: "添加成功",
          });
        })
        .catch(() => {
    
    
          this.$message({
    
    
            type: "error",
            message: "请先上传视频",
          });
        });
    },
    clickHandler() {
    
    
      this.dialogVisible = true;
    },
    handleClose() {
    
    
      this.dialogVisible = false;
      this.video = {
    
    };
    },
    // 添加相关的事件,可用的事件参照文档=> https://github.com/tinymce/tinymce-vue => All available events
    onClick(e) {
    
    
      this.$emit("onClick", e, tinymce);
    },
    //清空内容
    clear() {
    
    
      this.contentValue = "";
    },
  },
};
</script>

<style lang="less">
.tox-notifications-container {
    
    
  display: none;
}

.tox-tinymce-aux {
    
    
  z-index: 5000 !important;
}
</style>

Introduzca el componente tinymce donde se utilizará el cuadro de texto enriquecido

// 在需要使用富文本框的地方直接使用tinymce就可以了
<tinymce
    v-model="d"
    :disabled="disabled"
    ref="editor"
    style="height: auto; border-radius: 22px"
></tinymce>
              
import tinymce from "./tinymce";

export default {
    
    
  components: {
    
     tinymce },
  name: "Home",
  data() {
    
    
  	......
  }
}  

inserte la descripción de la imagen aquí

Supongo que te gusta

Origin blog.csdn.net/Charonmomo/article/details/122855665
Recomendado
Clasificación