React集成tinymce插件

目录

一、Tinymce介绍

二、React集成Tinymce

1、安装@tinymce/tinymce-react组件

2、React中引用

三、如何配置中文语言包

1、下载中文包

2、把语言文件放入tinymce

3、tinymce配置项中配置语言


一、Tinymce介绍

官网:The Most Advanced WYSIWYG Editor | Trusted Rich Text Editor | TinyMCE

中文官网:TinyMCE中文文档中文手册

描述:一个富文本插件,部分插件收费

二、React集成Tinymce

1、安装@tinymce/tinymce-react组件

bash 复制代码
npm install --save @tinymce/tinymce-react

对应版本:

"react": "^18.2.0",

"@tinymce/tinymce-react": "^4.3.0",

2、React中引用

javascript 复制代码
...
import { Editor } from '@tinymce/tinymce-react';
...

const handleEditorChange = (content: any, editor: any) => {
  console.log('Content was updated:', content);
}

const EditorPanel: FC =()=> {
  const editorRef: any = useRef(null);
   return (
     <>
       <Editor
         onInit={(evt, editor) => editorRef.current = editor}
         init={{
           height: '100%',
           menubar: false,
           language: 'zh_CN',
           plugins: [
             'advlist autolink lists link image charmap print preview anchor',
             'searchreplace visualblocks code fullscreen',
             'insertdatetime media table paste code help wordcount'
           ],
           toolbar: 'undo redo | formatselect | ' +
           'bold italic backcolor | alignleft aligncenter ' +
           'alignright alignjustify | bullist numlist outdent indent | ' +
           'removeformat | help',
           content_style: 'body { font-family:Helvetica,Arial,sans-serif; font-size:14px }'
         }}
        onEditorChange={handleEditorChange}
       />
     </>
   );     
  }
export {EditorPanel}

效果如下:

三、如何配置中文语言包

1、下载中文包

下载地址:https://www.tiny.cloud/get-tiny/language-packages/ 选择zh-CN;

压缩包解压缩后会得到一个zh-CN.js的语言文件;

2、把语言文件放入tinymce

把语言文件(zh-CN.js )移入node_modules/tinymce/langs目录下(如果没有langes文件夹,新建一个即可,文件名不可修改)

3、tinymce配置项中配置语言

相关推荐
命运之光21 小时前
【最新】ChromeDriver最新版本下载安装教程,ChromeDriver版本与Chrome不匹配问题
前端·chrome
星离~1 天前
Vue响应式原理详解:从零实现一个迷你Vue
前端·javascript·vue.js
梦6501 天前
React 简介
前端·react.js·前端框架
一只小阿乐1 天前
react 中的判断显示
前端·javascript·vue.js·react.js·react
光影少年1 天前
useMemo 和 React.memo区别
前端·react.js·前端框架
小沐°1 天前
React-页码组件
前端·javascript·react.js
消失的旧时光-19431 天前
Flutter 与 React/Vue 为什么思想一致?——声明式 UI 体系的深度对比(超清晰版)
vue.js·flutter·react.js
零一科技1 天前
Vue3学习第三课: ref 与 reactive 选择指南
前端·vue.js
余杭子曰1 天前
播放状态与播放序列的关系(999篇一线博客第107篇)
前端
e***U8201 天前
前端路由懒加载实现,React.lazy与Suspense
前端·react.js·前端框架