Vue tinymce富文本編輯器


tinymce 官方為 vue 項目提供了一個組件 tinymce-vue

一、安裝tinymce-vue

npm install @tinymce/tinymce-vue -S

 

二、下載tinymce

npm install tinymce -S

該文的使用方式在最新vue存在tinymce版本過高的情況,可安裝指定版本"@tinymce/tinymce-vue": "^3.2.8"   "tinymce": "~5.1.0"

 

 

下載的時候可以先在static(public)下面建個目錄tinymce,下載tinymce完成后在node_modules 中找到 tinymce/skins目錄,將其復制到static\tinymce目錄下面

三、下載中文語言包

https://www.tiny.cloud/get-tiny/language-packages/

 

 

下載完成后將其解壓到public\tinymce目錄下面,最終目錄結構形式如下 

 

 

四、創建組件tinymce.vue

 

 

<template>
  <div class="tinymce-editor">
    <editor v-model = "myValue" :init="init" :disabled="disabled" @onClick="onClick"></editor>
  </div>
</template>
<script>
// import axios from "axios";
import tinymce from "tinymce/tinymce";
import Editor from "@tinymce/tinymce-vue";
import "tinymce/themes/silver";
// 編輯器插件plugins
// 更多插件參考:https://www.tiny.cloud/docs/plugins/
import "tinymce/plugins/image"; // 插入上傳圖片插件
// import 'tinymce/plugins/media'// 插入視頻插件
import "tinymce/plugins/table"; // 插入表格插件
import "tinymce/plugins/lists"; // 列表插件
import "tinymce/plugins/wordcount"; // 字數統計插件
export default {
  components: {
    Editor
  },
  props: {
    value: {
      type: String,
      default: ""
    },
    // 基本路徑,默認為空根目錄,如果你的項目發布后的地址為目錄形式,
    // 即abc.com/tinymce,baseUrl需要配置成tinymce,不然發布后資源會找不到
    baseUrl: {
      type: String,
      default: ""
    },
    disabled: {
      type: Boolean,
      default: false
    },
    plugins: {
      type: [String, Array],
      default: "lists image table wordcount"
    },
    // 在toolbar中添加工具欄相應按鈕
    toolbar: {
      type: [String, Array],
      default:
        "undo redo |  formatselect | bold italic forecolor backcolor | alignleft aligncenter alignright alignjustify | bullist numlist outdent indent | lists image table | removeformat"
    }
  },
  data() {
    return {
      init: {
        language_url: `${this.baseUrl}/tinymce/langs/zh_CN.js`, // 語言包路徑
        language: "zh_CN",  //語言
        skin_url: `${this.baseUrl}/tinymce/skins/ui/oxide`, //skin路徑
        content_css: `${this.baseUrl}/tinymce/skins/content/default/content.css`,
        // skin_url: `${this.baseUrl}/tinymce/skins/ui/oxide-dark`, // 暗色系
        // content_css: `${this.baseUrl}/tinymce/skins/content/dark/content.css`, // 暗色系
        height: 300,  //編輯器高度
        plugins: this.plugins,
        toolbar: this.toolbar,
        branding: false,  //是否禁用“Powered by TinyMCE”
        menubar: false, //頂部菜單欄顯示
        // 此處為圖片上傳處理函數
        // 如需ajax上傳可參考https://www.tiny.cloud/docs/configure/file-image-upload/#images_upload_handler
        // images_upload_handler: (blobInfo, success, failure) => {
          // let formdata = new FormData()
          // formdata.set('file', blobInfo.blob())
          // axios.post(url, formdata).then(res => {
          //   success(res.data.data)
          // }).catch(res => {
          //   failure('error')
          // })
        // },
      },
      myValue: this.value
    };
  },
  mounted() {
    tinymce.init({});
  },
  methods: {
    // 添加相關的事件,可用的事件參照文檔=> https://github.com/tinymce/tinymce-vue => All available events
    // 需要什么事件可以自己增加
    onClick(e) {
      this.$emit("onClick", e, tinymce);
    },
    // 可以添加一些自己的自定義事件,如清空內容
    clear() {
      this.myValue = "";
    }
  },
  watch: {
    value(newValue) {
      this.myValue = newValue;
    },
    myValue(newValue) {
      this.$emit("input", newValue);
    }
  }
};
</script>

 五、引入組件

<template>
  <div>
    <tinymce-editor ref="editor" v-model="value"></tinymce-editor>
  </div>
</template>

<script>
import tinymceEditor from "./tinymce.vue";
export default {
  data() {
    return {
      value: ""
    };
  },
  components: {
    tinymceEditor
  }
};
</script>

效果圖如下

移動端處理富文本參數(圖片、長串字母)

        let obj = res.data;    // 假如該參數為富文本內容
        obj.content = obj.content.replace(/<img/g, "<img width='100%'")  
        obj.content = obj.content.replace(/[\s;]width:.+?/gi, '')
        obj.content = obj.content.replace(/<img[^>]*?(src="[^"]*?")[^>]*?>/g, '<img $1/>')
        obj.content = obj.content.replace(/\<img/gi, '<img style="max-width:100%;height:auto"')
        obj.content = obj.content.replace(/<p/g, "<p style='word-wrap:break-word'")


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM