vue中使用tinymce富文本编辑器

news2024/11/25 2:38:41

之前都是用的quill富文本,但是因为要实现添加表格的功能,quill没有tinymce强大,所以改用了tinymce。当时也是百度了一堆的教程可是没有记录下来,现在发现有的细节忘记了,所以这个文章可能会有错误 。

当时看了好几个安装教程,具体哪个忘记了,感觉像是照着这个教程

参考教程:tinymce富文本编辑器(vue)_天高任鸟飞dyz的博客-CSDN博客_富文本编辑器

tinymce文档参考手册: TinyMCE中文文档中文手册

1、安装(vue 2.X)

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

 我安装是下面这两个版本

 

安装之后,在 node_modules 中找到 tinymce/skins 目录,然后将 skins 目录拷贝到 static 目录下

到官网Language Packages | Trusted Rich Text Editor | TinyMCE下载中文语言包 ,找到对应得tinymce版本。

在刚才创建的static/tinymce文件夹下新建langs文件夹,用来存放下载的中文语言包

2、封装成子组件index.vue

<template>
  <!-- 富文本 -->
  <div style="margin-bottom:10px">
    <editor v-model="content" :init="init" :disabled="disabled"></editor>
  </div>
</template>


<script>
import tinymce from 'tinymce/tinymce';
import Editor from '@tinymce/tinymce-vue';
import 'tinymce/themes/silver/theme';
import "tinymce/icons/default/icons";
import 'tinymce/plugins/link';
import 'tinymce/plugins/code';
import 'tinymce/plugins/table';
import 'tinymce/plugins/lists';
import 'tinymce/plugins/contextmenu';
import 'tinymce/plugins/wordcount';
import 'tinymce/plugins/colorpicker';
import 'tinymce/plugins/textcolor';
import 'tinymce/plugins/charmap';
// 扩展插件
// import "../assets/tinymce/plugins/lineheight/plugin";
// import "../assets/tinymce/plugins/bdmap/plugin";


export default {
  components: {
    Editor
  },
  props: {
    value: {
      type: String,
      default: ""
    },
    disabled: {
      type: Boolean,
      default: false
    },
    plugins: {
      type: [String, Array],
      default:
        "image media table link code table lists wordcount"
    },
    toolbar: {
      type: [String, Array],
      default:
        " bold italic subscript superscript forecolor fontsizeselect fontselect  alignleft aligncenter alignright alignjustify  bullist numlist outdent indent lists  removeformat table "
    }
  },
  data() {
    return {
      //初始化配置
      init: {
        language_url: "/static/tinymce/langs/zh_CN.js",
        language: "zh_CN",
        skin_url: "/static/tinymce/skins/ui/oxide",
        // content_css: '/static/tinymce/skins/content/document/content.css',//设置编辑器中可编辑区域内的样式
        height: 300,
        min_height: 300,
        max_height: 300,
        object_resizing: false, //禁用表格内联样式拖拽拉伸
        table_resize_bars: false,//禁用表格单元格拖拽拉伸
        menubar: false,//菜单栏
        toolbar_mode: "wrap",
        plugins: this.plugins,
        toolbar: this.toolbar,
        content_style: "p {margin: 10px;}",//内容样式
        fontsize_formats: "12px 14px 16px 18px 24px 36px 48px 56px 72px",
        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 MS=comic sans ms,sans-serif;Courier New=courier new,courier;Georgia=georgia,palatino;Helvetica=helvetica;Impact=impact,chicago;Symbol=symbol;Tahoma=tahoma,arial,helvetica,sans-serif;Terminal=terminal,monaco;Times New Roman=times new roman,times;Trebuchet MS=trebuchet ms,geneva;Verdana=verdana,geneva;Webdings=webdings;Wingdings=wingdings",
        branding: false,//不显示富文本支持方
        // contextmenu: "undo redo | cut copy paste pastetext | selectall table", // 富文本右键菜单
      },
      content: this.value
    };
  },
  mounted() {
    tinymce.init({});
  },
  methods: {

  },
  watch: {
    value(newValue) {
      this.content = newValue;
    },
    content(newValue) {
      this.$emit("input", newValue);
    }
  }
};
</script>
<style>
/* 组件在dialog或者drawer中被遮挡 */
/* 富文本菜单 */
.tox-tinymce-aux {
  z-index: 9999 !important;
}
.tox-tinymce {
  border-radius: 0 !important;
}
</style>

 3、在父组件中引用

<editor-tinymce v-model="item.content"></editor-tinymce>

import EditorTinymce from "@/components/TinymceEditor/index.vue";

export default {
  components: {
    EditorTinymce
  },
}

4、页面效果 

 

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/116447.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

全球智能网联汽车出货量预计

IDC 于 2020 年最新发布的《全球智能网 联汽车预测报告&#xff08;2020-2024&#xff09;》数据显示&#xff0c;尽管受新冠肺炎疫情冲击&#xff0c;2020 年全球智能网联汽车出货量预计较上一年下滑 10.6%&#xff0c;约为 4440 万辆&#xff0c;但到 2024 年全球智能网联汽车…

数据可视化之excel和finebi报表实现对比

当我们拿到数据&#xff0c;想对数据实现可视化报表设计。第一步就是要了解什么是数据可视化分析&#xff0c;且数据可视化分析的方法有什么&#xff1f;而且当我们拿到excel表格的数据&#xff0c;第一个想法是excel表格自身实现报表数据可视化&#xff0c;除了用excel本身实现…

JMeter

Apache JMeter—压力测试工具 一.什么是Apache JMeter Apache JMeter 是 Apache 组织基于 Java 开发的压力测试工具&#xff0c;用于对软件做压力测试。 JMeter 最初被设计用于 Web 应用测试&#xff0c;但后来扩展到了其他测试领域&#xff0c;可用于测试静态和动态资源&am…

Linux-redis 集群配置

1、redis主从复制(Master/Slave) a、集群结构 三个节点&#xff1a;一个主节点&#xff0c;二个从节点 b、准备实例和配置 在虚拟机开启3个redis 实例&#xff0c;来模拟主从集群模式&#xff0c;信息如下&#xff1a; ippost角色192.168.150.1017001master192.168.150.101…

服务器硬件规格常用查看命令——HCA卡相关命令

使用不同厂商的InfiniBand设备&#xff0c;可能需要到不同厂商的官网下载相应的工具包&#xff0c; Matrox的HCA卡操作命令由infiniband-diags-1.6.5.MLNX20150902.0e83419-0.1.x86_64工具 包提供。由于这类工具的功能与厂商有关&#xff0c;且是针对特定设备的&#xff0c;所以…

融云CEO董晗:国产化进程加速,助推政企数智办公平台深化发展

政策催化加疫情助推下&#xff0c;办公线上化迅速完成着市场教育已经成为当前的主流趋势。而随着“国产化”成为各行业数字化发展道路上的关键词&#xff0c;政企办公领域国产替代的发展确定性更加凸显。关注【融云全球互联网通信云】了解更多 近期&#xff0c;融云与艾瑞咨询…

SpringBoot基础篇和运维篇

目录 parent starter 引导类 ​编辑 辅助功能 REST开发 REST简介 入门案例&#xff1a; 1、设置http请求方式​编辑 2、设置请求参数 知识点&#xff1a; 1&#xff0c;RequestMapping 2、PathVariable注解 3、三个有关页面请求参数的注解 4、REST风格的注解简化&…

基于数字孪生技术在水电站的探索应用

数字孪生技术作为一种新的技术趋势&#xff0c;日益被千行百业产业所重视。那么&#xff0c;是否可以使用数字孪生技术来构建一个数字孪生水电站&#xff1f;让传统的水电行业也能把握住最新的数字技术的发展趋势&#xff0c;促进水电事业的发展呢。 基于数字孪生技术在水电站 …

三、解构赋值、函数默认值、数组解构、对象解构

三、解构赋值、函数默认值、数组解构、对象解构 函数传参为undefined/不传值&#xff0c;解构赋值时值为undefined/不传值时&#xff0c;都可以去取自己定义的默认值。 一、函数默认值 1.1 函数默认值 ES5语法函数参数赋默认值 function foo(a, b){var a typeof(argument…

11.Linux文件管理命令---diff比较两个文件

