深入浅出 TinyEditor 富文本编辑器系列之一:TinyEditor 是什么

你好,我是 Kagol,个人公众号:前端开源星球

TinyEditor v4.0 已正式发布,接下来将通过一系列文章介绍 TinyEditor,让大家更好地理解和使用 TinyEditor。

🎉历时1年,TinyEditor v4.0 正式发布!

TinyEditor 是一个基于 Quill 2.0 构建的强大富文本编辑器,通过全面的模块和格式扩展了基础功能。本概述介绍了项目架构、关键特性和结构,帮助初学者开发者了解 TinyEditor 提供的功能以及如何开始使用。

什么是 TinyEditor?

TinyEditor 是一个框架无关的富文本编辑器,通过 30 多个额外的模块和格式增强了 Quill 2.0。它基于 Quill 生态系统,在保持完整 API 兼容性的同时,添加了强大的功能,如高级表格操作、图像处理、协作编辑、AI 集成等。该编辑器设计为与 Vue、React、Angular 及其他 Web 框架无缝协作。

项目架构

项目采用 pnpm workspaces 的 monorepo 结构,按不同关注点组织成独立的包:

核心包

用途 主要内容
fluent-editor 主编辑器库 核心 FluentEditor 类、模块、格式、主题
collaborative-editing-backend 实时协作服务器 WebSocket 服务器、MongoDB 持久化、Yjs 集成
docs 文档和示例 文档站点、演示场、示例
projects 演示应用 Vue 演示、实现示例

关键特性和模块

TinyEditor 通过一套全面的模块和格式扩展了 Quill,使其开箱即用即可投入生产环境:

核心特性

  • 30+ 模块和格式:除了 Quill 的 21 个内置格式,还添加了 15+ 个增强模块,包括表格、图像、链接、计数器、表情符号、文件、剪贴板、提及、快速菜单和截图功能
  • 高级表格操作:插入自定义尺寸表格、拖动行列大小、插入/删除行列、合并/拆分单元格
  • 框架无关:兼容 Vue、React、Angular 和原生 JavaScript
  • 完全 Quill 兼容:与 Quill API 和生态系统模块保持 100% 兼容性

模块架构

编辑器按几个关键模块类别组织:

技术栈

核心依赖

  • Quill 2.0:基础富文本编辑器引擎
  • TypeScript:完整类型安全和开发体验
  • Vite:用于开发和打包的现代构建工具
  • Sass:主题的 CSS 预处理

高级功能支持

  • Yjs:实时协作编辑框架
  • MongoDB:协作的文档持久化
  • WebSocket:实时通信
  • Emoji Mart:表情符号选择和插入
  • Highlight.js:代码语法高亮
  • MathLive:LaTeX 数学公式支持

快速开始

体验 TinyEditor 最快的方式是通过开发环境:

  1. 克隆和安装:
bash 复制代码
git clone git@github.com:opentiny/tiny-editor.git
cd tiny-editor
pnpm i
  1. 启动开发:
bash 复制代码
pnpm dev
  1. 查看示例:访问 http://localhost:5173/tiny-editor/

生产环境使用,请安装包:

bash 复制代码
npm i @opentiny/fluent-editor

项目结构深入解析

源码组织

主编辑器源码结构如下:

  • src/core/:扩展 Quill 的核心 FluentEditor 类
  • src/modules/:所有功能模块(工具栏、剪贴板、AI 等)
  • src/formats/:自定义内容格式和 blot
  • src/attributors/:样式和属性定义
  • src/themes/:视觉主题实现
  • src/config/:配置类型和国际化

模块注册系统

TinyEditor 使用复杂的模块注册系统,支持轻松扩展和定制。所有模块在主入口点注册,具有覆盖能力,使开发者能够自定义或替换任何组件。

模块化设计和全面的功能集使 TinyEditor 适用于从简单内容编辑到复杂协作应用的各种场景。项目对 Quill 兼容性的承诺确保你可以利用整个 Quill 生态系统,同时享受 TinyEditor 的增强功能。

后续将全面介绍 TinyEditor 如何使用、设计架构、实现原理、二次开发等内容,点个关注,不迷路。

联系我们

GitHub:github.com/opentiny/ti...(欢迎 Star ⭐)

官网:opentiny.github.io/tiny-editor

个人博客:kagol.github.io/blogs/

小助手微信:opentiny-official

公众号:OpenTiny

相关推荐
不务正业的前端学徒17 小时前
手写简单的call bind apply
前端
jump_jump17 小时前
Ripple:一个现代的响应式 UI 框架
前端·javascript·前端框架
用户9047066835717 小时前
Nuxt css 如何写?
前端
夏天想17 小时前
element-plus的输入数字组件el-input-number 显示了 加减按钮(+ -) 和 小三角箭头(上下箭头),怎么去掉+,-或者箭头
前端·javascript·vue.js
0思必得017 小时前
[Web自动化] Selenium基础介绍
前端·python·selenium·自动化·web自动化
Filotimo_17 小时前
前端.d.ts文件作用
前端
进击的野人17 小时前
Vue 3 响应式数据解构:toRef 与 toRefs 的深度解析
前端·vue.js·前端框架
ohyeah17 小时前
CSS 作用域隔离实战:React、Vue 与 Styled Components 的三种范式
前端
二哈喇子!17 小时前
前端HTML、CSS、JS、VUE 汇总
开发语言·前端