JavaScript网页选区高亮保持技巧
网页交互中,用户选中文本时,浏览器通常以蓝色高亮显示。然而,页面失去焦点后,高亮可能会消失变灰。本文介绍如何用JavaScript代码,在页面失去焦点后保持选区蓝色高亮显示。
问题: 用户选中文本(例如,文本输入框或
解决方案: 浏览器没有直接修改选区颜色属性的API。解决方法是保存并恢复选区信息。在页面失去焦点前保存选区信息,需要时再恢复。
以下代码片段演示如何通过保存和恢复Range对象来实现:
立即学习“Java免费学习笔记(深入)”;
let lastRange = null; const txt = document.getElementById('myTextbox'); // 将'myTextbox'替换为你的文本框ID txt.onkeyup = function(e) { const selection = window.getSelection(); lastRange = selection.rangeCount > 0 ? selection.getRangeAt(0) : null; }; const btn = document.getElementById('restoreButton'); // 将'restoreButton'替换为你的按钮ID btn.onclick = () => { const selection = window.getSelection(); selection.removeAllRanges(); if (lastRange) { selection.addRange(lastRange); } };
这段代码在onkeyup事件中,使用window.getSelection()获取当前选区,并用getRangeAt(0)获取第一个Range对象,保存到lastRange变量。 点击按钮(btn)时,代码清除所有选区,然后使用selection.addRange(lastRange)重新添加保存的Range对象,恢复之前的选区。
重要说明: 这并非直接改变选区颜色,而是通过重建选区来间接恢复高亮显示。选区颜色由浏览器决定,JavaScript无法直接控制。 此方法的本质是重新创建选区,而非修改颜色。 请确保你的html中包含一个ID为myTextbox的文本框和一个ID为restoreButton的按钮。
© 版权声明
文章版权归作者所有,未经允许请勿转载。
THE END