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'")