非常非常想要二级文档树

感谢“二级文档列表”的插件大大 @Misuzu2027)🎉🎉🎉

2024 年 10 月 9 日

在这里夸一下“二级文档列表”的插件大大,别看现在插件市场里的此插件朴素如斯,这几天和大大聊天得到的帮助,实际让二级文档的花样变得超丰富鸟(开心兴奋)

目前插件市场里,这个二级文档插件新增的两三个设计(大家有发现吗?没发现的话提醒一下)

  • 增加了二级文档搜索框 👍
  • 在二级文档里点开文件夹,有“返回上一级文档”按钮 👍
  • 增加了二级文档定位 👍 (文档在二级文档里定位——不用跳到一级里定位展开辣么长的文档)
  • 还有其他设计,大多数都是通过 css 实现的功能,目前还不清楚大大为啥没有更新到插件市场里,但就我个人评测——狠好用!!!从之前的毛坯房到精装修鸟

碎碎念吐槽:多亏了这几天可以上 github 啊,之前真是干着急,开心叉腰转圈

❤️ 感谢大大 @EmberSky

第一个版本已经做出来了 ❤️🎉 🎉

**有需要的小伙伴,请去大大的帖子下二级文档树简略版 _release_v1.0**

  1. 请积极在大大帖子下发布反馈,有沟通才有动力 🎉 🎉🎉
  2. 别忘了给大大点赞收藏送积分表示感谢哦!!!这个很重要!!!😄 😄
  3. 希望各路程序猿大大看到,请积极踊跃加入,让“二级文档树”这个功能变得更好用吧!🙏 🙏

这个真的很重要。

2024 年 8 月 26 日更新

* 这个是楼下评论,👍 某位大大 @Imuvux 写的对于二级文档树的总结——言简意赅,建议可以优先查看。

非常非常想要二级文档树 - Imuvux 的回帖

  • 这两个是 OneNote 的二级文档树的具体介绍
    看完就明白为什么我认为二级文档树很有必要

非常非常想要二级文档树 - Floria233 的回帖

非常非常想要二级文档树 - Floria233 的回帖

* 在此感谢 ❤️ 开始关注“二级文档树”架构的程序猿大大 @EmberSky

非常非常想要二级文档树 - EmberSky 的回帖


旧帖

请问思源未来的文档界面可以升级到类似 OneNote 这种二级文档结构?

页面 mosaicmosaic.png

即左边是层级文件夹,其中每一层都只有 folder file,每点开一层文件夹,其中的 page 则在右边对应展开。

这是传统版本,另一个版本是 uwp,那种两级文件夹在同一侧。

2mosaic.png

如果这种传统 2016 版做不出,uwp 那种也勉强可以啊,总之,二级文档树非常非常想要!!!

偶尔我也很需要传统的笔记方法来管理笔记——不是双链笔记,就是传统的树状笔记,参考 OneNote 或者 Evernote。思源的设计也确实完全支持这种笔记方法,奈何一级文档树架构真是太拖后腿了。上一代笔记软件,印象,有道云,为知,蚂蚁,古早的麦库,无一例外都是这种近似二级文档树的架构设计,其可以存在那么多年,还是有一定用户认可并深度使用着这种功能啊啊(只可惜这些父辈软件无一例外花样作恶不让人省心)。

目前思源的功能对我而言已经非常丰富,完全足够当个主力软件,目前我有一个库就是这种传统的树形笔记文档。(即便是项目文档笔记,我也认为二级文档树架构比一级好太多了)

每每这种时候,思源给我的感觉就就像一个设计先进科技发达的火箭,明明架在高架台上蓄势待发,却唯独缺了可以让它点火升空的航空燃油,没有那玩意儿,这个火箭就算再牛逼,就是飞不起来啊。


之所以提出这种建议,因为我有一个很重要的痛点。

目前使用思源时,左侧文件夹一旦内容变多,那么不管是点开查看,还是翻阅,都会非常非常麻烦。

1 不够直观

折叠的文件夹和文件 page 混在一起,而显示屏的尺寸限制了当前界面所能呈现的文件,一旦有七八十个折叠文件夹,那么就需要不断往下滑动查找。

稍不小心就可能看漏,因此需要反复来回滑动。

