希望鼠标悬浮自动展开大纲

🙏 🙏 🙏

大佬们能否写个代码片段,当鼠标移动到大纲的时候,大纲对应的内容自动展开,当鼠标移出对应的内容时恢复原来状态

🙏 🙏 🙏

  • 思源笔记

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

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

    22919 引用 • 92145 回帖
  • Q&A

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

    8401 引用 • 38284 回帖 • 156 关注
被采纳的回答
  • wilsons 1

    只展开一级标题,当鼠标移动到对应处时自动展开一级标题的内容,移开时自动收回

    按照这个需求,我实现了这个功能,不知能否是你想要的效果

    效果

    r64.gif

    代码

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • cxg318

    1 到 6 级标题,做成 markdown 超链接或者引用,就好了啊.

  • temacc0531
    1 回复
  • 楼主的需求应该是自动展开大纲子层级

    1 回复
  • CongSec

    还得是你懂我,像这种比较长的大纲,全部展开又太长了,只展开一级标题又太短了,我想的是只展开一级标题,当鼠标移动到对应处时自动展开一级标题的内容,移开时自动收回trollface

    image.png

    2 回复
  • Yvain

    这个功能提的好,我也有同样需求,有的大文档目录太长了,每次都翻半天

  • 我让 GPT 辅助写了一个 JS 片段,基本能实现,但我感觉交互很奇怪:

    // 鼠标移动到大纲标题自动展开与折叠下级 JS片段
    
    setTimeout(() => {
        const headings = document.querySelectorAll('li.b3-list-item[data-type="NodeHeading"]');
    
        headings.forEach((heading) => {
            let hideTimeout;
            let removeTimeout;
            let isMouseInHeading = false; // 标志变量,跟踪鼠标是否在 heading 内
            let isMouseInSubMenu = false; // 标志变量,跟踪鼠标是否在子菜单内
    
            // 鼠标进入列表项
            heading.addEventListener('mouseenter', () => {
                isMouseInHeading = true; // 设置标志变量
                clearTimeout(removeTimeout); // 清除可能存在的移除定时器
    
                let nextElement = heading.nextElementSibling;
                if (nextElement && nextElement.tagName.toLowerCase() === 'ul') {
                    removeTimeout = setTimeout(() => {
                        if (isMouseInHeading) {
                            nextElement.classList.remove('fn__none');
                        }
                    }, 200); // 延迟 200ms 后再移除 fn__none
                }
            });
    
            // 鼠标离开列表项
            heading.addEventListener('mouseleave', () => {
                isMouseInHeading = false; // 更新标志变量
                hideTimeout = setTimeout(() => {
                    let nextElement = heading.nextElementSibling;
                    if (nextElement && nextElement.tagName.toLowerCase() === 'ul' && !isMouseInSubMenu) {
                        nextElement.classList.add('fn__none');
                    }
                }, 200); // 延迟 200ms 后再添加 fn__none
            });
    
            // 鼠标移动到 ul > li 上时,阻止 fn__none 添加
            let nextElement = heading.nextElementSibling;
            if (nextElement) {
                nextElement.querySelectorAll('li').forEach((ulItem) => {
                    ulItem.addEventListener('mouseenter', () => {
                        isMouseInSubMenu = true; // 更新标志变量
                        clearTimeout(hideTimeout); // 清除定时器,防止隐藏
                        clearTimeout(removeTimeout); // 清除移除定时器
                    });
    
                    ulItem.addEventListener('mouseleave', () => {
                        isMouseInSubMenu = false; // 更新标志变量
                        hideTimeout = setTimeout(() => {
                            if (nextElement) {
                                nextElement.classList.add('fn__none');
                            }
                        }, 200);
                    });
                });
            }
        });
    
    }, 1000);
    
    3 回复
  • CongSec

    你这个好像只能执行一次的 😂 ,而且鼠标移出标题后应该是恢复原来状态不是折叠

    ❤️

  • 这个 ai 这么牛逼还能知道思源的 html 吗,是啥 ai?这么厉害

    1 回复
  • wilsons 1 1 赞同 4 评论

    应该是作为上下文发给 ai 的 😄

    并且逻辑也是我想的,AI 的作用只是输出代码
    JeffreyChen
    @JeffreyChen 是哪个 ai?求推荐
    zxkmm
    @zxkmm 我是通过第三方 API 调用 gpt-4o-mini
    JeffreyChen 1
    @JeffreyChen 感谢,我去康康 gpt4o,之前没听说过这个模型
    zxkmm
  • wilsons 1 1 评论

    只展开一级标题,当鼠标移动到对应处时自动展开一级标题的内容,移开时自动收回

    按照这个需求,我实现了这个功能,不知能否是你想要的效果

    效果

    r64.gif

    代码

    4 回复
    好像使用不了,不知道是不是和文档树相关插件冲突了
    QQQorange
  • 好像使用不了,不知道是不是和文档树相关插件冲突了

  • Yvain

    这个脚本我在思源的代码片段里加载之后,没有作用哎,请问应该如何使用呢?

  • Oldbear

    为什么我添加了你的 js 代码却无法运行功能呢?我的版本的是 3.1.6

    1 回复
  • CongSec

    十分感谢大佬代码 ❤️ ❤️ ❤️

  • 不好意思,我是在升级到 3.1.7 后写的代码片段,所以在 3.1.7 测试通过,之前的版本不清楚,理论上应该没问题,建议升级到 3.1.7 后使用。

    @Yvain 放到 js 代码片段中即可,注意别忘了在代码片段右上角开启 js 代码片段。

    @QQQorange 请先在新空间测试,排除干扰项。

  • CongSec 1 评论

    我这边可以,但是评论区好像挺多不行的,以下是我的插件列表:日历热力图, 自定义块样式, 关系图增强, 导入工具, 替换背景图片, 文档高亮搜索, 数学增强, 侧边备注, 工具栏 Plus, Web 工具集成, 目录插件, 同步感知, 鸿蒙字体和 Twitter Emoji, 移除按钮, 番茄工具箱, 双击文档树, 文档层级导航, 网页视图

    1 回复
    版本是 3.16
    CongSec
  • Yvain

    佬的思维导图是怎么生成的呀

    1 回复
  • GloR

    感谢大佬的代码,试了一下能用,但有个小问题:就是一旦把某个标题折叠起来,好像就不能再展开了(因为鼠标一离开就自动折叠了)

    1 回复
  • 抱歉,设计如此,这是针对楼主的需求定制的,不是满足各种需求和情况的通用版

