深入浅出 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

相关推荐
天蓝色的鱼鱼20 分钟前
关于 CSS 你可能不知道的属性,但关键时刻很有用
前端·css
泯泷1 小时前
第 2 篇:设计第一套字节码:Opcode、Instruction 与 Constant Pool
前端·javascript·安全
妙码生花1 小时前
从 PHP 到 AI + Golang,程序员自救转型手记(十五):优化细节、网络请求封装
前端·后端·ai编程
泯泷1 小时前
第 1 篇:从 1 + 2 开始:亲手写出第一台 JSVM
前端·javascript·安全
团团崽_七分甜1 小时前
Spring Boot 核心知识点总结
前端
ZzT2 小时前
在 GitHub 上 @一下 claude,它自己把 issue 改成 PR
人工智能·开源
lichenyang4532 小时前
从一个按钮开始,理解 ASCF 框架到底在做什么
前端
古夕2 小时前
第三方 SSO 接入实践:redirect_uri 编码、回调一致性与跨项目联调
前端·vue.js
朦胧之2 小时前
页面白屏卡住排查方法
前端·javascript
用户593608741402 小时前
Playwright 黑魔法:用 ClipboardEvent 绕过 React 富文本编辑器
前端