0
点赞
收藏
分享

微信扫一扫

作品管理-集成富文本编辑器

caoxingyu 2022-06-01 阅读 53

插件安装

​tinymce​​​ 官方提供了一个 vue 的组件 ​​tinymce-vue​​ 安装指令如下

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

npm install tinymce -S --no-fund

在 ​​public​​​ 文件夹中导入语言包,语言包下载地址为:​​https://www.tiny.cloud/get-tiny/language-packages/​​

作品管理-集成富文本编辑器_ico

在 node_modules 里面找到 ​​tinymce​​​, 将 ​​skins​​ 目录复制到 public/tinymce 里面

作品管理-集成富文本编辑器_ico_02

作品管理-集成富文本编辑器_ico_03

语言包也要放进去

作品管理-集成富文本编辑器_版本号_04

然后在 components 文件夹下新一个 ​​Tinymce.vue​​ 的组件内容如下

作品管理-集成富文本编辑器_Project_05

<template>
  <div class="tinymce-box">
    <editor v-model="myValue"
            :init="init"
            :disabled="disabled"
            @onClick="onClick">
    </editor>
  </div>
</template>

<script>
import tinymce from 'tinymce/tinymce' //tinymce默认hidden,不引入不显示
import Editor from '@tinymce/tinymce-vue'
import 'tinymce/themes/silver'
// 编辑器插件plugins
// 更多插件参考:https://www.tiny.cloud/docs/plugins/
import 'tinymce/icons/default/icons.min.js'
import 'tinymce/plugins/image'// 插入上传图片插件
import 'tinymce/plugins/media'// 插入视频插件
import 'tinymce/plugins/table'// 插入表格插件
import 'tinymce/plugins/lists'// 列表插件
import 'tinymce/plugins/wordcount'// 字数统计插件
import 'tinymce/plugins/code'
import 'tinymce/plugins/link'
import 'tinymce/plugins/contextmenu'
import 'tinymce/themes/silver/theme'
import 'tinymce/plugins/colorpicker'
import 'tinymce/plugins/textcolor'

export default {
  components: {
    Editor
  },
  name: 'tinymce',
  props: {
    value: {
      type: String,
      default: ''
    },
    disabled: {
      type: Boolean,
      default: false
    },
    plugins: {
      type: [String, Array],
      default: 'link lists image code table colorpicker textcolor wordcount contextmenu'
    },
    toolbar: {
      type: [String, Array],
      default: 'bold italic underline strikethrough | fontsizeselect | forecolor backcolor | alignleft aligncenter alignright alignjustify | bullist numlist | outdent indent blockquote | undo redo | link unlink image code | removeformat'
    }
  },
  data() {
    return {
      init: {
        language_url: '/tinymce/langs/zh_CN.js',
        language: 'zh_CN',
        skin_url: '/tinymce/skins/ui/oxide',
        // skin_url: 'tinymce/skins/ui/oxide-dark',//暗色系
        height: 400,
        plugins: this.plugins,
        toolbar: this.toolbar,
        branding: false,
        menubar: true,
        // 此处为图片上传处理函数,这个直接用了base64的图片形式上传图片,
        // 如需ajax上传可参考https://www.tiny.cloud/docs/configure/file-image-upload/#images_upload_handler
        images_upload_handler: (blobInfo, success, failure) => {
          const img = 'data:image/jpeg;base64,' + blobInfo.base64()
          success(img)
        }
      },
      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>
<style scoped>

</style>

然后在添加作品的时候,引用组件如下

作品管理-集成富文本编辑器_ico_06

作品管理-集成富文本编辑器_版本号_07

<tinymce ref="editor" v-model="contentVO.description"/>

本博主在使用的时候已发现问题,高版本存在问题,你可以按照我如下的版本号进行锁定,你也可以试着高版本我的版本号如下图

作品管理-集成富文本编辑器_版本号_08

如果修改了版本号需要重新执行一下 ​​npm install​​ 重新安装对应的依赖包


举报

相关推荐

0 条评论