请输入回帖内容 ...
CongSec
新手可以看我发的求助帖以及汇总帖子,很有帮助的!_! 香港

推荐标签 标签

  • FreeMarker

    FreeMarker 是一款好用且功能强大的 Java 模版引擎。

    23 引用 • 20 回帖 • 464 关注
  • SQLite

    SQLite 是一个进程内的库,实现了自给自足的、无服务器的、零配置的、事务性的 SQL 数据库引擎。SQLite 是全世界使用最为广泛的数据库引擎。

    5 引用 • 7 回帖 • 4 关注
  • Rust

    Rust 是一门赋予每个人构建可靠且高效软件能力的语言。Rust 由 Mozilla 开发,最早发布于 2014 年 9 月。

    58 引用 • 22 回帖 • 3 关注
  • JWT

    JWT(JSON Web Token)是一种用于双方之间传递信息的简洁的、安全的表述性声明规范。JWT 作为一个开放的标准(RFC 7519),定义了一种简洁的,自包含的方法用于通信双方之间以 JSON 的形式安全的传递信息。

    20 引用 • 15 回帖 • 7 关注
  • BAE

    百度应用引擎(Baidu App Engine)提供了 PHP、Java、Python 的执行环境,以及云存储、消息服务、云数据库等全面的云服务。它可以让开发者实现自动地部署和管理应用,并且提供动态扩容和负载均衡的运行环境,让开发者不用考虑高成本的运维工作,只需专注于业务逻辑,大大降低了开发者学习和迁移的成本。

    19 引用 • 75 回帖 • 653 关注
  • webpack

    webpack 是一个用于前端开发的模块加载器和打包工具,它能把各种资源,例如 JS、CSS(less/sass)、图片等都作为模块来使用和处理。

    41 引用 • 130 回帖 • 255 关注
  • 智能合约

    智能合约(Smart contract)是一种旨在以信息化方式传播、验证或执行合同的计算机协议。智能合约允许在没有第三方的情况下进行可信交易,这些交易可追踪且不可逆转。智能合约概念于 1994 年由 Nick Szabo 首次提出。

    1 引用 • 11 回帖 • 3 关注
  • Redis

    Redis 是一个开源的使用 ANSI C 语言编写、支持网络、可基于内存亦可持久化的日志型、Key-Value 数据库,并提供多种语言的 API。从 2010 年 3 月 15 日起,Redis 的开发工作由 VMware 主持。从 2013 年 5 月开始,Redis 的开发由 Pivotal 赞助。

    286 引用 • 248 回帖 • 47 关注
  • HTML

    HTML5 是 HTML 下一个的主要修订版本,现在仍处于发展阶段。广义论及 HTML5 时,实际指的是包括 HTML、CSS 和 JavaScript 在内的一套技术组合。

    107 引用 • 295 回帖
  • 外包

    有空闲时间是接外包好呢还是学习好呢?

    26 引用 • 232 回帖 • 2 关注
  • Google

    Google(Google Inc.,NASDAQ:GOOG)是一家美国上市公司(公有股份公司),于 1998 年 9 月 7 日以私有股份公司的形式创立,设计并管理一个互联网搜索引擎。Google 公司的总部称作“Googleplex”,它位于加利福尼亚山景城。Google 目前被公认为是全球规模最大的搜索引擎,它提供了简单易用的免费服务。不作恶(Don't be evil)是谷歌公司的一项非正式的公司口号。

    49 引用 • 192 回帖
  • LeetCode

    LeetCode(力扣)是一个全球极客挚爱的高质量技术成长平台,想要学习和提升专业能力从这里开始,充足技术干货等你来啃,轻松拿下 Dream Offer!

    209 引用 • 72 回帖 • 1 关注
  • OnlyOffice
    4 引用 • 3 关注
  • Android

    Android 是一种以 Linux 为基础的开放源码操作系统,主要使用于便携设备。2005 年由 Google 收购注资,并拉拢多家制造商组成开放手机联盟开发改良,逐渐扩展到到平板电脑及其他领域上。

    334 引用 • 323 回帖 • 1 关注
  • QQ

    1999 年 2 月腾讯正式推出“腾讯 QQ”,在线用户由 1999 年的 2 人(马化腾和张志东)到现在已经发展到上亿用户了,在线人数超过一亿,是目前使用最广泛的聊天软件之一。

    45 引用 • 557 回帖 • 48 关注
  • 设计模式

    设计模式(Design pattern)代表了最佳的实践,通常被有经验的面向对象的软件开发人员所采用。设计模式是软件开发人员在软件开发过程中面临的一般问题的解决方案。这些解决方案是众多软件开发人员经过相当长的一段时间的试验和错误总结出来的。

    200 引用 • 120 回帖
  • OAuth

    OAuth 协议为用户资源的授权提供了一个安全的、开放而又简易的标准。与以往的授权方式不同之处是 oAuth 的授权不会使第三方触及到用户的帐号信息(如用户名与密码),即第三方无需使用用户的用户名与密码就可以申请获得该用户资源的授权,因此 oAuth 是安全的。oAuth 是 Open Authorization 的简写。

    36 引用 • 103 回帖 • 18 关注
  • AngularJS

    AngularJS 诞生于 2009 年,由 Misko Hevery 等人创建,后为 Google 所收购。是一款优秀的前端 JS 框架,已经被用于 Google 的多款产品当中。AngularJS 有着诸多特性,最为核心的是:MVC、模块化、自动化双向数据绑定、语义化标签、依赖注入等。2.0 版本后已经改名为 Angular。

    12 引用 • 50 回帖 • 481 关注
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    238 引用 • 224 回帖
  • danl
    144 关注
  • GAE

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

    14 引用 • 42 回帖 • 780 关注
  • 互联网

    互联网(Internet),又称网际网络,或音译因特网、英特网。互联网始于 1969 年美国的阿帕网,是网络与网络之间所串连成的庞大网络,这些网络以一组通用的协议相连,形成逻辑上的单一巨大国际网络。

    98 引用 • 344 回帖
  • DevOps

    DevOps(Development 和 Operations 的组合词)是一组过程、方法与系统的统称,用于促进开发(应用程序/软件工程)、技术运营和质量保障(QA)部门之间的沟通、协作与整合。

    51 引用 • 25 回帖 • 2 关注
  • 阿里云

    阿里云是阿里巴巴集团旗下公司,是全球领先的云计算及人工智能科技公司。提供云服务器、云数据库、云安全等云计算服务,以及大数据、人工智能服务、精准定制基于场景的行业解决方案。

    89 引用 • 345 回帖
  • 前端

    前端技术一般分为前端设计和前端开发,前端设计可以理解为网站的视觉设计,前端开发则是网站的前台代码实现,包括 HTML、CSS 以及 JavaScript 等。

    247 引用 • 1348 回帖
  • Windows

    Microsoft Windows 是美国微软公司研发的一套操作系统,它问世于 1985 年,起初仅仅是 Microsoft-DOS 模拟环境,后续的系统版本由于微软不断的更新升级,不但易用,也慢慢的成为家家户户人们最喜爱的操作系统。

    222 引用 • 474 回帖
  • H2

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

    11 引用 • 54 回帖 • 653 关注