[js] 替换原始 跳转到开头和末尾 快捷键效果

操作&效果

原有效果: 不管光标在哪里, 使用 ctrl+homnectrl+end 都是跳转到整个文档的开头和结尾

修改后效果:

  1. 当光标在代码块中间的时候, 使用 ctrl+homnectrl+end 跳转到代码块的开头和结尾
  2. 当光标在代码块开头和结尾的时候, 跳转到整个文档的开头和结尾
  3. 当光标在非代码块的时候, 跳转到整个文档的开头和结尾

js 代码

(()=>{ // 获取光标所在的元素 function getElementAtCursor() { const selection = window.getSelection(); if (selection.rangeCount > 0) { const range = selection.getRangeAt(0); const startContainer = range.startContainer; // 如果是文本节点,获取其父元素 const element = startContainer.nodeType === 3 ? startContainer.parentNode : startContainer; return element; } return null; // 如果没有选中内容或光标位置无效 } // 当前块是否是代码块 function getCodeBlockDfs(ele) { if (ele.classList.contains('protyle-wysiwyg')) { return null } if (ele.classList.contains('hljs')) { return ele } return getCodeBlockDfs(ele.parentElement) } async function handle_goto_home(event, element) { if (!element) { return; } element = getCodeBlockDfs(element) if (element == null) { console.log("[跳转开头] 所在位置不是代码块, 使用默认功能") return; } // 找到代码块的第一个子元素, 用于判断 let firstChild = element.querySelector('[contenteditable="true"]')?.firstChild if (firstChild == null) { console.log("[跳转开头] 子元素寻找失败, 使用默认功能") return; } // 获取当前的 Selection 对象 const selection = window.getSelection(); // 获取选择的范围 const range = selection.getRangeAt(0); // 判断光标是否在第一个子元素的开头 if (range.startContainer !== firstChild || range.startOffset !== 0) { if (range.startContainer !== firstChild) { console.log("[跳转开头] 不在第一个子元素附近, 功能生效") } else if (range.startOffset !== 0) { console.log("[跳转开头] 不在第一个子元素的开头, 功能生效") } event.preventDefault(); // 防止快捷键默认行为 event.stopPropagation(); // 停止事件传播 // 如果不在,移动到最前面 range.selectNodeContents(firstChild); range.collapse(true); selection.removeAllRanges(); selection.addRange(range); } else { console.log("[跳转开头] 已经在最开头了, 使用默认功能") } } async function handle_goto_end(event, element) { if (!element) { return; } element = getCodeBlockDfs(element) if (element == null) { console.log("[跳转末尾] 所在位置不是代码块, 使用默认功能") return; } // 找到代码块的第一个子元素, 用于判断 let lastChild = element.querySelector('[contenteditable="true"]')?.lastChild if (lastChild == null) { console.log("[跳转末尾] 子元素寻找失败, 使用默认功能") return; } // 获取当前的 Selection 对象 const selection = window.getSelection(); // 获取选择的范围 const range = selection.getRangeAt(0); // 判断光标是否在第一个子元素的开头 if (range.startContainer !== lastChild || range.startOffset !== lastChild.textContent.length) { if (range.startContainer !== lastChild) { console.log("[跳转末尾] 不在最后一个子元素附近, 功能生效") } else if (range.startOffset !== lastChild.textContent.length) { console.log("[跳转末尾] 不在最后一个子元素的末尾, 功能生效") } event.preventDefault(); // 防止快捷键默认行为 event.stopPropagation(); // 停止事件传播 // 如果不在,移动到最前面 range.selectNodeContents(lastChild); range.collapse(false); selection.removeAllRanges(); selection.addRange(range); } else { console.log("[跳转末尾] 已经在代码块最末尾了, 使用默认功能") } } // 事件监听 document.addEventListener('keydown', async (event) => { let element = getElementAtCursor(); // event.preventDefault(); // 防止快捷键默认行为 // event.stopPropagation(); // 停止事件传播 if (event.ctrlKey && !event.shiftKey && !event.altKey && event.key.toLowerCase() === 'home') { // 判断是否需要处理 跳转到代码块开头, 并处理 handle_goto_home(event, element); } else if (event.ctrlKey && !event.shiftKey && !event.altKey && event.key.toLowerCase() === 'end') { // 判断是否需要处理 跳转到代码块末尾, 并处理 handle_goto_end(event, element); } }); })()
  • 思源笔记

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

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

    24742 引用 • 101646 回帖
  • 代码片段

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

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

    132 引用 • 876 回帖 • 4 关注

相关帖子

欢迎来到这里!

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

注册 关于
请输入回帖内容 ...
  • wilsons 1 赞同

    trollface 嗯,都是不习惯的缘故,看习惯就好了,我以前也经常用蛇形风格,自从用了驼峰,蛇形不习惯了。

  • 其他回帖
  • EmberSky

    有没有一种可能, 这是 ai 写的

    我还是喜欢下划线, 看着直观, 但是 ai 生成的 js 代码, 都是驼峰, 我懒得改了

    所以现在是两种混在一起

    1 回复
  • 😄 下划线我看着眼花,貌似驼峰更流行。

    1 回复
  • EmberSky

    巧了, 驼峰看的我眼花

    1 回复
  • 查看全部回帖
EmberSky
如果感觉我的回答对你有帮助, 请点击 感谢 支持一下, 谢谢! 杭州

推荐标签 标签

  • API

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

    79 引用 • 431 回帖
  • Vim

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

    29 引用 • 66 回帖 • 3 关注
  • Flume

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

    9 引用 • 6 回帖 • 652 关注
  • Hexo

    Hexo 是一款快速、简洁且高效的博客框架,使用 Node.js 编写。

    22 引用 • 148 回帖 • 11 关注
  • Wide

    Wide 是一款基于 Web 的 Go 语言 IDE。通过浏览器就可以进行 Go 开发,并有代码自动完成、查看表达式、编译反馈、Lint、实时结果输出等功能。

    欢迎访问我们运维的实例: https://wide.b3log.org

    30 引用 • 218 回帖 • 642 关注
  • Scala

    Scala 是一门多范式的编程语言,集成面向对象编程和函数式编程的各种特性。

    13 引用 • 11 回帖 • 157 关注
  • 互联网

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

    99 引用 • 367 回帖
  • Swift

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

    36 引用 • 37 回帖 • 544 关注
  • 生活

    生活是指人类生存过程中的各项活动的总和,范畴较广,一般指为幸福的意义而存在。生活实际上是对人生的一种诠释。生活包括人类在社会中与自己息息相关的日常活动和心理影射。

    230 引用 • 1454 回帖
  • 心情

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

    59 引用 • 369 回帖
  • 一些有用的避坑指南。

    69 引用 • 93 回帖
  • FFmpeg

    FFmpeg 是一套可以用来记录、转换数字音频、视频,并能将其转化为流的开源计算机程序。

    23 引用 • 32 回帖
  • Outlook
    1 引用 • 5 回帖
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    169 引用 • 1527 回帖
  • Gzip

    gzip (GNU zip)是 GNU 自由软件的文件压缩程序。我们在 Linux 中经常会用到后缀为 .gz 的文件,它们就是 Gzip 格式的。现今已经成为互联网上使用非常普遍的一种数据压缩格式,或者说一种文件格式。

    9 引用 • 12 回帖 • 169 关注
  • 支付宝

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

    29 引用 • 347 回帖
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖
  • Quicker

    Quicker 您的指尖工具箱!操作更少,收获更多!

    36 引用 • 155 回帖
  • CSS

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

    198 引用 • 541 回帖 • 2 关注
  • Access
    1 引用 • 3 回帖 • 7 关注
  • 又拍云

    又拍云是国内领先的 CDN 服务提供商,国家工信部认证通过的“可信云”,乌云众测平台认证的“安全云”,为移动时代的创业者提供新一代的 CDN 加速服务。

    20 引用 • 37 回帖 • 570 关注
  • 学习

    “梦想从学习开始,事业从实践起步” —— 习近平

    172 引用 • 515 回帖
  • 人工智能

    人工智能(Artificial Intelligence)是研究、开发用于模拟、延伸和扩展人的智能的理论、方法、技术及应用系统的一门技术科学。

    157 引用 • 289 回帖
  • 京东

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

    14 引用 • 102 回帖 • 319 关注
  • 机器学习

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

    83 引用 • 37 回帖
  • JetBrains

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

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

    Swagger 是一款非常流行的 API 开发工具,它遵循 OpenAPI Specification(这是一种通用的、和编程语言无关的 API 描述规范)。Swagger 贯穿整个 API 生命周期,如 API 的设计、编写文档、测试和部署。

    26 引用 • 35 回帖 • 2 关注