0

0

使用原生JavaScript在富文本区域中替换或包裹选中内容

霞舞

霞舞

发布时间:2025-10-23 09:20:15

|

715人浏览过

|

来源于php中文网

原创

使用原生javascript在富文本区域中替换或包裹选中内容

本文详细介绍了如何利用原生JavaScript的Selection和Range API,在HTML富文本输入区域或任何可编辑内容中精确地查找并替换或包裹用户选中的文本。教程涵盖了获取选区、操作选区范围、删除原有内容、创建新节点以及插入新内容的核心步骤,并提供了两种具体实现:将选中内容替换为指定文本,以及将选中内容的文本内容进行包裹。

在现代Web应用中,富文本编辑器是常见的组件。用户经常需要对编辑器中的特定文本进行操作,例如替换、加粗、斜体等。与简单的字符串查找替换不同,这些操作通常针对的是用户当前“选中”的文本。本教程将深入探讨如何使用原生JavaScript(不依赖任何库,如jQuery)来精确地识别并替换或包裹HTML内容中的选中文本。

核心概念:Selection 和 Range API

要操作用户选中的文本,我们主要依赖两个核心的Web API:Selection 和 Range。

  1. window.getSelection(): 这个方法返回一个 Selection 对象,代表用户当前选定的文本范围或光标的当前位置。一个 Selection 对象可以包含一个或多个 Range 对象(尽管在大多数常见情况下,用户只会创建一个单一的连续选区)。

  2. Selection 对象: Selection 对象提供了一系列方法来查询和修改当前选区。其中最常用的是 rangeCount 属性(表示选区中包含的 Range 对象的数量)和 getRangeAt(index) 方法(用于获取指定索引处的 Range 对象)。

  3. Range 对象: Range 对象代表文档中的一个连续区域,可以包含节点的一部分或整个节点。它提供了丰富的API来精确地操作这个区域,例如:

    • deleteContents(): 从文档中删除 Range 包含的内容。
    • extractContents(): 从文档中删除 Range 包含的内容,并返回一个包含这些内容的 DocumentFragment。
    • insertNode(node): 在 Range 的起始位置插入一个节点。
    • surroundContents(newParent): 用一个新节点包裹 Range 的内容。

实现选中内容替换的步骤

无论是替换还是包裹选中内容,基本流程都相似:

立即学习Java免费学习笔记(深入)”;

  1. 获取当前选区 (Selection):使用 window.getSelection()。
  2. 获取选区范围 (Range):通过 selection.getRangeAt(0) 获取第一个(也是最常见的)选区范围。
  3. 操作选区内容
    • 对于替换:先删除选中内容 (deleteContents()),再插入新内容 (insertNode())。
    • 对于包裹:提取选中内容 (extractContents()),创建一个包裹元素,将提取的内容添加到包裹元素中,然后将包裹元素插入到原位置 (insertNode())。
  4. 更新选区 (可选):操作完成后,通常会清除旧选区并设置新的选区,以保持光标的合理位置。

示例一:将选中内容替换为指定文本

这个示例演示了如何将用户选中的文本替换为一段预设的新文本。

HTML 结构:

我们将创建一个可编辑的 div 区域,以及一个触发替换操作的按钮。




    
    
    替换选中内容
    



    

JavaScript 选中内容替换教程

selectionRange.range.endContainer.innerHTML = newParent.innerHTML;

请在此处选择一些文本,然后点击按钮进行替换。

剪映
剪映

一款全能易用的桌面端剪辑软件

下载

例如,您可以选择 "innerHTML" 或 "newParent"。

代码解析:

  1. window.getSelection() 获取当前的 Selection 对象。
  2. selection.rangeCount 检查是否有选区。如果没有,函数直接返回。
  3. selection.getRangeAt(0) 获取用户创建的第一个(也是通常唯一一个)选区范围。
  4. range.deleteContents() 是实现替换的关键一步,它会直接从DOM中移除 Range 所包含的所有内容。
  5. document.createTextNode(newText) 创建一个包含新文本的文本节点。如果需要插入更复杂的HTML结构,可以创建 DocumentFragment 或 HTMLElement。
  6. range.insertNode(textNode) 将新创建的文本节点插入到 Range 的起始位置(即原选区被删除后的位置)。
  7. 最后的可选步骤 range.setStartAfter(textNode); range.setEndAfter(textNode); selection.removeAllRanges(); selection.addRange(range); 用于将光标定位到替换后的文本末尾,提供更好的用户体验。

