在Web開發中,為了讓用戶可以方便地輸入和格式化文本,我們通常會使用WYSIWYG編輯器。其中,Tinymce 是流行的開源的 WYSIWYG 編輯器。
如果你正在使用 Vue 框架,可以通過 Vue 插件的方式來使用 Tinymce。下面是一些步驟說明:
// 安裝 Tinymce
npm install --save tinymce
// 安裝 Vue 的 Tinymce 插件
npm install --save vue-tinymce
// 導入 Tinymce 組件
import tinymce from 'tinymce/tinymce'
// 導入 Vue-Tinymce 組件
import VueTinymce from 'vue-tinymce'
// 添加 Tinymce 組件到 Vue
Vue.component('tinymce', VueTinymce)
// 在 template 中使用 Tinymce<tinymce v-model="content"></tinymce>// 在 script 中定義 data
data () {
return {
content: ''
}
}
這樣,我們就可以在組件中使用 Tinymce 了,但是默認情況下,Tinymce 并沒有啟用很多常用的插件和設置。下面是一些常見的設置:
<template>
<tinymce :value="value"
:init="init">
</tinymce>
</template>
<script>
export default {
data () {
return {
value: '',
init: {
// 語言
language: 'zh_CN',
// 皮膚
skin: 'oxide',
// 插件
plugins: 'print preview paste importcss searchreplace autolink autosave save directionality code visualblocks visualchars fullscreen image link media template codesample table charmap hr pagebreak nonbreaking anchor toc insertdatetime advlist lists wordcount imagetools textpattern noneditable help charmap emoticons',
// 工具欄
toolbar: 'undo redo | bold italic underline strikethrough | fontsizeselect | forecolor backcolor | alignleft aligncenter alignright alignjustify | numlist bullist outdent indent | link image media | code fullscreen',
// 文件選擇器
file_picker_types: 'image',
file_picker_callback: function(callback, value, meta) {
if (meta.filetype == 'image') {
// 打開文件選擇器
const input = document.createElement('input');
input.setAttribute('type', 'file');
input.setAttribute('accept', 'image/*');
input.onchange = function() {
const file = this.files[0];
const reader = new FileReader();
reader.readAsDataURL(file);
reader.onload = function () {
// 將圖片插入到編輯器中
callback(reader.result, {
alt: ''
});
};
};
input.click();
}
},
}
}
},
}
</script>
其中,語言、皮膚和插件可以通過 CDN 引入,或者直接在本地部署。工具欄可以根據需求來自定義。文件選擇器的回調函數中,我們可以使用原生的 JavaScript 文件選擇器來選擇圖片,然后把選擇的圖片插入到編輯器中。
總之,如果你需要使用 WYSIWYG 編輯器來優化用戶體驗, Tinymce 是一個不錯的選擇。結合 Vue 框架和使用插件的方式,可以更為方便地使用和定制。