首页 > 其他分享 >VUE 3.0使用Tinymce编辑器

VUE 3.0使用Tinymce编辑器

时间:2023-09-26 16:48:06浏览次数:65  
标签:插件 VUE Tinymce tinymce content vue 3.0 plugins import

本人使用的IDEA开发工具

参考文档:

1.官方文档
2.中文文档

一、使用npm安装Tinymce。我这里是指定了版本号的

npm install [email protected]

npm install @tinymce/[email protected]

二、修改路径,加汉化

1、将下载好的tinymce,从node_modules复制到public文件夹里

 

 

 2、汉化(加中文语言包)

 在 tinymce 中新增:langs 文件夹,并将从官网下载的zh-Hans.js文件放入其中。

zh-Hans.js下载地址

 

3、修改 tinymce-vue中的引用路径

原引用地址为:“https://cdn.tiny.cloud/1/”.concat(apiKey, “/tinymce/”).concat(channel, “/tinymce.min.js”)

本地地址:locolhost:8080/tinymce/tinymce.min.js

可替代为:window.location.origin.concat(‘/tinymce/tinymce.min.js’)

找到 node_modules 文件夹中的 @tinymce,我们需要修改这四个文件中的地址

语言包的使用方法

return {

init {

language_url: "/tinymce/langs/zh-Hans.js", language: "zh-Hans"

}

}

4.在Vue里面使用

①在components 目录下新建 Editor.vue 将下面代码复制进去

<template>
<editor v-model="content" :init="init" tag-name="div" />
</template>
<script setup>
import tinymce from 'tinymce/tinymce'
import Editor from '@tinymce/tinymce-vue'
import { ref, watch } from 'vue'
import 'tinymce/themes/silver/theme' // 引用主题文件
import 'tinymce/icons/default' // 引用图标文件
import 'tinymce/models/dom'
// tinymce插件可按自己的需要进行导入
// 更多插件参考:https://www.tiny.cloud/docs/plugins/
import 'tinymce/plugins/advlist'
import 'tinymce/plugins/anchor'
import 'tinymce/plugins/autolink'
import 'tinymce/plugins/autoresize'
import 'tinymce/plugins/autosave'
import 'tinymce/plugins/charmap' // 特殊字符
import 'tinymce/plugins/code' // 查看源码
import 'tinymce/plugins/codesample' // 插入代码
import 'tinymce/plugins/directionality'
import 'tinymce/plugins/emoticons'
import 'tinymce/plugins/fullscreen' //全屏
import 'tinymce/plugins/help'
import 'tinymce/plugins/image' // 插入上传图片插件
import 'tinymce/plugins/importcss' //图片工具
import 'tinymce/plugins/insertdatetime' //时间插入
import 'tinymce/plugins/link'
import 'tinymce/plugins/lists' // 列表插件
import 'tinymce/plugins/media' // 插入视频插件
import 'tinymce/plugins/nonbreaking'
import 'tinymce/plugins/pagebreak' //分页
import 'tinymce/plugins/preview' // 预览
import 'tinymce/plugins/quickbars'
import 'tinymce/plugins/save' // 保存
import 'tinymce/plugins/searchreplace' //查询替换
import 'tinymce/plugins/table' // 插入表格插件
import 'tinymce/plugins/template' //插入模板
import 'tinymce/plugins/visualblocks'
import 'tinymce/plugins/visualchars'
import 'tinymce/plugins/wordcount' // 字数统计插件
// v-model
const props = defineProps({
modelValue: {
type: String,
default: '',
},
})
const emit = defineEmits(['update:modelValue'])
// 配置
const init = {
language_url: '/tinymce/langs/zh-Hans.js', // 中文语言包路径
language: 'zh-Hans',
skin_url: '/tinymce/skins/ui/oxide', // 编辑器皮肤样式
content_css: '/tinymce/skins/content/default/content.min.css',
menubar: false, // 隐藏菜单栏
autoresize_bottom_margin: 50,
max_height: 500,
min_height: 450,
// height: 320,
toolbar_mode: 'none',
plugins:
'wordcount visualchars visualblocks template searchreplace save quickbars preview pagebreak nonbreaking media insertdatetime importcss image help fullscreen directionality codesample code charmap link code table lists advlist anchor autolink autoresize autosave',
toolbar:
'formats undo redo fontsizeselect fontselect ltr rtl searchreplace media | outdent indent aligncenter alignleft alignright alignjustify lineheight underline quicklink h2 h3 blockquote numlist bullist table removeformat forecolor backcolor bold italic strikethrough hr link preview fullscreen help ',
content_style: 'p {margin: 5px 0; font-size: 14px}',
fontsize_formats: '12px 14px 16px 18px 24px 36px 48px 56px 72px',
font_formats:
'微软雅黑=Microsoft YaHei,Helvetica Neue,PingFang SC,sans-serif;苹果苹方= PingFang SC, Microsoft YaHei, sans- serif; 宋体 = simsun, serif; 仿宋体 = FangSong, serif; 黑体 = SimHei, sans - serif; Arial = arial, helvetica, sans - serif;Arial Black = arial black, avant garde;Book Antiqua = book antiqua, palatino; ',
branding: false,
elementpath: false,
resize: false, // 禁止改变大小
statusbar: false, // 隐藏底部状态栏
}
tinymce.init // 初始化
const content = ref(props.modelValue)
watch(props, (newVal) => (content.value = newVal.modelValue))
watch(content, (newVal) => emit('update:modelValue', newVal))
</script>
<style scoped>
.tox-tinymce-aux {
z-index: 9999 !important;
}
</style>

