当前位置: 首页 > 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 的响应式系统和模板语法,可以实现很多有趣而实用的功能。无论是文字编辑、批注、高亮,还是富文本场景,它都能派上用场。

http://www.dtcms.com/a/181347.html

相关文章:

  • 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 — 数据管理
  • Faiss 索引深度解析:从基础到实战
  • 文旅田园康养小镇规划设计方案PPT(85页)
  • RabbitMQ-高级特性1
  • 如何避免双击时触发单击事件
  • Springboot+Vue+Mybatis-plus-Maven-Mysql项目部署
  • Kepware价格大概是多少?在哪里可以下载正版试用?
  • 李沐《动手学深度学习》 | 多层感知机
  • WebRTC工作原理详细介绍、WebRTC信令交互过程和WebRTC流媒体传输协议介绍
  • 大模型应用开发之模型架构
  • 101 alpha——8 学习