[js] 聚焦当前编辑元素块 - 禅模式

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

最近老是注意力不太集中,于是尝试写点脚本简化页面元素

当前隐藏了页面大部分元素后,整个页面就只剩编辑内容了,配合 Aris 主题,可以做到整个窗口只有一个块。

PixPin20241205202117.png

PixPin20241205202125.png

一些功能全用快捷键代替,或者设置透明度,通过鼠标移动到相应位置上显示。

PixPin20241205202140.png

不过这些小 css 片段不是重点,主要是用 gpt 写了个聚焦当前编辑块的 js

效果如下

PixPin20241205201840.gif

!(function () { // 初始化样式 const style = document.createElement("style"); style.textContent = ` /* 默认所有 data-node-id 块低透明度 */ div[data-node-id] { opacity: 0.82; transition: opacity 0.2s; } /* 高亮块样式 */ .highlighted-block { opacity: 1 !important; } `; document.head.appendChild(style); // 当前聚焦的块 let focusedBlock = null; // 设置高亮状态(包括父块) function highlightBlock(block) { if (!block || block === focusedBlock) return; // 如果已有聚焦块,移除其高亮 if (focusedBlock) { let parent = focusedBlock; while (parent) { parent.classList.remove("highlighted-block"); parent = parent.parentElement; } } // 设置新的高亮块 focusedBlock = block; let parent = block; while (parent) { parent.classList.add("highlighted-block"); parent = parent.parentElement; } } // 获取光标所在的块 function getCursorBlock() { const selection = document.getSelection(); if (!selection.rangeCount) return null; const range = selection.getRangeAt(0); return range.startContainer.closest?.("div[data-node-id]") || null; } // 获取上下键切换的块 function getBlockByKey(direction) { if (!focusedBlock) return null; const allBlocks = Array.from(document.querySelectorAll('div[data-node-id]')); const currentIndex = allBlocks.indexOf(focusedBlock); if (currentIndex === -1) return null; if (direction === "up" && currentIndex > 0) { return allBlocks[currentIndex - 1]; } else if (direction === "down" && currentIndex < allBlocks.length - 1) { return allBlocks[currentIndex + 1]; } return null; } // 监听键盘上下键事件 document.addEventListener("keydown", (event) => { if (event.key === "ArrowUp" || event.key === "ArrowDown") { const direction = event.key === "ArrowUp" ? "up" : "down"; const nextBlock = getBlockByKey(direction); if (nextBlock) { highlightBlock(nextBlock); } } }); // 初次加载时高亮可视范围内位于中心的块 document.addEventListener("DOMContentLoaded", () => { const wnd = document.querySelector('div[data-type="wnd"]'); if (wnd) { const firstBlock = wnd.querySelector('div[data-node-id]'); if (firstBlock) { highlightBlock(firstBlock); } } }); // 监听光标切换事件 document.addEventListener("selectionchange", () => { const block = getCursorBlock(); if (block) { highlightBlock(block); } }); // 监听点击事件,切换聚焦 document.addEventListener("click", (event) => { const target = event.target.closest("div[data-node-id]"); if (target) { highlightBlock(target); } }); })();
  • 代码片段

    代码片段分为 CSS 与 JS 两种代码,添加在 [设置 - 外观 - 代码片段] 中,这些代码会在思源笔记加载时自动执行,用于改善笔记的样式或功能。

    用户在该标签下分享代码片段时需在帖子标题前添加 [css] [js] 用于区分代码片段类型。

    177 引用 • 1255 回帖
  • 思源笔记

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

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

    25893 引用 • 107282 回帖
1 操作
xqh042 在 2024-12-05 21:11:35 更新了该帖

相关帖子

欢迎来到这里!

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

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

    当前有个问题,判断指针所在的块其实不太准,这块 ai 补全的代码没细看出漏子了。

    考虑了一下,先直接配合插件市场里的打字机插件使用吧(当前似乎从段落块外切换到列表内的折叠块都有聚焦到未显示的折叠块上的问题),后面再看看有没有动力(需求)改吧 😂

  • 其他回帖
  • xqh042

    感谢分享,这个行高亮的效果我一开始写的效果差不多 😄 但因为觉得鼠标移动会出现频繁的切换高亮块的情况,进,加上我更许要的是静态和编辑状态下的高亮,所以就修改成了现在的效果。

    费眼的情况可以尝试调整一下透明度临时处理(

  • xqh042

    欸,才发现有这么一个功能。刚才搜了以下发现本体里似乎叫作全屏切换,感觉这个功能名字似乎不够直观(容易和 f11 全屏理解冲突?),新开了个工作空间尝试了一下,发现效果不错 👍 如果早知道有这个功能应该会考虑将当前的简化样式的一部分移到这一块,谢谢分享 😄

    PixPin20241205205219.png

    PixPin20241205210055.png

  • 感谢分享,感觉虚化文字部分有点费眼,这个行高亮的代码片段也可以用。

    行高亮

    1 回复
  • 查看全部回帖

推荐标签 标签

  • 自由行
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    211 引用 • 358 回帖
  • WebClipper

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

    3 引用 • 9 回帖 • 1 关注
  • Facebook

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

    4 引用 • 15 回帖 • 451 关注
  • sts
    2 引用 • 2 回帖 • 239 关注
  • 知乎

    知乎是网络问答社区,连接各行各业的用户。用户分享着彼此的知识、经验和见解,为中文互联网源源不断地提供多种多样的信息。

    10 引用 • 66 回帖 • 1 关注
  • 周末

    星期六到星期天晚,实行五天工作制后,指每周的最后两天。再过几年可能就是三天了。

    14 引用 • 297 回帖
  • 印象笔记
    3 引用 • 16 回帖 • 1 关注
  • iOS

    iOS 是由苹果公司开发的移动操作系统,最早于 2007 年 1 月 9 日的 Macworld 大会上公布这个系统,最初是设计给 iPhone 使用的,后来陆续套用到 iPod touch、iPad 以及 Apple TV 等产品上。iOS 与苹果的 Mac OS X 操作系统一样,属于类 Unix 的商业操作系统。

    89 引用 • 150 回帖
  • 微信

    腾讯公司 2011 年 1 月 21 日推出的一款手机通讯软件。用户可以通过摇一摇、搜索号码、扫描二维码等添加好友和关注公众平台,同时可以将自己看到的精彩内容分享到微信朋友圈。

    133 引用 • 796 回帖
  • 机器学习

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

    77 引用 • 37 回帖
  • Linux

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

    954 引用 • 944 回帖
  • 锤子科技

    锤子科技(Smartisan)成立于 2012 年 5 月,是一家制造移动互联网终端设备的公司,公司的使命是用完美主义的工匠精神,打造用户体验一流的数码消费类产品(智能手机为主),改善人们的生活质量。

    4 引用 • 31 回帖
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    10 引用 • 15 回帖 • 7 关注
  • Java

    Java 是一种可以撰写跨平台应用软件的面向对象的程序设计语言,是由 Sun Microsystems 公司于 1995 年 5 月推出的。Java 技术具有卓越的通用性、高效性、平台移植性和安全性。

    3201 引用 • 8216 回帖 • 1 关注
  • 开源

    Open Source, Open Mind, Open Sight, Open Future!

    411 引用 • 3588 回帖
  • Logseq

    Logseq 是一个隐私优先、开源的知识库工具。

    Logseq is a joyful, open-source outliner that works on top of local plain-text Markdown and Org-mode files. Use it to write, organize and share your thoughts, keep your to-do list, and build your own digital garden.

    7 引用 • 69 回帖 • 5 关注
  • SQLite

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

    4 引用 • 7 回帖 • 7 关注
  • JetBrains

    JetBrains 是一家捷克的软件开发公司,该公司位于捷克的布拉格,并在俄国的圣彼得堡及美国麻州波士顿都设有办公室,该公司最为人所熟知的产品是 Java 编程语言开发撰写时所用的集成开发环境:IntelliJ IDEA

    18 引用 • 54 回帖 • 1 关注
  • Elasticsearch

    Elasticsearch 是一个基于 Lucene 的搜索服务器。它提供了一个分布式多用户能力的全文搜索引擎,基于 RESTful 接口。Elasticsearch 是用 Java 开发的,并作为 Apache 许可条款下的开放源码发布,是当前流行的企业级搜索引擎。设计用于云计算中,能够达到实时搜索,稳定,可靠,快速,安装使用方便。

    117 引用 • 99 回帖 • 199 关注
  • Flutter

    Flutter 是谷歌的移动 UI 框架,可以快速在 iOS 和 Android 上构建高质量的原生用户界面。 Flutter 可以与现有的代码一起工作,它正在被越来越多的开发者和组织使用,并且 Flutter 是完全免费、开源的。

    39 引用 • 92 回帖 • 7 关注
  • WiFiDog

    WiFiDog 是一套开源的无线热点认证管理工具,主要功能包括:位置相关的内容递送;用户认证和授权;集中式网络监控。

    1 引用 • 7 回帖 • 612 关注
  • API

    应用程序编程接口(Application Programming Interface)是一些预先定义的函数,目的是提供应用程序与开发人员基于某软件或硬件得以访问一组例程的能力,而又无需访问源码,或理解内部工作机制的细节。

    79 引用 • 431 回帖
  • Openfire

    Openfire 是开源的、基于可拓展通讯和表示协议 (XMPP)、采用 Java 编程语言开发的实时协作服务器。Openfire 的效率很高,单台服务器可支持上万并发用户。

    6 引用 • 7 回帖 • 119 关注
  • Solidity

    Solidity 是一种智能合约高级语言,运行在 [以太坊] 虚拟机(EVM)之上。它的语法接近于 JavaScript,是一种面向对象的语言。

    3 引用 • 18 回帖 • 433 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2388 回帖
  • SVN

    SVN 是 Subversion 的简称,是一个开放源代码的版本控制系统,相较于 RCS、CVS,它采用了分支管理系统,它的设计目标就是取代 CVS。

    29 引用 • 98 回帖 • 691 关注