js让光标选择节点中部分文本

简介: js让光标选择节点中部分文本

我走得很慢,但我从不后退。——林肯

如题,代码:

<!DOCTYPE html>
<html>
<head>
    <meta charset="utf-8">
    <title></title>
</head>
<body>
    <div id="container">ruben</div>
    <button>r</button>
    <button>u</button>
    <button>b</button>
    <button>e</button>
    <button>n</button>
    <button>ALL</button>
    <script>
        // 获取所有按钮
        document.querySelectorAll("button").forEach(btn => {
            // 给按钮绑定点击事件
            btn.addEventListener('click', function(event) {
                // 获取按钮内的文本
                const btnText = event.target.textContent
                // 获取需要选中的节点
                const container = document.querySelector("#container")
                // 获取节点内文本
                const contentText = container.textContent
                // 获取selection对象
                const selection = window.getSelection()
                // 移除上次选择结果
                selection.removeAllRanges()
                // 创建范围对象
                const range = document.createRange()
                if (contentText.includes(btnText)) {
                    // 如果节点文本包含按钮内文本,就获取节点中的文本节点
                    const textNode = container.firstChild
                    // 获取 按钮内文本 在 节点文本 中 文本节点 的下标
                    const offsetStart = contentText.indexOf(btnText)
                    // 设置范围起始点
                    range.setStart(textNode, offsetStart)
                    // 设置范围结束点
                    range.setEnd(textNode, offsetStart + btnText.length)
                } else {
                    // 如果内容不包含按钮中的内容,就直接选中整个节点
                    range.selectNode(container)
                }
                // 选中范围
                selection.addRange(range)
            })
        })
</script>
</body></html>


效果:

RangeMDNhttps://developer.mozilla.org/zh-CN/docs/Web/API/Range/setStart

Range.setStart()

Range.setStart() 方法用于设置 Range的开始位置。

如果起始节点类型是 TextCommentCDATASection之一,那么 startOffset 指的是从起始节点算起字符的偏移量。 对于其他 Node 类型节点,startOffset 是指从起始结点开始算起子节点的偏移量。

如果设置的起始位点在结束点之下(在文档中的位置),将会导致选区折叠,起始点和结束点都会被设置为指定的起始位置。

SelectionMDNhttps://developer.mozilla.org/zh-CN/docs/Web/API/Selection

相关文章
|
3月前
|
JavaScript 前端开发 索引
JavaScript HTML DOM 节点列表
JavaScript HTML DOM 节点列表
24 5
|
3月前
|
JavaScript 前端开发
JavaScript HTML DOM 元素 (节点)
JavaScript HTML DOM 元素 (节点)
29 2
|
2月前
|
JavaScript
js 特殊文本的判断
js 特殊文本的判断
41 0
|
5月前
|
前端开发 JavaScript
文本,wangEditor5展示HTML无样式,wangEditor5如何看源码,Ctrl + U看CSS文件,代码高亮,Prism.js可以实现,解决方法,参考网页源代码的写法
文本,wangEditor5展示HTML无样式,wangEditor5如何看源码,Ctrl + U看CSS文件,代码高亮,Prism.js可以实现,解决方法,参考网页源代码的写法
|
5月前
|
JavaScript 前端开发
vue 模拟随机变速的动态打字特效【支持多行文本】(含css实现闪烁光标,js动态改变setInterval定时器的时间间隔)
vue 模拟随机变速的动态打字特效【支持多行文本】(含css实现闪烁光标,js动态改变setInterval定时器的时间间隔)
107 1
|
5月前
|
JavaScript
文本,Pinia的使用,(0 , _stores_token_js__WEBPACK_IMPORTED_MODULE_1__.useTokenStore),接口中必须用引入store.js文件
文本,Pinia的使用,(0 , _stores_token_js__WEBPACK_IMPORTED_MODULE_1__.useTokenStore),接口中必须用引入store.js文件
文本vitepress,如何设置背景图,如何插入背景图,如何插入logo,为了放背景图片,我们要新建pubilc的文件夹,插入logo要在config.js中进行配置,注意细节,在添加背景时,注意格式
文本vitepress,如何设置背景图,如何插入背景图,如何插入logo,为了放背景图片,我们要新建pubilc的文件夹,插入logo要在config.js中进行配置,注意细节,在添加背景时,注意格式
|
5月前
|
资源调度 前端开发
文本,vitepress的使用,如何使用vitevitepress没有config.js该怎么办?这里使用vitepress进行手动配置,参考只爭朝夕不負韶華的文章
文本,vitepress的使用,如何使用vitevitepress没有config.js该怎么办?这里使用vitepress进行手动配置,参考只爭朝夕不負韶華的文章
|
5月前
|
JavaScript
js 解析和操作树 —— 获取树的深度、提取并统计树的所有的节点和叶子节点、添加节点、修改节点、删除节点
js 解析和操作树 —— 获取树的深度、提取并统计树的所有的节点和叶子节点、添加节点、修改节点、删除节点
154 0
|
6月前
|
JavaScript BI
技术笔记:JS获取子节点、父节点和兄弟节点的方法实例总结
技术笔记:JS获取子节点、父节点和兄弟节点的方法实例总结
110 0