示例二:将选中内容的文本内容进行包裹

这个示例演示了如何提取选中内容的纯文本,然后用一个带有特定前缀和后缀的 元素将其包裹起来。这与问题答案中提供的 {{C1::...}} 格式类似。

HTML 结构 (同上):





代码解析:

  1. range.extractContents() 是这里的关键。它不仅删除了选中的内容,还将其作为一个 DocumentFragment 返回。这意味着如果选中的内容包含多个DOM节点,它们都会被包含在这个 DocumentFragment 中。
  2. selectedContentFragment.textContent 获取 DocumentFragment 中所有节点的纯文本内容,忽略其内部的HTML结构。
  3. document.createElement("span") 创建一个新的 元素。
  4. wrapperSpan.innerHTML =${prefix}${selectedText}${suffix}`将提取的纯文本与指定的前缀和后缀组合,并设置为新元素的innerHTML`。
  5. range.insertNode(wrapperSpan) 将这个新的 元素插入到DOM中,替换了原来的选中内容。
  6. 同样,最后更新选区的步骤是可选的,用于优化用户体验。

deleteContents() 与 extractContents() 的区别:

  • deleteContents(): 仅从DOM中删除选中的内容,不返回任何东西。
  • extractContents(): 从DOM中删除选中的内容,并返回一个包含这些内容的 DocumentFragment。如果你需要对被删除的内容进行进一步处理(例如像本例中获取其 textContent 或重新包裹它),extractContents() 是更合适的选择。

注意事项

  1. 浏览器兼容性: window.getSelection() 和 Range API 在现代浏览器中都有良好的支持。对于IE9及以下版本,可能需要使用 document.selection 和 TextRange 对象,但这在当前Web开发中已不常见。
  2. 空选区处理: 在执行任何操作之前,务必检查 selection.rangeCount 以确保用户确实有内容被选中,避免运行时错误。
  3. 富文本编辑器集成: 如果你的应用中使用了现成的富文本编辑器(如nicEditor、TinyMCE、Quill等),它们通常会提供自己的API来操作选区。直接使用 window.getSelection() 和 Range API 可能会与编辑器的内部逻辑冲突,或者在某些情况下无法正确处理编辑器的复杂DOM结构。在集成时,建议优先使用编辑器提供的API。如果编辑器没有提供所需的功能,再考虑使用原生API,但需进行充分测试。
  4. 内容复杂性: 如果选中的内容包含复杂的HTML结构(例如嵌套的 div、img 等),extractContents() 会保留这些结构。但如果像示例二那样,你只取 textContent,则会丢失所有HTML格式。根据需求选择是保留结构还是只取纯文本。
  5. 安全性: 如果替换或插入的内容来源于用户输入,请务必进行适当的HTML转义或清理,以防止跨站脚本攻击(XSS)。

总结

通过 window.getSelection() 和 Range API,JavaScript提供了强大而灵活的机制来操作用户在网页上选中的文本。无论是简单的文本替换,还是更复杂的文本内容包裹,这些原生API都能帮助开发者精确地控制DOM。理解并熟练运用这些API,是构建高性能、用户友好的富文本交互功能的关键。

热门AI工具

更多
DeepSeek
DeepSeek

幻方量化公司旗下的开源大模型平台

豆包大模型
豆包大模型

字节跳动自主研发的一系列大型语言模型

通义千问
通义千问

阿里巴巴推出的全能AI助手

腾讯元宝
腾讯元宝

腾讯混元平台推出的AI助手

文心一言
文心一言

文心一言是百度开发的AI聊天机器人,通过对话可以生成各种形式的内容。

讯飞写作
讯飞写作

