网站首页 > 技术文章 正文
大家好,很高兴又见面了,我是"高级前端?进阶?",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发,您的支持是我不断创作的动力。
什么是 Rooster
Rooster is a framework-independent JavaScript rich-text editor neatly nested inside one HTML <div> element. Editing operations performed by end users are handled in simple ways to generate the final HTML.
Rooster 是一个独立于框架的 JavaScript 富文本编辑器,用于嵌套在一个 HTML元素中。最终用户执行的编辑操作以简单的方式处理并生成最终的 HTML。
Rooster 在名为 “内容模型” 的中间层数据结构之上工作。所有格式 API 和编辑操作都使用此内容模型层作为内容格式,最后转换为 HTML 并在编辑器中显示。Rooster 包含 6 个基本包:
- roosterjs:为想要快速入门的用户提供所有 Rooster 代码的外观。开发者可以使用 roosterjs 中的 createEditor() 函数创建具有默认配置的编辑器。
- roosterjs-content-model-core:定义核心编辑器和插件基础结构。使用 roosterjs-content-model-core 而不是 roosterjs 来构建和自定义自己的编辑器。
- roosterjs-content-model-api:定义编辑器操作的 API。使用这些 API 修改使用 roosterjs-content-model-core 构建的编辑器中的内容和格式。
- roosterjs-content-model-dom:定义内容模型和 DOM 操作的 API。此包在 DOM 树和 roosterjs 内容模型之间进行转换。
- roosterjs-content-model-plugins:定义常用功能的基本插件。
- roosterjs-content-model-types:定义公共接口和枚举,包括内容模型类型、API 参数和其他类型。
目前 Rooster 在 GIthub 通过 MIT 协议开源,短短时间内已经有超过 1k 的 star、是一个值得关注的前端开源项目。
如何使用 Rooster
首先需要安装相应的依赖:
yarn add roosterjs
// 安装主包
yarn add roosterjs-content-model-core
yarn add roosterjs-content-model-api
// 安装子包
yarn add webpack -g
// 安装 webpack
Rooster 的使用非常简单,比如下面的示例:
import {Editor} from 'roosterjs-content-model-core';
const editor = new Editor(div, {
defaultSegmentFormat: {
fontSize: '10pt',
},
plugins: [new MyPlugin(), ...],
initialModel: {
}
});
Rooster 还支持插件,开发者可以使用内置插件或自行构建插件,插件调用 API 与编辑器进行通信。当用户执行操作或通过代码更改内容时,编辑器将触发事件以供插件处理。
// 在编辑器中键入 “a” 时,将显示 “Hello Rooster” 对话框
class HelloRooster implements EditorPlugin {
getName() {
return 'HelloRooster';
}
initialize(editor: IEditor) {}
dispose() {}
onPluginEvent(e: PluginEvent) {
// 判断按键的 code 是否是 65
if (e.eventType == 'input' && e.rawEvent.which == 65) {
alert('Hello Rooster');
}
}
}
开发者还可以调用 dispose(); 来销毁实例,一旦编辑器被释放,就无法重新启用同一个编辑器对象。但开发者可以再次使用同一个内容 DIV 调用 createEditor() 或 new Editor() 来使其可编辑,从而能够在可编辑模式和不可编辑模式之间切换内容 DIV。例如:
class EditorWrapper {
private editor: Editor;
constructor(
private contentDiv: HTMLDivElement,
private plugins: EditorPlugin[]
) {
this.enableEditing();
}
public enableEditing() {
if (!this.editor) {
this.editor = createEditor(this.contentDiv, this.plugins);
}
}
public disableEditing() {
if (this.editor) {
this.editor.dispose();
this.editor = null;
}
}
}
更多关于Rooster的用法和示例可以参考文末资料,本文不再过多展开。
参考资料
https://github.com/Microsoft/roosterjs
https://github.com/Microsoft/roosterjs/wiki/Dispose-an-editor
https://microsoft.github.io/roosterjs/index.html
https://github.com/microsoft/roosterjs/wiki/RoosterJs-9
猜你喜欢
- 2025-06-03 基于OpenAI的新NLP文本编写APP—GPT-2,随时随地和你一起写作
- 2025-06-03 推荐6套非常热门的微信小程序开源项目
- 2025-06-03 腾讯开源的Markdown编辑器,开箱即用、轻量简洁、易扩展
- 2025-06-03 挖洞经验|UEditor编辑器存储型XSS漏洞
- 2025-06-03 介绍几款表单设计器(anyreport表单设计器)
- 2025-06-03 来了!JavaScript 最强大的 8 个 DOM API
- 2025-06-03 2014年最优秀JavaScript编辑器大盘点
- 2025-06-03 2021年最值得推荐的13个提高开发效率工具,程序员必备
- 2025-06-03 LATEX文本编辑器:MiKTeX 23.10(中文latex编辑器)
- 2025-06-03 所见即所得的 markdown 编辑器:Typora
你 发表评论:
欢迎- 06-24发现一款开源宝藏级工作流低代码快速开发平台
- 06-24程序员危险了,这是一个 无代码平台+AI+code做项目的案例
- 06-24一款全新的工作流,低代码快速开发平台
- 06-24如何用好AI,改造自己的设计工作流?
- 06-24濮阳网站开发(濮阳网站建设)
- 06-24AI 如何重塑前端开发,我们该如何适应
- 06-24应届生靠这个Java简历模板拿下了5个offer
- 06-24服务端性能测试实战3-性能测试脚本开发
- 567℃几个Oracle空值处理函数 oracle处理null值的函数
- 566℃Oracle分析函数之Lag和Lead()使用
- 550℃Oracle数据库的单、多行函数 oracle执行多个sql语句
- 546℃0497-如何将Kerberos的CDH6.1从Oracle JDK 1.8迁移至OpenJDK 1.8
- 545℃Oracle 12c PDB迁移(一) oracle迁移到oceanbase
- 536℃【数据统计分析】详解Oracle分组函数之CUBE
- 526℃最佳实践 | 提效 47 倍,制造业生产 Oracle 迁移替换
- 519℃Oracle有哪些常见的函数? oracle中常用的函数
- 最近发表
- 标签列表
-
- 前端设计模式 (75)
- 前端性能优化 (51)
- 前端模板 (66)
- 前端跨域 (52)
- 前端缓存 (63)
- 前端react (48)
- 前端aes加密 (58)
- 前端脚手架 (56)
- 前端md5加密 (54)
- 前端富文本编辑器 (47)
- 前端路由 (61)
- 前端数组 (73)
- 前端js面试题 (50)
- 前端定时器 (59)
- Oracle RAC (73)
- oracle恢复 (76)
- oracle 删除表 (48)
- oracle 用户名 (74)
- oracle 工具 (55)
- oracle 内存 (50)
- oracle 导出表 (57)
- oracle 中文 (51)
- oracle的函数 (57)
- 前端调试 (52)
- 前端登录页面 (48)
本文暂时没有评论,来添加一个吧(●'◡'●)