11.Linux文件管理命令—diff比较两个文件 文章目录diff比较两个文件练习案例diff比较两个文件 作用&#xff1a;找出两个文件的不同点。 用法&#xff1a;diff [选项] 源文件 目标文件 主要选项如下。 下面是 GNU 所接受的 diff 所有选项的概要。大多数选项有两个相同的名字&…

单机模拟集群(三主两从)

引言 操作系统环境&#xff1a;Ubuntu 20.04 Redis版本&#xff1a;6.2.8 准备工作 如果已经安装过了&#xff0c;找到自己的安装路径。如果没有安装过&#xff0c;去官网下载 当前最新版本是7.0&#xff0c;我这里用的是6.0&#xff0c;下载 redis-6.2.8.tar.gz&#xff0c…

CAPL学习之路-测试功能集函数(测试报告部分)

测试功能集函数用于测试用例的实现,主要使用场景在test module和test unit模块的capl中 。所以千万不要在网络节点的CAPL脚本中使用,不然会报错。比如TestWaitForTimeout()函数,等待指定的时间 在网络节点的capl脚本中使用时会报错: 在test module节点的capl脚本中使用时正…

SpreadJS集算表联动数据透视表,高效实现前端数据多维分析

在做一些财务、供应链、资产管理等系统时&#xff0c;由于业务人员线下都是采用Excel来完成的&#xff0c;因此就需要将Excel中业务人员使用的功能都能在Web端系统实现&#xff0c;整体上的实现方案有三种&#xff1a; 完全自研一套具备Excel功能的组件&#xff1b;使用成品软…

Linux-tar打包与解压命令

tar命令位于/bin目录下&#xff0c;它能够将用户所指定的文件或目录打包成一个文件&#xff0c;但不做压缩。一般Linux上常用的压缩方式是选用tar将许多文件打包成一个文件&#xff0c;再以gzip压缩命令压缩成xxx.tar.gz(或称为xxx.tgz)的文件。 常用参数&#xff1a; -c&a…

布隆过滤器【美与不美之谈】

什么是布隆过滤器 布隆过滤器其实本质上来讲就是一种巧妙的数据结构&#xff0c;特点就是高效的插入和查询。 它能告诉我们&#xff1a;什么一定不存在&#xff0c;或者什么可能会存在 总结&#xff1a;布隆过滤器是概率性的。它只能告诉我们什么一定不存在&#xff0c;或者…

科技向“实”万物生长,2023年云计算五大技术趋势展望

科技云报道原创。 近日&#xff0c;全球最大的专业技术组织IEEE(电气电子工程师学会)发布了《IEEE全球调研&#xff1a;科技在2023年及未来的影响》。根据相关调研显示&#xff0c;云计算(40%)、5G(38%)、元宇宙(37%)将成为影响2023年最重要的技术&#xff0c;其中云计算位居首…

算法---模拟(2)

目录 一、模拟算法题目 &#xff08;1&#xff09;神奇的幻方 &#xff08;2&#xff09;Proceting the Flower &#xff08;3&#xff09;排座椅 &#xff08;4&#xff09;国王的游戏 &#xff08;5&#xff09;字典序最大的子序列 一、模拟算法题目 &#xff08;1&…

Spring源码下载

一、Spring | Home 二、Projects->Spring Framework 三、点击小猫图片进入Spring Framework的代码仓 四、选择感兴趣的分支

如何实现高性能点赞(二)

1.3 Redis 的数据结构类型 Redis 可以存储键与5种不同数据结构类型之间的映射&#xff0c;这5种数据结构类型分别为String&#xff08;字符串&#xff09;、List&#xff08;列表&#xff09;、Set&#xff08;集合&#xff09;、Hash&#xff08;散列&#xff09;和 Zset&…

Mac M2芯 超详细k8s集群实战 - kubeadm

概述 我们准备搭建kubeadm的masterworker集群&#xff0c;实现k8s集群&#xff0c;master、worker在虚拟机上来执行&#xff0c;中间遇到了超级多的坑&#xff0c;都搞定了之后&#xff0c;在这里系统的总结一下&#xff0c;这也是一篇学习笔记。 这篇比较难搞&#xff0c;如…