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

🙏 🙏 🙏

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

🙏 🙏 🙏

  • 思源笔记

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

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

    22250 引用 • 88929 回帖
  • Q&A

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

    8073 引用 • 36877 回帖 • 162 关注

相关帖子

被采纳的回答
  • 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
没事别关注我, 因为发帖需要更多积分 香港

推荐标签 标签

  • 设计模式

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

    200 引用 • 120 回帖
  • Linux

    Linux 是一套免费使用和自由传播的类 Unix 操作系统,是一个基于 POSIX 和 Unix 的多用户、多任务、支持多线程和多 CPU 的操作系统。它能运行主要的 Unix 工具软件、应用程序和网络协议,并支持 32 位和 64 位硬件。Linux 继承了 Unix 以网络为核心的设计思想,是一个性能稳定的多用户网络操作系统。

    943 引用 • 943 回帖
  • 书籍

    宋真宗赵恒曾经说过:“书中自有黄金屋,书中自有颜如玉。”

    77 引用 • 390 回帖
  • Eclipse

    Eclipse 是一个开放源代码的、基于 Java 的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。

    75 引用 • 258 回帖 • 617 关注
  • uTools

    uTools 是一个极简、插件化、跨平台的现代桌面软件。通过自由选配丰富的插件,打造你得心应手的工具集合。

    6 引用 • 14 回帖
  • 反馈

    Communication channel for makers and users.

    123 引用 • 911 回帖 • 243 关注
  • Vim

    Vim 是类 UNIX 系统文本编辑器 Vi 的加强版本,加入了更多特性来帮助编辑源代码。Vim 的部分增强功能包括文件比较(vimdiff)、语法高亮、全面的帮助系统、本地脚本(Vimscript)和便于选择的可视化模式。

    29 引用 • 66 回帖 • 2 关注
  • flomo

    flomo 是新一代 「卡片笔记」 ,专注在碎片化时代,促进你的记录,帮你积累更多知识资产。

    5 引用 • 107 回帖
  • 房星科技

    房星网,我们不和没有钱的程序员谈理想,我们要让程序员又有理想又有钱。我们有雄厚的房地产行业线下资源,遍布昆明全城的 100 家门店、四千地产经纪人是我们坚实的后盾。

    6 引用 • 141 回帖 • 586 关注
  • WebClipper

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

    3 引用 • 9 回帖
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • GAE

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

    14 引用 • 42 回帖 • 762 关注
  • CSS

    CSS(Cascading Style Sheet)“层叠样式表”是用于控制网页样式并允许将样式信息与网页内容分离的一种标记性语言。

    197 引用 • 549 回帖
  • jQuery

    jQuery 是一套跨浏览器的 JavaScript 库,强化 HTML 与 JavaScript 之间的操作。由 John Resig 在 2006 年 1 月的 BarCamp NYC 上释出第一个版本。全球约有 28% 的网站使用 jQuery,是非常受欢迎的 JavaScript 库。

    63 引用 • 134 回帖 • 727 关注
  • Oracle

    Oracle(甲骨文)公司,全称甲骨文股份有限公司(甲骨文软件系统有限公司),是全球最大的企业级软件公司,总部位于美国加利福尼亚州的红木滩。1989 年正式进入中国市场。2013 年,甲骨文已超越 IBM,成为继 Microsoft 后全球第二大软件公司。

    105 引用 • 127 回帖 • 389 关注
  • 区块链

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

    91 引用 • 751 回帖
  • OpenResty

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

    17 引用 • 41 关注
  • 百度

    百度(Nasdaq:BIDU)是全球最大的中文搜索引擎、最大的中文网站。2000 年 1 月由李彦宏创立于北京中关村,致力于向人们提供“简单,可依赖”的信息获取方式。“百度”二字源于中国宋朝词人辛弃疾的《青玉案·元夕》词句“众里寻他千百度”,象征着百度对中文信息检索技术的执著追求。

    63 引用 • 785 回帖 • 177 关注
  • CSDN

    CSDN (Chinese Software Developer Network) 创立于 1999 年,是中国的 IT 社区和服务平台,为中国的软件开发者和 IT 从业者提供知识传播、职业发展、软件开发等全生命周期服务,满足他们在职业发展中学习及共享知识和信息、建立职业发展社交圈、通过软件开发实现技术商业化等刚性需求。

    14 引用 • 155 回帖
  • Flume

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

    9 引用 • 6 回帖 • 628 关注
  • C++

    C++ 是在 C 语言的基础上开发的一种通用编程语言,应用广泛。C++ 支持多种编程范式,面向对象编程、泛型编程和过程化编程。

    107 引用 • 153 回帖
  • RabbitMQ

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

    49 引用 • 60 回帖 • 360 关注
  • Angular

    AngularAngularJS 的新版本。

    26 引用 • 66 回帖 • 537 关注
  • Typecho

    Typecho 是一款博客程序,它在 GPLv2 许可证下发行,基于 PHP 构建,可以运行在各种平台上,支持多种数据库(MySQL、PostgreSQL、SQLite)。

    12 引用 • 65 回帖 • 441 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    325 引用 • 1395 回帖 • 1 关注
  • 旅游

    希望你我能在旅途中找到人生的下一站。

    90 引用 • 899 回帖 • 3 关注
  • 导航

    各种网址链接、内容导航。

    39 引用 • 170 回帖