vuecli3.x中轻松4步带你使⽤tinymce的步骤
前⾔
笔者在使⽤tinymce时发现跟着⽹上的⽅法去做,基本都会因为版本等⼀些问题报错,所以笔者总结了以下⽅案!可以收藏哦
第⼀步:
npm install @tinymce/tinymce-vue@3.2.2 tinymce@5.3.1 -S
第⼆步:
到node_modules中的skins⽂件夹,然后在项⽬中的public下新建tinymce⽂件夹,然后将刚刚到的整个skins⽂件夹拷贝到public的tinymce⽬录下。
接着去官⽹下载语⾔包,解压,将langs⽂件夹拷贝到public的tinymce⽂件夹下(和skins⽂件夹同级)
第三步:
在components⽂件夹下新建tinymce组件的⽂件夹,新建index.vue⽂件,复制以下代码进去:
<template>
<div class="tinymce-editor">
<Editor
:id="editorId"
v-model="editorValue"
:init="editorInit"
editor bar/>
</div>
</template>
<script>
// 引⼊组件
import tinymce from 'tinymce/tinymce';
import Editor from '@tinymce/tinymce-vue';
import 'tinymce/icons/default/icons';
import 'tinymce/themes/silver';
// 引⼊富⽂本编辑器主题的js和css
import 'tinymce/themes/silver/theme.min';
import 'tinymce/skins/ui/oxide/skin.min.css';
// 扩展插件
import 'tinymce/plugins/image';
import 'tinymce/plugins/link';
import 'tinymce/plugins/code';
import 'tinymce/plugins/table';
import 'tinymce/plugins/lists';
import 'tinymce/plugins/wordcount'; // 字数统计插件
import 'tinymce/plugins/media';// 插⼊视频插件
import 'tinymce/plugins/template';// 模板插件
import 'tinymce/plugins/fullscreen';
import 'tinymce/plugins/paste';
import 'tinymce/plugins/preview';
import 'tinymce/plugins/contextmenu';
import 'tinymce/plugins/textcolor';
export default {
name: 'TinymceEditor',
components: {Editor},
props: {
height: {
type: Number,
default: 500
},
id: {
type: String,
default: 'tinymceEditor'
},
value: {
type: String,
default: ''
},
plugins: {
type: [String, Array],
default: 'link lists image code table wordcount media fullscreen preview paste contextmenu textcolor'
},
toolbar: {
type: [String, Array],
default: 'fontselect | bold italic underline strikethrough | link unlink image | undo redo | fontsizeselect | f
orecolor backcolor | alignleft aligncenter alignright alignjustify | bullist numlist | outdent indent blockquote | code | removeformat'
}
},
data() {
return {
editorInit: {
language_url: `${window.baseUrl}/tinymce/langs/zh_CN.js`,
language: 'zh_CN',
skin_url: `${window.baseUrl}/tinymce/skins/ui/oxide`,
content_css: `${window.baseUrl}/tinymce/skins/content/default/content.css`,
height: this.height,
content_style: '* { padding:0; margin:0; } img {max-width:100% !important }',
plugin_preview_width: 375, // 预览宽度
plugin_preview_height: 668,
lineheight_val: "1 1.1 1.2 1.3 1.35 1.4 1.5 1.55 1.6 1.75 1.8 1.9 1.95 2 2.1 2.2 2.3 2.4 2.5 2.6 2.7 2.8 3 3.1 3.2 3.3 3.4 4 5",
fontsize_formats: "8pt 10pt 11pt 12pt 13pt 14pt 15pt 16pt 17pt 18pt 24pt 36pt",
font_formats:"微软雅⿊='微软雅⿊';宋体='宋体';⿊体='⿊体';仿宋='仿宋';楷体='楷体';⾪书='⾪书';幼圆='幼圆';Andale Mono=andale mono,times;Arial=arial,helvetica,sans-serif;Arial Black=arial black,avant garde;Book Antiqua=book antiqua,palatino;Comic Sans M    plugins: this.plugins,
powerpaste_word_import: 'merge',
toolbar: lbar,
paste_data_images: true,
statusbar: true, // 底部的状态栏
menubar: true, // 最上⽅的菜单
branding: false, // ⽔印“Powered by TinyMCE”
images_upload_handler: (blobInfo, success, failure) => {
this.$emit('handleImgUpload', blobInfo, success, failure);
}
},
editorId: this.id,
newValue: ''
};
},
watch: {
newValue(newValue) {
this.$emit('input', newValue);
}
},
mounted() {
tinymce.init({});
},
computed: {
editorValue: {
get() {
return this.value;
},
set(val) {
}
}
},
methods: {
// github/tinymce/tinymce-vue => All available events
clear() {
this.editorValue = '';
}
}
};
</script>
第四步:
在要使⽤的组件中加⼊以下代码:
import TinymceEditor from '@/components/tinymce';
components: { //注册TinymceEditor组件
TinymceEditor
},
data() {
return {
content: '', //富⽂本的内容
baseUrl: window.baseUrl, //默认为'' 空字符串
}
}
computed:{
realHeight() {
return (window.innerHeight || document.documentElement.clientHeight || document.body.clientHeight) - 200
}
}
methods:{
async imgUpload(blobInfo, success, failure) {
const formData = new FormData();
formData.append('file', blobInfo.blob());
try {
const res = await uploadFile(formData);
success(this.server + res);
console.log(this.server + res);
} catch (e) {
console.log(e);
failure('上传失败:' + e);
}
},
}
模板中使⽤:
<tinymce-editor
id="editor"
ref="editor"
v-model="content"
:height="realHeight"
@handleImgUpload="imgUpload"
/>
然后就⼤功告成:
到此这篇关于vuecli3.x中轻松4步带你使⽤tinymce的步骤的⽂章就介绍到这了,更多相关vuecli3.x使⽤tinymce内容请搜索以前的⽂章或继续浏览下⾯的相关⽂章希望⼤家以后多多⽀持!