如何为文件树添加缩进线

本贴最后更新于 663 天前,其中的信息可能已经东海扬尘

根据好心人的回答,我自己改了改代码,也分享一下:

⭕ 主要改动为:(适用于明亮模式,暗黑模式需要自己调下颜色)
① 图标保持为原大小。
② 缩进线间距调大、调细。(我真的密恐,受不了那么密密麻麻还很粗的缩进线)
③ 添加了笔记区隔。

这个代码的缺陷是:存在不必要的缩进线,导致观感不够好,理想状况下,笔记本下的第一条缩进线应该是不需要的。

欢迎美工大佬们进一步改进、分享代码 🌸

.sy__file .b3-list-item__toggle { padding-left:8px !important; padding-right:1px; color:#899fad; } .sy__file .b3-list.b3-list--background ul { border-left:1px dotted #c5d2db; margin:0px 0px 0px 16.5px; } .sy__file .fn__flex-1 { margin:0px; padding-right:5px; } .layout--float .file-tree { margin-right:5px; } .fn__flex-1.fn__flex-column.file-tree.sy__file .b3-list-item { margin-left:0px !important; } /* 笔记本 区隔 */ .sy__file ul.b3-list.b3-list--background { border-radius: 0.3em; margin: 6px 10px 6px 12px; outline: 1.5px double #d2dfe8; overflow: hidden; }

其实还可以为 无子文档的文档 添加一个记号以便优化显示效果,但由于这个记号会污染大纲,而我又不知道如何才能让它不影响到大纲,故未采用。

b3-list-item.b3-list-item--hide-action .b3-list-item__toggle.fn__hidden::before { content: '○'; font-size: 30%; display: block; position: absolute; visibility: visible; transition: var(--b3-transition); margin-bottom: 2px; margin-left: 2.3px; }

如何为文件树添加类似 Obsidian 里的这种列表项引导线?

image.png

  • 思源笔记

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

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

    26088 引用 • 108316 回帖
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    10020 引用 • 45553 回帖 • 71 关注
4 操作
GloR 在 2023-09-03 09:16:54 更新了该帖
GloR 在 2023-09-02 15:22:35 更新了该帖
GloR 在 2023-09-02 15:18:43 更新了该帖
GloR 在 2023-09-02 15:17:14 更新了该帖

相关帖子

被采纳的回答
  • 我从 Cliff-Dark 主题上把对应的 CSS 片段扒下来了:

    /*文件树缩进线*/ .sy__file .b3-list-item__toggle { padding-left:1px !important; padding-right:1px; color:var(--b3-theme-primary); opacity:0.6; } .sy__file .b3-list-item__icon { margin-left:0px; margin-right:0px; padding:0px 0px; transform:scale(0.6); } .sy__file .b3-list.b3-list--background ul { border-left:2px solid var(--b3-theme-background-light); margin:0px 0px 0px 10px; } .sy__file .fn__flex-1 { margin:0px; padding-right:5px; } .layout--float .file-tree { margin-right:5px; } .fn__flex-1.fn__flex-column.file-tree.sy__file .b3-list-item { margin-left:0px !important; }

    如果你想改一改样式,可以参考以下 GPT 的回答:

    --GPT 回答分界线--

    在这段代码中,每个模块的作用如下:

    1. .sy__file .b3-list-item__toggle 模块:

      • padding-left:1px !important;:设置列表项的左内边距为 1 像素。
      • padding-right:1px;:设置列表项的右内边距为 1 像素。
      • color:var(--b3-theme-primary);:设置列表项的文本颜色为预定义的主题主色。
      • opacity:0.6;:设置列表项的透明度为 0.6。
    2. .sy__file .b3-list-item__icon 模块:

      • margin-left:0px;:将列表项图标的左外边距设置为 0 像素。
      • margin-right:0px;:将列表项图标的右外边距设置为 0 像素。
      • padding:0px 0px;:将列表项图标的内边距设置为 0 像素。
      • transform:scale(0.6);:将列表项图标进行缩放,缩放比例为 0.6。
    3. .sy__file .b3-list.b3-list--background ul 模块:

      • border-left:2px solid var(--b3-theme-background-light);:在文件列表的左侧添加一个宽度为 2 像素、颜色为预定义的背景亮色的实线边框。
      • margin:0px 0px 0px 10px;:设置文件列表的外边距,上、右、下边距为 0 像素,左边距为 10 像素。
    4. .sy__file .fn__flex-1 模块:

      • margin:0px;:将元素的外边距设置为 0 像素。
      • padding-right:5px;:将元素的右内边距设置为 5 像素。
    5. .layout--float .file-tree 模块:

      • margin-right:5px;:将浮动布局中的文件树元素的右外边距设置为 5 像素。
    6. .fn__flex-1.fn__flex-column.file-tree.sy__file .b3-list-item 模块:

      • margin-left:0px !important;:将文件树中的列表项的左外边距设置为 0 像素,并使用 !important 关键字强制应用此样式,覆盖其他可能存在的样式。

    以上是对每个模块的简要解释,它们主要用于调整文件列表中的元素的样式,包括列表项的内边距、图标的外边距和缩放、文件列表的边框和外边距,以及文件树中的列表项的外边距。

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • jxst991059 2 赞同

    感谢,基于你提供的代码,我做了大幅精简,感觉这样就够了,也更加接近出厂默认的体验:

    .sy__file .b3-list-item__toggle {

    padding-left: 2px !important;

    padding-right: 2px;

    }

    .sy__file .b3-list.b3-list--background ul {

    border-left: 1px solid #e0e0e0;

    margin-left: 18px;

    }

  • 其他回帖
  • 我用暗黑模式感觉那个框框太亮了,有点影响我看文件标题

  • GloR

    我就是需要笔记本的区隔来着 😂

    1 回复
  • 我从 Cliff-Dark 主题上把对应的 CSS 片段扒下来了:

    /*文件树缩进线*/ .sy__file .b3-list-item__toggle { padding-left:1px !important; padding-right:1px; color:var(--b3-theme-primary); opacity:0.6; } .sy__file .b3-list-item__icon { margin-left:0px; margin-right:0px; padding:0px 0px; transform:scale(0.6); } .sy__file .b3-list.b3-list--background ul { border-left:2px solid var(--b3-theme-background-light); margin:0px 0px 0px 10px; } .sy__file .fn__flex-1 { margin:0px; padding-right:5px; } .layout--float .file-tree { margin-right:5px; } .fn__flex-1.fn__flex-column.file-tree.sy__file .b3-list-item { margin-left:0px !important; }

    如果你想改一改样式,可以参考以下 GPT 的回答:

    --GPT 回答分界线--

    在这段代码中,每个模块的作用如下:

    1. .sy__file .b3-list-item__toggle 模块:

      • padding-left:1px !important;:设置列表项的左内边距为 1 像素。
      • padding-right:1px;:设置列表项的右内边距为 1 像素。
      • color:var(--b3-theme-primary);:设置列表项的文本颜色为预定义的主题主色。
      • opacity:0.6;:设置列表项的透明度为 0.6。
    2. .sy__file .b3-list-item__icon 模块:

      • margin-left:0px;:将列表项图标的左外边距设置为 0 像素。
      • margin-right:0px;:将列表项图标的右外边距设置为 0 像素。
      • padding:0px 0px;:将列表项图标的内边距设置为 0 像素。
      • transform:scale(0.6);:将列表项图标进行缩放,缩放比例为 0.6。
    3. .sy__file .b3-list.b3-list--background ul 模块:

      • border-left:2px solid var(--b3-theme-background-light);:在文件列表的左侧添加一个宽度为 2 像素、颜色为预定义的背景亮色的实线边框。
      • margin:0px 0px 0px 10px;:设置文件列表的外边距,上、右、下边距为 0 像素,左边距为 10 像素。
    4. .sy__file .fn__flex-1 模块:

      • margin:0px;:将元素的外边距设置为 0 像素。
      • padding-right:5px;:将元素的右内边距设置为 5 像素。
    5. .layout--float .file-tree 模块:

      • margin-right:5px;:将浮动布局中的文件树元素的右外边距设置为 5 像素。
    6. .fn__flex-1.fn__flex-column.file-tree.sy__file .b3-list-item 模块:

      • margin-left:0px !important;:将文件树中的列表项的左外边距设置为 0 像素,并使用 !important 关键字强制应用此样式,覆盖其他可能存在的样式。

    以上是对每个模块的简要解释,它们主要用于调整文件列表中的元素的样式,包括列表项的内边距、图标的外边距和缩放、文件列表的边框和外边距,以及文件树中的列表项的外边距。

    如果看不懂是什么意思,随便改一改数值,重新加载之后看看变化就知道了
    JeffreyChen
  • 查看全部回帖

推荐标签 标签

  • Mac

    Mac 是苹果公司自 1984 年起以“Macintosh”开始开发的个人消费型计算机,如:iMac、Mac mini、Macbook Air、Macbook Pro、Macbook、Mac Pro 等计算机。

    167 引用 • 597 回帖 • 1 关注
  • GAE

    Google App Engine(GAE)是 Google 管理的数据中心中用于 WEB 应用程序的开发和托管的平台。2008 年 4 月 发布第一个测试版本。目前支持 Python、Java 和 Go 开发部署。全球已有数十万的开发者在其上开发了众多的应用。

    14 引用 • 42 回帖 • 821 关注
  • 快应用

    快应用 是基于手机硬件平台的新型应用形态;标准是由主流手机厂商组成的快应用联盟联合制定;快应用标准的诞生将在研发接口、能力接入、开发者服务等层面建设标准平台;以平台化的生态模式对个人开发者和企业开发者全品类开放。

    15 引用 • 127 回帖 • 4 关注
  • 电影

    这是一个不能说的秘密。

    122 引用 • 608 回帖
  • Flume

    Flume 是一套分布式的、可靠的,可用于有效地收集、聚合和搬运大量日志数据的服务架构。

    9 引用 • 6 回帖 • 661 关注
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    186 引用 • 1021 回帖
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    437 引用 • 1238 回帖 • 588 关注
  • Hibernate

    Hibernate 是一个开放源代码的对象关系映射框架,它对 JDBC 进行了非常轻量级的对象封装,使得 Java 程序员可以随心所欲的使用对象编程思维来操纵数据库。

    39 引用 • 103 回帖 • 728 关注
  • Pipe

    Pipe 是一款小而美的开源博客平台。Pipe 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    134 引用 • 1127 回帖 • 109 关注
  • Sublime

    Sublime Text 是一款可以用来写代码、写文章的文本编辑器。支持代码高亮、自动完成,还支持通过插件进行扩展。

    10 引用 • 5 回帖 • 1 关注
  • Jenkins

    Jenkins 是一套开源的持续集成工具。它提供了非常丰富的插件,让构建、部署、自动化集成项目变得简单易用。

    54 引用 • 37 回帖
  • ReactiveX

    ReactiveX 是一个专注于异步编程与控制可观察数据(或者事件)流的 API。它组合了观察者模式,迭代器模式和函数式编程的优秀思想。

    1 引用 • 2 回帖 • 182 关注
  • 印象笔记
    3 引用 • 16 回帖
  • C

    C 语言是一门通用计算机编程语言,应用广泛。C 语言的设计目标是提供一种能以简易的方式编译、处理低级存储器、产生少量的机器码以及不需要任何运行环境支持便能运行的编程语言。

    86 引用 • 165 回帖
  • 机器学习

    机器学习(Machine Learning)是一门多领域交叉学科,涉及概率论、统计学、逼近论、凸分析、算法复杂度理论等多门学科。专门研究计算机怎样模拟或实现人类的学习行为,以获取新的知识或技能,重新组织已有的知识结构使之不断改善自身的性能。

    77 引用 • 37 回帖
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 580 关注
  • Notion

    Notion - The all-in-one workspace for your notes, tasks, wikis, and databases.

    10 引用 • 77 回帖
  • 区块链

    区块链是分布式数据存储、点对点传输、共识机制、加密算法等计算机技术的新型应用模式。所谓共识机制是区块链系统中实现不同节点之间建立信任、获取权益的数学算法 。

    92 引用 • 752 回帖
  • 微软

    微软是一家美国跨国科技公司,也是世界 PC 软件开发的先导,由比尔·盖茨与保罗·艾伦创办于 1975 年,公司总部设立在华盛顿州的雷德蒙德(Redmond,邻近西雅图)。以研发、制造、授权和提供广泛的电脑软件服务业务为主。

    8 引用 • 44 回帖 • 1 关注
  • Hadoop

    Hadoop 是由 Apache 基金会所开发的一个分布式系统基础架构。用户可以在不了解分布式底层细节的情况下,开发分布式程序。充分利用集群的威力进行高速运算和存储。

    93 引用 • 122 回帖 • 619 关注
  • HBase

    HBase 是一个分布式的、面向列的开源数据库,该技术来源于 Fay Chang 所撰写的 Google 论文 “Bigtable:一个结构化数据的分布式存储系统”。就像 Bigtable 利用了 Google 文件系统所提供的分布式数据存储一样,HBase 在 Hadoop 之上提供了类似于 Bigtable 的能力。

    17 引用 • 6 回帖 • 66 关注
  • Word
    13 引用 • 41 回帖
  • Follow
    4 引用 • 12 回帖 • 2 关注
  • Solo

    Solo 是一款小而美的开源博客系统,专为程序员设计。Solo 有着非常活跃的社区,可将文章作为帖子推送到社区,来自社区的回帖将作为博客评论进行联动(具体细节请浏览 B3log 构思 - 分布式社区网络)。

    这是一种全新的网络社区体验,让热爱记录和分享的你不再感到孤单!

    1443 引用 • 10082 回帖 • 498 关注
  • danl
    175 关注
  • 微服务

    微服务架构是一种架构模式,它提倡将单一应用划分成一组小的服务。服务之间互相协调,互相配合,为用户提供最终价值。每个服务运行在独立的进程中。服务于服务之间才用轻量级的通信机制互相沟通。每个服务都围绕着具体业务构建,能够被独立的部署。

    96 引用 • 155 回帖
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    22 引用 • 148 回帖 • 7 关注