当前位置: 首页 > news >正文

js-getSelection获取选中内容

在 Vue 项目中使用 getSelection() 获取用户选中的文本

在 Web 开发中,window.getSelection() 是一个强大的 API,它允许我们获取用户当前在页面上选中的文本内容。本文将介绍如何在 Vue 项目中使用该方法,并结合一些典型应用场景给出示例。

一、getSelection() 是什么?

getSelection()window 对象上的方法,用于返回一个表示用户当前所选文本范围的 Selection 对象。你可以从这个对象中提取文本内容、获取选区的起止节点、修改选区等。

const selection = window.getSelection();
console.log(selection.toString()); // 输出当前选中的文本内容

二、常见应用场景

  1. 富文本编辑器: 需要插入标签、格式化选中文本。
  2. 文字注释/高亮: 获取用户选中的文本范围,在原文中添加高亮背景或注释。
  3. 复制/引用功能: 自动提取并操作选中文本。

三、在 Vue 中使用 getSelection()

我们可以在 Vue 组件中通过事件监听(例如点击按钮)来调用该方法:

示例组件:获取用户选中的文本

<template><div><p ref="textBlock">请选中这段文字中的任意部分,然后点击下方按钮查看你选中了什么。</p><button @click="getSelectedText">获取选中文本</button><p v-if="selectedText">你选中了: "{{ selectedText }}"</p></div>
</template><script setup>
import { ref } from 'vue';const selectedText = ref('');
const getSelectedText = () => {const selection = window.getSelection();selectedText.value = selection ? selection.toString() : '';
};
</script>

注意事项

  • 跨元素选区: getSelection() 支持跨多个元素的选区,你可以遍历 selection.rangeCount 来获取每个 Range
  • 无法获取隐藏元素中的内容: 如果选中的内容被 CSS 隐藏(如 display: none),将无法被获取。
  • 受限于 Shadow DOM: getSelection() 无法直接获取 Shadow DOM 中的选区内容。

四、拓展:插入 HTML 或高亮选中的文字

可以结合 Range 对象实现更复杂的功能,比如插入高亮标记:

const selection = window.getSelection();
if (!selection.rangeCount) return;const range = selection.getRangeAt(0);
const span = document.createElement('span');
span.style.backgroundColor = 'yellow';
span.textContent = range.toString();range.deleteContents();
range.insertNode(span);

⚠️ 小提示: 修改选区 DOM 会破坏原始结构,请确保插入操作符合预期,必要时做节点备份。

五、封装成 Vue 指令(可选)

你也可以封装一个自定义指令来处理选区逻辑,便于复用。

// directives/select-highlight.js
export default {mounted(el, binding) {el.addEventListener('mouseup', () => {const selection = window.getSelection();const text = selection.toString();if (text) {binding.value(text); // 执行绑定的回调函数}});},
};

使用方式:

<div v-select-highlight="onSelectText">选我试试!</div><script setup>
import selectHighlight from './directives/select-highlight';
import { onMounted } from 'vue';const onSelectText = (text) => {console.log('你选中了:', text);
};onMounted(() => {// 注册全局或局部指令
});
</script>

还有一种场景上也可以用到getSelection,当我们点击列表中的一项进入详情,但是长按标题时我们又想复制,不触发跳转详情事件,这个时候我们只需要在点击事件中判断下当前是否选中了文本,如果选中了就阻止默认事件,就不会触发跳转详情事件。

const selectedText = window.getSelection()?.toString()
if (selectedText) {return
}

六、总结

getSelection() 是处理用户选中文本的利器,结合 Vue 的响应式系统和模板语法,可以实现很多有趣而实用的功能。无论是文字编辑、批注、高亮,还是富文本场景,它都能派上用场。

相关文章:

  • tcpdump 的用法
  • CDGP重点知识梳理(82个)
  • Auto DOP:让并行执行实现智能调优 | OceanBase 实践
  • 达梦、PostgreSQL数据库讲json解析成临时表(json_table函数的使用)
  • 通用外设驱动模型(四步法)
  • 微信小程序地图缩放scale隐性bug
  • [AI Tools] Dify 平台插件开发全解:如何构建 Tools 插件并解析输出逻辑
  • OpenCV中适用华为昇腾(Ascend)后端的逐元素操作(Per-element Operations)
  • 【质量管理】TRIZ因果链分析:解码质量问题的“多米诺效应“
  • 经典计算核心问题在于多项式时间内无法求解
  • 重庆工商职业学院“户卫者”团队为建筑外墙检测技术推广创新赋能
  • PostgreSQL创建只读账号
  • 自适应混合索引创建与管理:一种智能数据库优化机制的研究
  • PH热榜 | 2025-05-09
  • 『Python学习笔记』ubuntu解决matplotlit中文乱码的问题!
  • 鸿蒙电脑:五年铸剑开新篇,国产操作系统新引擎
  • 华为防火墙双机热备(负载分担)
  • 华为欧拉(EulerOS)系统全栈软件部署指南:从 Redis 到 MySQL 实战详解
  • 计算机视觉】OpenCV项目实战:eye_mouse_movement:基于opencv实战眼睛控制鼠标
  • Oracle — 数据管理
  • 全国人大常委会启动食品安全法执法检查
  • 警惕“全网最低价”等宣传,市监总局和中消协发布直播消费提示
  • 金融监管局:已设立74支私募股权投资基金,支持投资科技创新企业
  • 媒体起底“速成洋文凭”灰产链,专家:我们要给学历“祛魅”
  • 国务院安委会办公室印发通知:坚决防范遏制重特大事故发生
  • 计划招录2577人,“国考”补录8日开始报名