如何为文件树添加缩进线

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

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

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

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

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


.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

  • 思源笔记

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

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

    22351 引用 • 89431 回帖 • 1 关注
  • Q&A

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

    8118 引用 • 37026 回帖 • 160 关注
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 关键字强制应用此样式,覆盖其他可能存在的样式。

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

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 我实现了!下面这段代码原来是 ul ,我改成 ul>ul 之后就可以去掉第一条线了。

    .sy__file .b3-list.b3-list--background ul>ul {
       border-left:1px dotted #c5d2db;
       margin:0px 0px 0px 16.5px;
    }
    

    现在我个人使用的完整代码片段是:

    /* 文件树缩进线&笔记本区隔 CSS片段*/
    .sy__file .b3-list-item__toggle {
       padding-left:8px !important;
       padding-right:1px;
       color:#899fad; 
    }
    
    .sy__file .b3-list-item__icon {
    margin-left:0px;
    margin-right:0px;
    padding:0px 0px;
    transform:scale(0.7);
    }
    
    .sy__file .b3-list.b3-list--background ul>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 #5f7a8c;
        overflow: hidden;
    }
    
    2 回复
  • 其他回帖
  • 我把笔记本区隔的颜色改成 #5f7a8c ,那个框框就不会太显眼了

    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
  • toy 主题和 cliff-dark 都有

  • 查看全部回帖

推荐标签 标签

  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 72 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 26 关注
  • 域名

    域名(Domain Name),简称域名、网域,是由一串用点分隔的名字组成的 Internet 上某一台计算机或计算机组的名称,用于在数据传输时标识计算机的电子方位(有时也指地理位置)。

    43 引用 • 208 回帖
  • JRebel

    JRebel 是一款 Java 虚拟机插件,它使得 Java 程序员能在不进行重部署的情况下,即时看到代码的改变对一个应用程序带来的影响。

    26 引用 • 78 回帖 • 664 关注
  • 脑图

    脑图又叫思维导图,是表达发散性思维的有效图形思维工具 ,它简单却又很有效,是一种实用性的思维工具。

    26 引用 • 84 回帖
  • 微软

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

    8 引用 • 44 回帖
  • OpenResty

    OpenResty 是一个基于 NGINX 与 Lua 的高性能 Web 平台,其内部集成了大量精良的 Lua 库、第三方模块以及大多数的依赖项。用于方便地搭建能够处理超高并发、扩展性极高的动态 Web 应用、Web 服务和动态网关。

    17 引用 • 40 关注
  • RabbitMQ

    RabbitMQ 是一个开源的 AMQP 实现,服务器端用 Erlang 语言编写,支持多种语言客户端,如:Python、Ruby、.NET、Java、C、PHP、ActionScript 等。用于在分布式系统中存储转发消息,在易用性、扩展性、高可用性等方面表现不俗。

    49 引用 • 60 回帖 • 364 关注
  • SOHO

    为成为自由职业者在家办公而努力吧!

    7 引用 • 55 回帖 • 18 关注
  • WebClipper

    Web Clipper 是一款浏览器剪藏扩展,它可以帮助你把网页内容剪藏到本地。

    3 引用 • 9 回帖
  • PHP

    PHP(Hypertext Preprocessor)是一种开源脚本语言。语法吸收了 C 语言、 Java 和 Perl 的特点,主要适用于 Web 开发领域,据说是世界上最好的编程语言。

    179 引用 • 407 回帖 • 488 关注
  • App

    App(应用程序,Application 的缩写)一般指手机软件。

    91 引用 • 384 回帖
  • Swift

    Swift 是苹果于 2014 年 WWDC(苹果开发者大会)发布的开发语言,可与 Objective-C 共同运行于 Mac OS 和 iOS 平台,用于搭建基于苹果平台的应用程序。

    36 引用 • 37 回帖 • 529 关注
  • WebSocket

    WebSocket 是 HTML5 中定义的一种新协议,它实现了浏览器与服务器之间的全双工通信(full-duplex)。

    48 引用 • 206 回帖 • 334 关注
  • CongSec

    本标签主要用于分享网络空间安全专业的学习笔记

    1 引用 • 1 回帖 • 9 关注
  • JSON

    JSON (JavaScript Object Notation)是一种轻量级的数据交换格式。易于人类阅读和编写。同时也易于机器解析和生成。

    52 引用 • 190 回帖
  • HHKB

    HHKB 是富士通的 Happy Hacking 系列电容键盘。电容键盘即无接点静电电容式键盘(Capacitive Keyboard)。

    5 引用 • 74 回帖 • 471 关注
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 4 关注
  • 微服务

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

    96 引用 • 155 回帖 • 1 关注
  • 心情

    心是产生任何想法的源泉,心本体会陷入到对自己本体不能理解的状态中,因为心能产生任何想法,不能分出对错,不能分出自己。

    59 引用 • 369 回帖
  • H2

    H2 是一个开源的嵌入式数据库引擎,采用 Java 语言编写,不受平台的限制,同时 H2 提供了一个十分方便的 web 控制台用于操作和管理数据库内容。H2 还提供兼容模式,可以兼容一些主流的数据库,因此采用 H2 作为开发期的数据库非常方便。

    11 引用 • 54 回帖 • 654 关注
  • 电影

    这是一个不能说的秘密。

    120 引用 • 599 回帖
  • Facebook

    Facebook 是一个联系朋友的社交工具。大家可以通过它和朋友、同事、同学以及周围的人保持互动交流,分享无限上传的图片,发布链接和视频,更可以增进对朋友的了解。

    4 引用 • 15 回帖 • 453 关注
  • Node.js

    Node.js 是一个基于 Chrome JavaScript 运行时建立的平台, 用于方便地搭建响应速度快、易于扩展的网络应用。Node.js 使用事件驱动, 非阻塞 I/O 模型而得以轻量和高效。

    139 引用 • 269 回帖 • 43 关注
  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 536 关注
  • FlowUs

    FlowUs.息流 个人及团队的新一代生产力工具。

    让复杂的信息管理更轻松、自由、充满创意。

    1 引用 • 1 关注
  • PWA

    PWA(Progressive Web App)是 Google 在 2015 年提出、2016 年 6 月开始推广的项目。它结合了一系列现代 Web 技术,在网页应用中实现和原生应用相近的用户体验。

    14 引用 • 69 回帖 • 154 关注