vue2使用tinymce富文本编辑器

1 下载 

(不能下载最新版本否则vue2用不了)

2 移动

在node_modules下找到tinymce文件复制到public的tinymce下 :

tiny.css是我自己创建的,只需要移动icons、models、plugins、skins、themes文件就行

 langs汉化文件需要单独下载

 地址:Language Packages | Trusted Rich Text Editor | TinyMCE

 汉化包下这个: 

3 封装
<template>
    <div class="tinymce-editor">
      <Editor 
        v-model="myValue" 
        :init="init" 
        :disabled="disabled" 
        ref="editorRef" 
        :key="timestamp" 
        @onClick="onClick">
      </Editor>
    </div>
  </template>
  <script>
  import tinymce from 'tinymce/tinymce'
  import Editor from '@tinymce/tinymce-vue'
  import 'tinymce/themes/silver/theme'
  // 列表插件
  import 'tinymce/plugins/lists'
  import 'tinymce/plugins/advlist'
  // 上传图片插件
  import 'tinymce/plugins/image'
  import 'tinymce/plugins/imagetools'
  // 表格插件
  import 'tinymce/plugins/table'
  // 自动识别链接插件
  import 'tinymce/plugins/autolink'
  // 预览插件
  import 'tinymce/plugins/preview'
  export default {
    name: 'TinymceEditor',
    components: {
      Editor
    },
    props: {
      // 传入一个value,使组件支持v-model绑定
      value: {
        type: String,
        default: ''
      },
      disabled: {
        type: Boolean,
        default: false
      },
      menubar: { // 菜单栏      
        type: String,
        default: 'file edit insert view format table'
      },
      // 插件配置
      plugins: {
        type: [String, Array],
        default:
          'lists advlist image imagetools table autolink preview'
      },
      // 工具栏配置
      toolbar: {
        type: [String, Array],
        default:
          'undo redo | formatselect | fontsizeselect | bold italic underline forecolor backcolor | alignleft aligncenter alignright alignjustify | bullist numlist outdent indent | lists image table preview'
      },
      // 富文本高度
      height: {
        type: Number,
        default: 600
      }
    },
    data () {
      return {
        // 当前时间戳,是为了解决回显问题
        timestamp: 0,
        //初始化配置
        init: {
          language_url: '/tinymce/langs/zh-Hans.js', // /可以直接访问到public文件
          language: 'zh-Hans', // 汉化
          skin_url: '/tinymce/skins/ui/oxide',
          height: this.height,
          plugins: this.plugins,
          toolbar: this.toolbar,
          branding: false,
          menubar: false, // 菜单栏是否显示
          content_css:'/tinymce/tiny.css',
        },
        myValue: this.value
      }
    },
    methods: {
      onClick (e) {
        this.$emit('onClick', e, tinymce)
      },

      // 解决切换页签后数据回显问题
      setTinymceContent () {
        setTimeout(() => {
          this.timestamp = new Date().getTime()
        }, 10)
      }
    },
    watch: {
      value: {
        handler (newValue) {
          this.myValue = newValue
        },
        immediate: true
      },
      myValue (newValue) {
        this.$emit('input', newValue)
      }
    }
  }
  </script>
  
4 使用 
<template>
    <div>
        <myTiny v-model="mytiny" ref="tinymceEditorRef"></myTiny>
    </div>
</template>


<script>

export default {
    data() {
        return {
            mytiny: ''
        }
    }
}

</script>

  • 10
    点赞
  • 6
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

檐上踏月客

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值