② app.vue中代码,引入组件 Editor.vue

<template>
    <Editor v-model="content" />
</template>
 
 
 
<script setup>
import { ref } from "vue"
import Editor from "/src/components/Editor.vue"
const form = ref({
    content: ''
})
</script>

如果是类似这种弹框的编辑时,在关闭弹框的时候,清空文本框内的内容,比如我下面的vue代码

 

 state.form.remarks = {}

标签:插件,VUE,Tinymce,tinymce,content,vue,3.0,plugins,import
From: https://www.cnblogs.com/LoveQin/p/17730407.html

相关文章

  • vue~封装一个文本框标签组件
    用到的技术父组件向子组件的传值类型检查和默认值:您可以为props指定类型检查和默认值。这可以确保传递给子组件的数据符合期望的类型,以及在没有传递数据时具有合理的默认值。例如:props:{message:{type:String,default:'DefaultMessage'},count:{......
  • 【vue2】实现数字纵向滚动效果(计时器效果)
    需求:在页面中显示一个数字,并在进入视口时显示计时器滚动效果: 效果如上↑ 新建组件ScrollNumber.vue:<template><divstyle="display:inline-flex;justify-content:flex-start;align-items:center;"><divv-for="(item......
  • VUE~~vue-grid-layout
    1.vue2版本yarnaddvue-grid-layoutimport{GridLayout,GridItem}from"vue-grid-layout";2.vue3版本[email protected]'vue-grid-layout';app.use(VueGridLayout);......
  • vue3 模糊搜索 不区分大小写 多选框 element plus
    ```javascript<divclass="select-part"ref="selectRef"><divclass="check-type"><inputtype="text"class="check-type-title":placeholder="placeholder"@focus="onFo......
  • Vue3 组件基础:轻松掌握前端开发新技能!
    基本实例这里有一个Vue组件的示例://创建一个Vue应用constapp=Vue.createApp({})//定义一个名为button-counter的新全局组件app.component('button-counter',{data(){return{count:0}},template:`<button@click="count++">......
  • Vue3-vite 按需引入Element-plus
    1.下载unplugin-vue-components,unplugin-auto-import包npmi-Dunplugin-vue-componentsunplugin-auto-import2.vite.config.js文件中配置1importAutoImportfrom'unplugin-auto-import/vite'2importComponentsfrom'unplugin-vue-components/vite�......
  • 关于 TDengine 3.0 数据订阅,你需要知道这些
    小T导读:为了帮助应用实时获取写入时序数据库(TimeSeriesDatabase)TDengine的数据,或者以事件到达顺序处理数据,TDengine提供了类似消息队列产品的数据订阅、消费接口。这样在很多场景下,采用TDengine的时序数据处理系统就不需要再集成如Kafka一般的消息队列产品,从而简化系统设......
  • 基于vue.js的社区健康服务管理系统-计算机毕业设计源码+LW文档
    摘要:本社区健康服务管理系统是针对目前社区健康服务管理的实际需求,从实际工作出发,对过去的社区健康服务管理系统存在的问题进行分析,完善用户的使用体会。采用计算机系统来管理信息,取代人工管理模式,查询便利,信息准确率高,节省了开支,提高了工作的效率。本系统结合计算机系统的结构、......
  • vue npm 视频播放 项目中感觉比较好用的包
    npm@easydarwin/easyplayer对H265H264支持都比较友好!!实测比较好用<!DOCTYPEhtml><htmllang=""><head><metacharset="utf-8"><metahttp-equiv="X-UA-Compatible"content="IE=edge"><......
  • vue中没有index.html 如何可以加上
    在Vue项目中,如果没有默认的index.html文件,你可以手动创建一个并进行设置。以下是创建并配置index.html的步骤:在你的Vue项目根目录下创建一个新的public文件夹(如果还没有)。在public文件夹下创建一个新的index.html文件。在index.html文件中添加基本的HTML结构和必要的标......