Taleweaver - 支持分页的在线编辑器


MIT
跨平台
TypeScript

软件简介

Taleweaver,支持分页的在线编辑器。

有很多在线编辑器(WYSIWYG),但是这些编辑器都不支持分页。这些编辑器都是在浏览器中使用,浏览器关注的是布局和渲染,不关心内容将会渲染在什么地方。当页面需要印刷到文档中的时候,很多特性就不在适用了。比如将一个页面印刷到
A4 纸张上面,这些编辑器就无法做到想微软的 office 中的 word 那样,可以支持分页、页面等特性。

支持此特性的商业编辑器有谷歌文档、微软的 office online 中的
word,taleweaver 似乎是第一个支持分页的开源软件。

Taleweaver 拥有排版引擎同时提供了一套 API 来访问排版信息。它的目标就是把 word 那种风格的文字编辑体验带到开源社区。

实现方式:

Taleweaver 通过获取文档状态并将其呈现到屏幕上来工作。通过状态转换修改状态时,通过一系列步骤将更改传播到屏幕。

[状态] -> [模型树] -> [呈现树] -> [布局树] -> [视图树]

状态

文档的 State 是用一系列的水平的 token 来表示的. 共有三种 token:

  • Open tag token——标记文档中元素的开始
  • Close tag token——标记文档中元素的结尾
  • Character token——文档内容的一个字符

State 允许在数组上以插入或删除的形式进行更改。这个简单的接口能够实现以最小的工作量实现协作编辑。

便于存储和基于文本的传输,state 可以序列化为标记,且能够通过分词相关技术从标记中恢复。