微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

Taleweaver 支持分页的在线编辑器

程序名称:Taleweaver

授权协议: MIT

操作系统: 跨平台

开发语言: TypeScript

Taleweaver 介绍

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 可以序列化为标记,且能够通过分词相关技术从标记中恢复。

Taleweaver 官网

https://github.com/yuzhenmi/taleweaver

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 [email protected] 举报,一经查实,本站将立刻删除。

相关推荐