关于划线和笔记功能的设计实现讨论

2021-12-16 20:56:17 +08:00
 cxyfreedom
现在很多 App 都有划线、笔记的功能,比如微信读书、极客时间、有知有行等等。

我通过网页端看了一下极客时间的请求接口,划线和记笔记会产生一条记录,具体存储可能是 My SQL 和 ES 结合。但是上层还有一个 block 块,比如请求某篇文章的 note ,会获得这个文章所有的 block ,然后通过某个 block 的 id 能获取到这个 block 下所有的笔记。

但是我手动创建笔记或者划线时,生成的并不是 block 块的数据。

想问问大家关于这个功能,了解一下具体的后台存储设计应该是怎么样的?谢谢
872 次点击
所在节点    问与答
2 条回复
somalia
2021-12-16 23:41:05 +08:00
没看明白。给文章指定位置打上标记,如何进行存储?
cxyfreedom
2021-12-17 00:38:43 +08:00
@somalia #1 我拿极客的举例子。当请求一篇文章时,首先会通过请求获取个人划线和笔记的数据,以及请求获取 block 块的列表(也就是文章中看到划线的内容列表),每个 block 块内容包括 block ID 、长度、index 位置等。

当我选中某个划线时,会通过这个 block id 请求获取到这个 id 下所有的笔记。假设笔记信息包括 id ,划线内容,用户 id 等等。

当我去 post 请求划线或者新增笔记时,新增的数据也就是笔记 id 、划线内容、uid 等等。删除修改也是针对创建出来的这条笔记 id 处理。

也就是说我新增的数据从接口看不会创建出 block 。那么这个 block 块是如何产生的 或者说怎么产生的

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

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

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

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

© 2021 V2EX