靠搜索也完全无法解决这种查看,因为人脑记忆有限,一旦数量达到数十个,我的感受是,很多时候我就连记了哪些内容都需要依赖文档树来回顾,如果不做文档树的层级结构调整和重设,那么这种查看非常非常麻烦-鼠标滚轮都快冒烟了,还容易看漏。

2 不便管理

如 1 所述,单一层级文档树带来的第二个麻烦,一旦文档达到几百个,就连其调整顺序和拖动也变得十分麻烦。

一种场景是:一个 page 在文档树最下面,而我想要挪动到很上层的 folder。

2.1 鼠标法

如果靠鼠标拖动,有时候要拖很久,还容易一不小心误拖到中途某个文件夹中, 这个失误步骤后续带来的两个衍生麻烦是,① 有时候一走神,这个 page 究竟被拖动到哪个错误的 folder 都需要再度查找 ② 即便知道 page 在哪里,也还是需要再度往上托,重复这个漫长无聊的动作(等待文档树自动往上慢吞吞滚动)

2.2 键盘法

如果使用文档树中的“移动”这个操作——

依旧如 1 所述,一旦文档达到数百个,即便使用“移动”选项,那么右键弹出也是“数量庞大的全部文档”,对于选中其中某个特定 page 或 file,使用体验简直是灾难---就跟用鼠标直接往往上拖没什么区别。

这个痛点,目前我只能以文档子目录的方式来解决,效果也不是十分理想。因为子目录毕竟只涉及到文档内容,而我需要的,则是直接对某个文档本身操作。

OneNote2016 这种文档树架构,左 folder 右 note,是我见过的所有文档树设计中最优秀的(只可惜 OneNote 本身槽点太多)。

从我使用的 n 个软件体验来看,这种二级文档树架构,不管是对需要文档树和不需要文档树的人,都是一个完美的兜底,它对于文档层面“管理文档”极其高效。

如果是类似 OneNote 这种两侧文档树层级模式,将文件夹和文档本身分开,那么不管是查看,还是管理文档,其效率都会大幅增高。


ps:我能理解很多大佬使用双链或 tag 来管理文档,但就我的使用体验——

1 这种靠链接来管理方式只适用于当下频繁使用的文档,更接近于项目文档,它需要立刻以某种逻辑结构 or 形式呈现出来。

这种笔记方式一边以链接来管理笔记,一边帮着使用者整理思维,但它一旦应用到超庞大数量的文档时,这种精细化处理就会造成相当的思考成本和记录成本。

关键是,有时候很多内容并不需要这么处理啊。

2 笔记仓库类型这种模式的文档,并不需要太强的逻辑架构,它需要被准备安放在一个特定位置,随着时间流逝,被调取出来,或者被删除,或者被移动。

我有仓鼠症囤积癖啊,有些摘录笔记或者随便写的东西,一时间不想也没法用双链给连接起来,就只想先屯起来。如果每次写一个笔记就要立刻用双链来管理,那么记录笔记的成本就大幅提高了,关键是有些笔记也确实没有重要到需要双链

3 即便是项目文档,当前的这种一级文档树架构,也还是比不上 OneNote 这种二级文档树架构,因为偶尔有些项目文档也是超大型数量繁多,用久之后也还是会遇上我上述问题。

没有二级文档树,思源的使用体验总感觉只能达到 80%,这种无力拍击键盘感。

再 ps:在树形笔记软件中,我知道还有另一个开源的 joplin,试过了,还是思源好用,所以希望思源更好用一点 😄

  • 思源笔记

    思源笔记是一款隐私优先的个人知识管理系统,支持完全离线使用,同时也支持端到端加密同步。

    融合块、大纲和双向链接,重构你的思维。

    23020 引用 • 92601 回帖
4 操作
Floria233 在 2024-10-09 23:54:41 更新了该帖
Floria233 在 2024-08-30 10:56:04 更新了该帖
Floria233 在 2024-08-26 11:00:19 更新了该帖
Floria233 在 2024-08-26 10:57:39 更新了该帖

相关帖子

