开源一个 block-based 的编辑器

2021-03-04 19:59:03 +08:00
 djyde

事缘我在写一个给自己用的和 Roam Research 类似的笔记软件,现在差不多完成了,但是目前不打算把笔记软件开源,而是先把里面的编辑器开源了。

在这里可以试试 https://plastic-editor.netlify.app

在设计和实现这个编辑器的时候,我把它做成了和环境无关的,我抽象了一个 Adapter, 用来给不同的宿主环境做各自的数据持久化实现。这样我编辑器日后可以同时在 Electron 和 native app 工作。

因为项目还在非常早期的开发,API 还是相当不稳定的,所以没有写文档。但是可以通过 https://github.com/djyde/plastic-editor/blob/master/demo/index.ts 一窥大概的用法。

另外由于我做这个编辑器就是为了方便实现「双向链接」、「块级引用」的,所以这个编辑器就是围绕 block 来设计的。可以在 https://github.com/djyde/plastic-editor/blob/master/demo/data.ts 看到实际上页面和 block 的数据结构。而我的笔记软件的目标就是每个 notebook 实际上都是一个纯 json 文件。

当然编辑器本身还有非常多需要做的功能和需要解决的 bug (比如 block 的自由拖拽是我目前最想实现的). 我会在 dog food 自己的同时不断地去改进它(如果这个项目没有烂尾的话😆)。

要注意的是,因为「双向链接」、「块级引用」是笔记应用需要实现的,而不是编辑器要实现的,所以你不能在上面的页面里体验到。

2756 次点击
所在节点    分享创造
4 条回复
narmgalaxy
2021-03-04 20:15:45 +08:00
svelte 好评
SenLief
2021-03-04 20:22:00 +08:00
大纲笔记?
uselessVisitor
2021-03-05 09:33:30 +08:00
Obsidian ?
April5
2021-03-06 00:56:36 +08:00
提个 bug,使用中文输入法输入 abc 会生成两行

这是一个专为移动设备优化的页面(即为了让你能够在 Google 搜索结果里秒开这个页面),如果你希望参与 V2EX 社区的讨论,你可以继续到 V2EX 上打开本讨论主题的完整版本。

https://www.v2ex.com/t/758569

V2EX 是创意工作者们的社区,是一个分享自己正在做的有趣事物、交流想法,可以遇见新朋友甚至新机会的地方。

V2EX is a community of developers, designers and creative people.

© 2021 V2EX