网站首页 > 基础教程 正文
大家好,很高兴又见面了,我是"高级前端?进阶?",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。
1. 什么是 TinyMCE
TinyMCE 是世界排名第一的开源富文本编辑器。
TinyMCE 也是世界上最可定制、可扩展且灵活的富文本编辑器,受到数百万开发人员的使用和信赖,同时推出了 Atlassian、Medium、Evernote 等产品,帮助开发者为用户创造卓越的内容和体验。
TinyMCE 每年的下载量超过 3.5 亿次,也是互联网上最值得信赖的企业级开源 HTML 编辑器之一。 目前全球有超过 1 亿多个由 Tiny 提供支持的产品。 作为一款高性能的所见即所得编辑器,TinyMCE 专为扩展而设计,旨在创新,并不断完善特殊边界情况。
开发者可以在 TinyMCE 网站文档中访问 TinyMCE 的全功能演示。同时,官方建议升级到 TinyMCE 7 以继续接收安全更新,或者如果需要更多时间升级,请考虑 TinyMCE 5 LTS。
2.TinyMCE 有什么特色
2.1 轻松集成
借助以下组件,TinyMCE 可以轻松集成到当前项目中:
- tinymce-react
- tinymce-vue
- tinymce-angular
目前 TinyMCE 拥有超过 29 个集成和 400 多个 API,请参阅 TinyMCE 文档以获取编辑器集成的完整列表,包括:使用 Tiny Cloud、包管理器或自托管下载安装 TinyMCE 的各种安装和集成选项。支持 React、Angular、Vue.js、Blazor、Svelte、Web Component、Java Swing、jQuery、Bootstrap、Django、Node.js + Express、Laravel、Ruby on Rails、Wordpress 等等。
2.2 高可定制
开发者可以轻松配置富文本编辑器的 UI 以匹配当前网站、产品或应用程序的设计。 由于其灵活性,开发者还可以根据需要为编辑器配置任意数量的功能。
配置 UI 非常简单,比如:
tinymce.init({
selector: 'textarea',
// 根据页面 HTML 配置
skin: 'oxide-dark',
content_css: 'dark'
// skin 皮肤配置
});
tinymce 还支持将 skin 版本基于用户操作系统中指定的首选项,比如下面例子:
tinymce.init({
selector: 'textarea',
// change this value according to your HTML
skin: (window.matchMedia('(prefers-color-scheme: dark)').matches ? 'oxide-dark' : 'oxide'),
content_css: (window.matchMedia('(prefers-color-scheme: dark)').matches ? 'dark' : 'default')
});
凭借 50 多个强大的插件,以及作为 TinyMCE 基础的可编辑内容,添加附加功能就像添加一行代码一样简单。只需要几行代码即可实现大多数插件的全部功能。
比如,以下示例启用列表(lists)、高级列表(advlist)、链接(link)和图像(image)插件。
tinymce.init({
selector: 'textarea',
// change this value according to your HTML
plugins: 'advlist link image lists'
});
2.3 可扩展性
有时,编辑器要求可能非常独特,例如:需要自由和灵活性来进行创新。 由于 TinyMCE 是开源的,开发者可以查看源代码并开发自己的自定义功能扩展,以满足自己的需求。
TinyMCE API 的公开使开发者可以更轻松地编写适合 TinyMCE UI 组件现有框架的自定义功能。比如常见的 API:
- add(editor: tinymce.Editor): tinymce.Editor:将编辑器实例添加到编辑器集合中,并将其设置为活动编辑器。
- addI18n():添加语言包,由加载的语言文件(如 en.js)调用。
- createEditor():创建一个编辑器实例并将其添加到 EditorManager 集合中
- execCommand(cmd: String, ui: Boolean, value: Object | String | Number | Boolean): Boolean:在当前活动编辑器上执行特定命令
- get(id: String | Number): tinymce.Editor | Array:返回给定 id 的编辑器实例
- triggerSave():对集合中的所有编辑器实例调用 save 方法,当要提交表单时这会很有用。
对于需要根据企业级标准构建更深入的效率、合规性或协作功能的专业软件团队,开发者还可以与官方团队联系。
Tiny 还为专业开发团队提供专门的 SLA 和支持。
3.TinyMCE 基础用法
TinyMCE 的使用非常简单,假如有以下 HTML 页面结构:
<textarea id="basic-example">
<p><img style="display: block; margin-left: auto; margin-right: auto;" title="Tiny Logo" src="https://www.tiny.cloud/docs/images/logos/android-chrome-256x256.png" alt="TinyMCE Logo" width="128" height="128"></p>
<h2 style="text-align: center;">Welcome to the TinyMCE editor demo!</h2>
<h2>A simple table to play with</h2>
<h2>Found a bug?</h2>
<p>
Don't forget to check out our other product <a href="http://www.plupload.com"target="_blank">Plupload</a>, your ultimate upload solution featuring HTML5 upload support.
</p>
<p>
Thanks for supporting TinyMCE! We hope it helps you and your users create great content.<br>All the best from the TinyMCE team.
</p>
</textarea>
可以快速通过下面的 JS 实例化编辑器脚本,其中 plugins 指定了编辑器的插件列表,而 toolbar 指定了导航栏的基本功能。
tinymce.init({
selector: 'textarea#basic-example',
height: 500,
plugins: [
'advlist', 'autolink', 'lists', 'link', 'image', 'charmap', 'preview',
'anchor', 'searchreplace', 'visualblocks', 'code', 'fullscreen',
'insertdatetime', 'media', 'table', 'help', 'wordcount'
],
toolbar: 'undo redo | blocks |' +
'bold italic backcolor | alignleft aligncenter' +
'alignright alignjustify | bullist numlist outdent indent |' +
'removeformat | help',
content_style: 'body {font-family:Helvetica,Arial,sans-serif; font-size:16px}'
});
更多关于 tinymce 的用法可以参考文末资料,本文不再过多展开。
参考资料
https://github.com/tinymce/tinymce
https://www.tiny.cloud/docs/tinymce/6/installation/
https://www.tiny.cloud/docs/tinymce/6/customize-ui/
https://www.tiny.cloud/docs/tinymce/6/apis/tinymce.root/
猜你喜欢
- 2024-12-20 一个慢SQL引起的惨案 一个慢sql,如何将其优化
- 2024-12-20 knockout+echarts实现图表展示 基于echarts的数据可视化源码
- 2024-12-20 在C++中调用Python c++调用python numpy
- 2024-12-20 大厂二面让我谈谈Vue.js框架,我慌了,我不知道啊
- 2024-12-20 记好这24个ES6方法,用于解决实际开发的JS问题
- 2024-12-20 Backbone前端框架解读 前端框架底层原理
- 2024-12-20 自己实现一个javascript事件模块 js事件模型及处理机制
- 2024-12-20 前端小伙伴,axios 是如何封装 HTTP 请求的?(看完会了吗)
- 2024-12-20 Kendo UI Professional Q3 2015 Beta发布
- 2024-12-20 最佳设计:A-Frame,阅读进度指示器,Colorify.js,交互式讲故事
- 最近发表
- 标签列表
-
- gitpush (61)
- pythonif (68)
- location.href (57)
- tail-f (57)
- pythonifelse (59)
- deletesql (62)
- c++模板 (62)
- css3动画 (57)
- c#event (59)
- linuxgzip (68)
- 字符串连接 (73)
- nginx配置文件详解 (61)
- html标签 (69)
- c++初始化列表 (64)
- exec命令 (59)
- canvasfilltext (58)
- mysqlinnodbmyisam区别 (63)
- arraylistadd (66)
- node教程 (59)
- console.table (62)
- c++time_t (58)
- phpcookie (58)
- mysqldatesub函数 (63)
- window10java环境变量设置 (66)
- c++虚函数和纯虚函数的区别 (66)