vue中使用Tinymce

  • vue中使用Tinymce已关闭评论
  • 210 次浏览
  • A+
所属分类:Web前端
摘要

npm i tinymce
npm i @tinymce/tinymce-vue或:yarn add tinymceyarn add @tinymce/tinymce-vue 地址:中文语言包


1、安装tinymce编辑器

npm i tinymce
npm i @tinymce/tinymce-vue

或:

yarn add tinymce

yarn add @tinymce/tinymce-vue

 

2、配置中文语言包

地址:中文语言包

注:最好将语言包放在public/langs/或static/langs/目录下,下面组件将会引用

 

3、封装组件

在components 目录下新建 tinymce.vue 

<template>     <div>         <Editor :id="tinymceId" :init="init" :disabled="disabled" v-model="myValue"></Editor>     </div> </template>  <script> //引入tinymce-vue import Editor from '@tinymce/tinymce-vue' //公共的图片前缀 //import Global from "./Global"; export default {     components: { Editor },     props: {         //编号         id: {             type: String         },         //内容         value: {             type: String,             default: ''         },         //是否禁用         disabled: {             type: Boolean,             default: false         },         //插件         plugins: {             type: [String, Array],             default: 'preview searchreplace autolink directionality visualblocks visualchars fullscreen image link media code codesample table charmap pagebreak nonbreaking anchor insertdatetime advlist lists wordcount help emoticons autosave autoresize formatpainter',         },         //工具栏         toolbar: {             type: [String, Array],             default: 'code undo redo restoredraft | fullscreen | cut copy paste pastetext | forecolor backcolor bold italic underline strikethrough link anchor | alignleft aligncenter alignright alignjustify outdent indent |      styleselect formatselect fontselect fontsizeselect | bullist numlist | blockquote subscript superscript removeformat |      table image media charmap emoticons hr pagebreak insertdatetime print preview | bdmap indent2em lineheight formatpainter axupimgs',         }     },     data() {         let that = this;         return {             tinymceId: this.id || 'vue-tinymce' + Date.parse(new Date()),             myValue: this.value,             init: {                 //汉化,路径是自定义的                 language_url: '/tinymce/langs/zh_CN.js',                 language: 'zh_CN',                 //皮肤                 skin: 'oxide',                 //插件                 plugins: this.plugins,                 //工具栏                 toolbar: this.toolbar,                 //高度                 height: 500,                 //图片上传                 images_upload_handler: function (blobInfo, success, failure) {                     //文件上传的formData传递                     let formData = new FormData();                     formData.append('file', blobInfo.blob(), blobInfo.filename());                     //上传的api,和后端配合,返回的是图片的地址,然后加上公共的图片前缀                     that.$api.system.uploadImage(formData).then(res => {                         var url = "tt"//Global.baseUrlImg + res;                         console.log(url)                         success(url)                     }).catch(res => {                         failure('图片上传失败')                     });                 }             }         }     },     methods: {      },     watch: {         //监听内容变化         value(newValue) {             this.myValue = newValue         },         myValue(newValue) {             this.$emit('input', newValue)         }     } } </script> <style> .tox-notifications-container {     display: none; }  /*在页面正常使用时不用加这个样式,在弹窗使用时,要加这个样式,因为使用弹窗,z-index层数比较低,工具栏的一些工具不能使用,要将z-index层数提高。*/ .tox.tox-silver-sink.tox-tinymce-aux {     z-index: 2100 !important; }</style>

 

4、引用组件

新建test.vue

<template>     <div>         <TinymceEditor :value="content" @input="newContent"></TinymceEditor>     </div> </template>    <script> import TinymceEditor from "./components/tinymce.vue" export default {     components: {         TinymceEditor     },     data() {         return {             content: ""         }     },     methods: {         // 获取富文本的内容         newContent(val) {             this.content = val; // 直接更新 content 属性         }     } } </script>

 

注:文件引入路径是关键