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

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

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

当前隐藏了页面大部分元素后,整个页面就只剩编辑内容了,配合 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] 用于区分代码片段类型。

    199 引用 • 1421 回帖 • 2 关注
  • 思源笔记

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

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

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

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • 很棒!另外提一嘴,楼主试过思源自带的禅模式不。alt + Y (和楼主的禅模式不太一样的哈)

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

    行高亮

    1 回复
  • xqh042

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

    PixPin20241205205219.png

    PixPin20241205210055.png

  • xqh042

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

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

  • xqh042

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

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

推荐标签 标签

  • Vditor

    Vditor 是一款浏览器端的 Markdown 编辑器,支持所见即所得、即时渲染(类似 Typora)和分屏预览模式。它使用 TypeScript 实现,支持原生 JavaScript、Vue、React 和 Angular。

    373 引用 • 1858 回帖 • 1 关注
  • Solo

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

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

    1444 引用 • 10083 回帖 • 506 关注
  • Outlook
    1 引用 • 5 回帖 • 2 关注
  • 支付宝

    支付宝是全球领先的独立第三方支付平台,致力于为广大用户提供安全快速的电子支付/网上支付/安全支付/手机支付体验,及转账收款/水电煤缴费/信用卡还款/AA 收款等生活服务应用。

    29 引用 • 347 回帖
  • 星云链

    星云链是一个开源公链,业内简单的将其称为区块链上的谷歌。其实它不仅仅是区块链搜索引擎,一个公链的所有功能,它基本都有,比如你可以用它来开发部署你的去中心化的 APP,你可以在上面编写智能合约,发送交易等等。3 分钟快速接入星云链 (NAS) 测试网

    3 引用 • 16 回帖
  • Redis

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

    284 引用 • 248 回帖
  • Flutter

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

    39 引用 • 92 回帖 • 10 关注
  • 京东

    京东是中国最大的自营式电商企业,2015 年第一季度在中国自营式 B2C 电商市场的占有率为 56.3%。2014 年 5 月,京东在美国纳斯达克证券交易所正式挂牌上市(股票代码:JD),是中国第一个成功赴美上市的大型综合型电商平台,与腾讯、百度等中国互联网巨头共同跻身全球前十大互联网公司排行榜。

    14 引用 • 102 回帖 • 314 关注
  • OpenCV
    15 引用 • 36 回帖
  • IPFS

    IPFS(InterPlanetary File System,星际文件系统)是永久的、去中心化保存和共享文件的方法,这是一种内容可寻址、版本化、点对点超媒体的分布式协议。请浏览 IPFS 入门笔记了解更多细节。

    20 引用 • 245 回帖 • 232 关注
  • JVM

    JVM(Java Virtual Machine)Java 虚拟机是一个微型操作系统,有自己的硬件构架体系,还有相应的指令系统。能够识别 Java 独特的 .class 文件(字节码),能够将这些文件中的信息读取出来,使得 Java 程序只需要生成 Java 虚拟机上的字节码后就能在不同操作系统平台上进行运行。

    180 引用 • 120 回帖 • 3 关注
  • Oracle

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

    107 引用 • 127 回帖 • 344 关注
  • SQLite

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

    4 引用 • 7 回帖
  • 服务器

    服务器,也称伺服器,是提供计算服务的设备。由于服务器需要响应服务请求,并进行处理,因此一般来说服务器应具备承担服务并且保障服务的能力。

    125 引用 • 585 回帖 • 1 关注
  • App

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

    91 引用 • 384 回帖
  • Ant-Design

    Ant Design 是服务于企业级产品的设计体系,基于确定和自然的设计价值观上的模块化解决方案,让设计者和开发者专注于更好的用户体验。

    17 引用 • 23 回帖 • 2 关注
  • BAE

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

    19 引用 • 75 回帖 • 680 关注
  • MongoDB

    MongoDB(来自于英文单词“Humongous”,中文含义为“庞大”)是一个基于分布式文件存储的数据库,由 C++ 语言编写。旨在为应用提供可扩展的高性能数据存储解决方案。MongoDB 是一个介于关系数据库和非关系数据库之间的产品,是非关系数据库当中功能最丰富,最像关系数据库的。它支持的数据结构非常松散,是类似 JSON 的 BSON 格式,因此可以存储比较复杂的数据类型。

    91 引用 • 59 回帖 • 1 关注
  • 小薇

    小薇是一个用 Java 写的 QQ 聊天机器人 Web 服务,可以用于社群互动。

    由于 Smart QQ 从 2019 年 1 月 1 日起停止服务,所以该项目也已经停止维护了!

    35 引用 • 468 回帖 • 764 关注
  • Ngui

    Ngui 是一个 GUI 的排版显示引擎和跨平台的 GUI 应用程序开发框架,基于
    Node.js / OpenGL。目标是在此基础上开发 GUI 应用程序可拥有开发 WEB 应用般简单与速度同时兼顾 Native 应用程序的性能与体验。

    7 引用 • 9 回帖 • 407 关注
  • 博客

    记录并分享人生的经历。

    273 引用 • 2389 回帖
  • GitHub

    GitHub 于 2008 年上线,目前,除了 Git 代码仓库托管及基本的 Web 管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。正因为这些功能所提供的便利,又经过长期的积累,GitHub 的用户活跃度很高,在开源世界里享有深远的声望,并形成了社交化编程文化(Social Coding)。

    209 引用 • 2040 回帖
  • 招聘

    哪里都缺人,哪里都不缺人。

    188 引用 • 1057 回帖 • 2 关注
  • TextBundle

    TextBundle 文件格式旨在应用程序之间交换 Markdown 或 Fountain 之类的纯文本文件时,提供更无缝的用户体验。

    1 引用 • 2 回帖 • 83 关注
  • Lute

    Lute 是一款结构化的 Markdown 引擎,支持 Go 和 JavaScript。

    29 引用 • 202 回帖 • 29 关注
  • B3log

    B3log 是一个开源组织,名字来源于“Bulletin Board Blog”缩写,目标是将独立博客与论坛结合,形成一种新的网络社区体验,详细请看 B3log 构思。目前 B3log 已经开源了多款产品:SymSoloVditor思源笔记

    1062 引用 • 3455 回帖 • 149 关注
  • 友情链接

    确认过眼神后的灵魂连接,站在链在!

    24 引用 • 373 回帖 • 2 关注