优质回帖
  • Imuvux 2 2 赞同

    稍微整理了一下。

    二级文档树的功能

    两个面板分别罗列本级文档的相邻文档和本级文档上方父文档的相邻文档。

    • 不需要增加三级、四级文档树,二级文档树的《本层 + 上层》足够产生质变
    • 与父子文档的理念并不冲突
      • 原本文档树的展开变成:将本文档(和同层文档)放到一级面板,其子层文档展开放到二级面板
      • 原本的折叠变成:将本文档(和同层文档)放到二级面板,其父层文档(和父层的同层文档)放到一级面板
      • 进一步优化操作的话可以 Ctrl+左键 展开文档子层,Ctrl+右键 展开文档父层
    二级文档树的作用
    检索文档时增加信息密度
    • 两级文档树可以增加文档上层的上下文信息展示。因为屏幕纵向高度有限,若某一层级文档较多,则单列文档树难以同时查看本文档相邻文档、上层文档相邻文档,而后者具有更宏观的分类视角
    • 文档级别的检索浏览是一个宏观操作,需要有足够大的全局视野在不同笔记分区上快速切换
      • 与文档树 + 大纲的差异:
        文档树 + 大纲 + 编辑器可以实现 文档层次上下文+大纲层次上下文+内容上下文,看上去是并列的不过后两者的作用域更加精细。而二级文档树关注的是更上层的 同层文档上下文+父层结构上下文,具有更高层次的观察视野,并不需要与大纲同时长期显示。
    • 同理,如果需要在某个层级上切换文档时观察其子层文档,不使用二级文档树就需要不断地展开折叠
    • 这一点可以采用文档层级导航插件稍作弥补,但显示效率仍然不如二级文档树;且还是不能解决文档过多时难以用文档树检索的问题
    • 采用文档链接组织 MOC 可以代替文档树的分类功能,但同样存在问题
      • MOC 的文档天然可分屏虽然有利于多视角检索,但不同页签缺乏二级文档树的联动性,还是要手动展开折叠
      • 此外,文档数量较大时 MOC 目录也会变得极其巨大,而拆分 MOC 目录页同样会损失全局预览能力
    移动文档时简化操作
    • 高效的文档切换使二级文档树能大幅提升文档移动体验,参考 MT 文件管理器的双窗口操作
    • 右键移动时同样面临只能查看单列文档树的问题,除非同时显示同层文档和子层文档;此外批量移动时手感同样较差
    • MOC 文档的链接移动起来更方便,但是:
      • 完全不移动文档本体,意味着文档数量不断增加会出现拖累性能的风险,而且不能采用关闭笔记本的方式缓解。而个人笔记这种超长使用周期的工具,即便是潜在的性能问题也会严重挫伤使用动力

    只要想移动文档,二级文档树几乎就是最优解决方案。

  • EmberSky 4

    我简单想了一下代码逻辑, 覆盖的场景肯定不全, 不过感觉有搞头

    显示二级文档树

    在一级文档树旁边插入一列, 用来显示二级文档树, 大概类似于这样

    image.png

    事件监听

    监听一级文档树点击事件

    1. 获取点击的笔记本 id 和文档 id (可行)
    2. 通过以下 api, 获取子文档列表 (未验证)
      http://127.0.0.1:59401/api/filetree/listDocsByPath
      {
          "notebook": "20240309142729-wq6qzz8",
          "path": "/20240403091024-c8fa15f.sy"
      }
      
    3. 在二级文档树里显示文档列表 (未验证)

    监听二级文档树点击事件

    1. 获取点击的 笔记本 id, 文档父节点 id, 文档 id (可行)
    2. 在一级文档树里找到文档父节点 (可行)
    3. 点击折叠按钮, 让文档父节点展开 (可行)
    4. 点击文档节点 (可行)
  • Floria233 3 赞同

    双链就可以辅助摆脱树形的僵化,维基只不过是大型的聚合双链,并不比文档树先进多少。

    甚至于,维基这种形式,最大的应用层面不就是用于“浏览”笔记吗?之所以在网页上看各种百科看得很爽,只是因为“百科”有众多网友一起参与维护数据,也不需要你个人去管理底层文档。管理成本主要是众人一起分摊,也有管理员在背后维护啊,这点你是不是没考虑?

    而 wiki 应用于个人笔记,所有的东西都要自己维护,自己链接,应用于海量数据时,这个管理难度也是海啸级别。光靠文档树都没法单独搞定,所以需要两者结合。

    也有一点是,wiki 这种强调笔记浓缩,写非常干货,写非常有用的东西,笔记被 link,才有意义,而笔记被作为树状组织,难道就没意义了吗?。

    如图,真 wiki 也是有文档树的,这还仅仅只是浏览就需要这种层级文档。

    那么作为个人笔记,一级文档树帮助浏览没问题, 二级文档树来辅助管理文档,这难道没必要?

    维基百科这种索引式,嵌套过度之后--一般到七层,就会非常消耗人的心智。管理成本和回顾成本是指数级别的上升。

    文档树也没有妨碍维基形式啊,作为一个辅助手段,文档树的文档跳跃,比纯粹的 moc 索引高效太多。

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...
  • 我也是比较习惯使用层级目录管理文档,目前把文档当做目录,整体休验还可以,主要差异是:1、习惯点击目录弹出下级菜单,但点击文档是转到文档,有些是空文档,没有跳转链接(子文档是手动从文档树中新建的,上级文档没有链接),需要再在文档树中点击箭头来展开 2、同级目录内,文档和文件夹按名称混排,不过有图标可以分清哪个文档是有子文档的。这样比起传统的二级目录也有好处,就是可以实现无限层级的子目录,不受限于只有二级。如果楼主痛点是同级目录下文档太多,是不是可以考虑把每级目录下的文档做整合,把每级目录控制在 10 个以内,太多的文档就再做分类,感觉还是可以接近目录的使用体验的。也提个建议是,如果文档包含下级文档,可以自动生成目录链接,当下级文档变化时,自动更新目录(飞书支持该功能),这样就能够更好的把文档当做目录使用。

    image.png

    image.png

    1 回复
  • 其他回帖
  • EmberSky 4

    我简单想了一下代码逻辑, 覆盖的场景肯定不全, 不过感觉有搞头

    显示二级文档树

    在一级文档树旁边插入一列, 用来显示二级文档树, 大概类似于这样

    image.png

    事件监听

    监听一级文档树点击事件

    1. 获取点击的笔记本 id 和文档 id (可行)
    2. 通过以下 api, 获取子文档列表 (未验证)
      http://127.0.0.1:59401/api/filetree/listDocsByPath
      {
          "notebook": "20240309142729-wq6qzz8",
          "path": "/20240403091024-c8fa15f.sy"
      }
      
    3. 在二级文档树里显示文档列表 (未验证)

    监听二级文档树点击事件

    1. 获取点击的 笔记本 id, 文档父节点 id, 文档 id (可行)
    2. 在一级文档树里找到文档父节点 (可行)
    3. 点击折叠按钮, 让文档父节点展开 (可行)
    4. 点击文档节点 (可行)
    1 回复
  • Floria233

    就我对文档管理的看法,我认为文档树和文档目录还是有点区别。

    文档树更像货架,矿泉水和泡面可以摆在一起,也可以不摆在一起,而文档目录,则强制要求矿泉水和矿泉水在一起,泡面和泡面在一起。

    文档目录我是用 moc 来进行索引,即如果在需要某些笔记时,就直接创建索引笔记,将需要的笔记以 moc 的形式放进去。

    真痛点不是文档太多,而是目前的一级文档树这种设计,造成文档的增熵,只有二级文档树是最简便有效的解决方式。

    你说的这种方式,我也在用,但我感觉这种只能应对于数量不多的文档,或者内容属性相近的文档,或者目前正在频繁使用(熟悉)的文档,即项目笔记。

    而一旦达到跨学科跨门类这个层级,这种管理方式会造成一级文档树的目录非常非常长——其实还有另一种解决方式,就是分库,但分库的话,就相当于把一个房间里货架上的商品,分割放置到了不同房间的货架上,卡片笔记法我认为精华的一点是不同领域的碰撞,分库的话,就是人为阻断了领域的联系,分库可以辅助在某个学科领域的深入研究,但却不利于激发出“创新”这种东西。说起来,就是树形和网状的区别。

    现在思源的网状框架做得很好啦,但这个树状,真是一言难尽。就算卢曼是靠卡片笔记来做研究,难道没人注意到,人家的卡片笔记也是分条缕析规规矩矩放在不同的卡片盒里吗?卡片本身是网状,但管理卡片的卡片盒,放到电子笔记领域,实则应当就是树状啊。

    现在的问题是,一级文档树在管理文档层面,没有二级树方便。这种堪比物理层面的限制,不是通过目录大纲可以解决的。(就好比说,卢曼的小纸片确实是放在一个个盒子里,但人家的盒子也不是从地面堆高一排直通天花板,而是上下左右堆成一个高度合适的类似货架的排布)zettelkasten0.jpeg

    文件夹就相当于一个个小盒子,文件夹下内部的文档就是卡片,一级文档树就是天梯叠叠乐,二级文档树就是货架堆叠法,哪种更容易取用,应当是一目了然。

  • Floria233

    2024 年 8 月 24 日 23:08:20

    • 二层文档树这个设计本身其实是很好的。有问题的是那些上代笔记,它们只是提供了笔记的“储存”功能,没有想出或者提供一个很好的“如何利用笔记”这个功能,使得记笔记只是一种静态活动,一旦收藏就会吃灰。
    • 现在这一代的 ob 思源 flowus 等等,让笔记连接起来,增加笔记的活跃度,这主要的卖点不就是加上一个“双链”,供以弥补上代树形笔记软件在“利用笔记”层面的短板吗?专注“双链”固然不错,但创新的同时有必要把过去的东西一棒子打死吗?
    • 新一代的笔记软件,似乎都对“文档树架构”这个东西,避之不及,好像用了这个架构就会使笔记体系僵化,其实怎么可能呢?既然已经有了“双链”这个功能,笔记如何利用的问题已经解决,双链加上目录树架构,完美解决了笔记在“管理”+“使用”两个方面的问题,然而现在的笔记软件却忽然集体砍掉文档树功能,使得 page 管理变得非常困难,让人不得不把一部分笔记继续放在传统的笔记软件里。
    • 其实就是,有很多人像我这样,很喜欢记录各种乱七八糟的玩意儿,这些东西在当下这个时刻或许根本就不重要,只是一种吐槽或者简单备忘,不是那种可以直接打印出来写成书的正式 note,这种不正式的笔记条儿(不是碎碎念啊)或许在未来才需要整理甚至删掉,在这种情况下,双链是不必要的,文档树把它存在一个固定位置是很有必要的。如果只用一层文档树,那么后续这种乱七八糟的笔记,其调整位置,其查看位置,就是用鼠标爬天梯般的痛苦。
    • 甚至于,即便对于正式 note,双链固然可以很方便引用文档,但如果 page 太多了,引用跳出来的链接也会非常非常多,这种时候,与其用【【这种来引用,还不如直接去文档树里面复制一个链接再跳回来插入呢。在这种场景下,二级文档树,也比一级文档树要方便多了。
    • 只有双链而无文档树,这还会导致另一个问题,即如果文档太多,你自己都不记得什么是什么的情况下,只用【【来引用,看似是可以唤起记忆,也有可能造成记忆负担。毕竟不是每个人都擅长文档编码,或者一开始就能规划好一辈子的笔记体系架构,那么引用跳出来的内容,实际也可能乱七八糟。再说一遍,还不如去文档树复制链接。
    • 没有文档树辅助管理文档,双链用到最后,会使得整个库的文档笔记彻底乱掉,这时候继续仅靠一级文档树来管理 page,其困难度也远远大于二级文档树。如果有二级文档树这种比较简洁管理 page 的界面,有可能大家在记笔记时顺手就把 page 给整理了,而不是堆积成一座笔记山再来整理。
    • 双链可以用于处理特定的重要的项目文档(精细化处理),文档树可以作为仓库管理所有文档(粗放式管理),双链对应着新一代的笔记软件,文档树对应着上一代的笔记软件,这两者本可以相得益彰,完美解决笔记在“管理”+“使用”两个方面的问题。现在的笔记软件,则强行要求大家只用“双链”来管理文档,一旦碰上千位级别的文档,实在是小牛拉大车,心有余而力不足。(就说一句话,那个闪闪发光的网球图,真会比文档树直观好用么?)
    1 回复
  • 查看全部回帖