基于讯飞星火大模型的AI写作工具,可以快速生成新闻稿件、品宣文案、工作总结、心得体会等各种文文稿

即梦AI
即梦AI

一站式AI创作平台,免费AI图片和视频生成。

ChatGPT
ChatGPT

最最强大的AI聊天机器人程序,ChatGPT不单是聊天机器人,还能进行撰写邮件、视频脚本、文案、翻译、代码等任务。

相关专题

更多
jquery插件有哪些
jquery插件有哪些

jquery插件有jQuery UI、jQuery Validate、jQuery DataTables、jQuery Slick、jQuery LazyLoad、jQuery Countdown、jQuery Lightbox、jQuery FullCalendar、jQuery Chosen和jQuery EasyUI等。本专题为大家提供jquery插件相关的文章、下载、课程内容,供大家免费下载体验。

151

2023.09.12

jquery怎么操作json
jquery怎么操作json

操作的方法有:1、“$.parseJSON(jsonString)”2、“$.getJSON(url, data, success)”;3、“$.each(obj, callback)”;4、“$.ajax()”。更多jquery怎么操作json的详细内容,可以访问本专题下面的文章。

312

2023.10.13

jquery删除元素的方法
jquery删除元素的方法

jquery可以通过.remove() 方法、 .detach() 方法、.empty() 方法、.unwrap() 方法、.replaceWith() 方法、.html('') 方法和.hide() 方法来删除元素。更多关于jquery相关的问题,详情请看本专题下面的文章。php中文网欢迎大家前来学习。

396

2023.11.10

jQuery hover()方法的使用
jQuery hover()方法的使用

hover()是jQuery中一个常用的方法,它用于绑定两个事件处理函数,这两个函数将在鼠标指针进入和离开匹配的元素时执行。想了解更多hover()的相关内容,可以阅读本专题下面的文章。

504

2023.12.04

jquery实现分页方法
jquery实现分页方法

在jQuery中实现分页可以使用插件或者自定义实现。想了解更多jquery分页的相关内容,可以阅读本专题下面的文章。

187

2023.12.06

jquery中隐藏元素是什么
jquery中隐藏元素是什么

jquery中隐藏元素是非常重要的一个概念,在使用jquery隐藏元素之前,需要先了解css样式中关于元素隐藏的属性,比如display、visibility、opacity等属性。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

120

2024.02.23

jquery中什么是高亮显示
jquery中什么是高亮显示

jquery中高亮显示是指对页面搜索关键词时进行高亮显示,其实现办法:1、先获取要高亮显示的行,获取搜索的内容,再遍历整行内容,最后添加高亮颜色;2、使用“jquery highlight”高亮插件。本专题为大家提供相关的文章、下载、课程内容,供大家免费下载体验。

176

2024.02.23

jQuery 正则表达式相关教程
jQuery 正则表达式相关教程

本专题整合了jQuery正则表达式相关教程大全,阅读专题下面的文章了解更多详细内容。

40

2026.01.13

C++ 设计模式与软件架构
C++ 设计模式与软件架构

本专题深入讲解 C++ 中的常见设计模式与架构优化,包括单例模式、工厂模式、观察者模式、策略模式、命令模式等,结合实际案例展示如何在 C++ 项目中应用这些模式提升代码可维护性与扩展性。通过案例分析,帮助开发者掌握 如何运用设计模式构建高质量的软件架构,提升系统的灵活性与可扩展性。

14

2026.01.30

热门下载

更多
网站特效
/
网站源码
/
网站素材
/
前端模板

精品课程

更多
相关推荐
/
热门推荐
/
最新课程
React 教程
React 教程

共58课时 | 4.4万人学习

TypeScript 教程
TypeScript 教程

共19课时 | 2.6万人学习

Bootstrap 5教程
Bootstrap 5教程

共46课时 | 3.1万人学习

关于我们 免责申明 举报中心 意见反馈 讲师合作 广告合作 最新更新
php中文网:公益在线php培训,帮助PHP学习者快速成长!
关注服务号 技术交流群
PHP中文网订阅号
每天精选资源文章推送

Copyright 2014-2026 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号