0

0

如何在 HTML 内容中安全替换标签之间的文本(不触碰标签本身)

心靈之曲

心靈之曲

发布时间:2025-12-27 09:45:12

|

823人浏览过

|

来源于php中文网

原创

如何在 HTML 内容中安全替换标签之间的文本(不触碰标签本身)

本文介绍一种基于正则表达式的轻量级方案,用于精准替换 html 标签内部的纯文本内容,确保 html 标签结构(如 `

`、``)完全不受影响,避免误删或破坏嵌套结构。

直接使用 preg_replace 处理 HTML 文本存在天然风险——正则无法真正解析 HTML 语法树,因此仅适用于结构简单、标签明确、无嵌套或自闭合干扰的场景(例如批量处理

、<h1> 等单层文本容器)。核心思路是:<strong>锚定起始标签,匹配其后连续的非标签字符(即“标签内文本”),再执行替换,同时保留前后标签不变</strong>。</h1> <p>以下是一个可复用的函数示例,支持任意搜索词与替换词:</p><pre class="brush:php;toolbar:false;">function replaceInTagContent($search, $replace, $subject, $tag = 'title') { // 构建正则:匹配 <tag> 后、下一个 < 或标签结束前的任意文本(非贪婪) $pattern = '/<' . preg_quote($tag, '/') . '>([^<]*?)<\/' . preg_quote($tag, '/') . '>/i'; // 使用回调函数,在匹配到的标签内容中执行 str_replace(避免正则转义问题) return preg_replace_callback($pattern, function($matches) use ($search, $replace) { $content = $matches[1]; $replaced = str_replace($search, $replace, $content); return '<' . $matches[0][0] . '>' . $replaced . '</' . $matches[0][0] . '>'; }, $subject); } // 使用示例 echo replaceInTagContent('remove it', 'new str', '<title>remove it, but not this</title>'); // 输出:<title>new str, but not this</title> echo replaceInTagContent('title', 'name', '<title>remove the title</title>'); // 输出:<title>remove the name</title></pre><p>⚠️ <strong>重要注意事项</strong>: </p><div class="aritcle_card flexRow"> <div class="artcardd flexRow"> <a class="aritcle_card_img" href="/ai/794" title="天工大模型"><img src="https://img.php.cn/upload/ai_manual/000/000/000/175679968422723.png" alt="天工大模型" onerror="this.onerror='';this.src='/static/lhimages/moren/morentu.png'" ></a> <div class="aritcle_card_info flexColumn"> <a href="/ai/794" title="天工大模型">天工大模型</a> <p>中国首个对标ChatGPT的双千亿级大语言模型</p> </div> <a href="/ai/794" title="天工大模型" class="aritcle_card_btn flexRow flexcenter"><b></b><span>下载</span> </a> </div> </div> <ul> <li>此方案<strong>不适用于含嵌套标签的 HTML</strong>(如 <title><em>text</em>),因 [^ 处截断;
  • 若需处理复杂 HTML,务必改用 DOM 解析器(如 DOMDocument + DOMXPath),这是唯一健壮可靠的方式;
  • 正则中使用 preg_quote($tag, '/') 防止标签名含特殊字符(如 h1, data-title)引发语法错误;
  • i 修饰符确保大小写不敏感匹配(如 也生效)。
  • 总结:对于可控、扁平的 HTML 片段(如模板中静态

    批量替换),上述正则+回调方案简洁高效;但一旦涉及动态、嵌套或用户输入 HTML,请立即切换至 DOMDocument —— 安全性永远优先于代码行数。<p><span>立即学习</span>“<a href="https://pan.quark.cn/s/cb6835dc7db1" style="text-decoration: underline !important; color: blue; font-weight: bolder;" rel="nofollow" target="_blank">前端免费学习笔记(深入)</a>”;</p>

    相关文章

    HTML速学教程(入门课程)
    HTML速学教程(入门课程)

    HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!

    下载

    本站声明:本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn

    热门AI工具

    更多
    DeepSeek
    DeepSeek

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

    豆包大模型
    豆包大模型

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

    WorkBuddy
    WorkBuddy

    腾讯云推出的AI原生桌面智能体工作台

    腾讯元宝
    腾讯元宝

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

    文心一言
    文心一言

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

    讯飞写作
    讯飞写作

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

    即梦AI
    即梦AI

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

    ChatGPT
    ChatGPT

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

    相关专题

    更多
    js正则表达式
    js正则表达式

    php中文网为大家提供各种js正则表达式语法大全以及各种js正则表达式使用的方法,还有更多js正则表达式的相关文章、相关下载、相关课程,供大家免费下载体验。

    530

    2023.06.20

    正则表达式不包含
    正则表达式不包含

    正则表达式,又称规则表达式,,是一种文本模式,包括普通字符和特殊字符,是计算机科学的一个概念。正则表达式使用单个字符串来描述、匹配一系列匹配某个句法规则的字符串,通常被用来检索、替换那些符合某个模式的文本。php中文网给大家带来了有关正则表达式的相关教程以及文章,希望对大家能有所帮助。

    258

    2023.07.05

    java正则表达式语法
    java正则表达式语法

    java正则表达式语法是一种模式匹配工具,它非常有用,可以在处理文本和字符串时快速地查找、替换、验证和提取特定的模式和数据。本专题提供java正则表达式语法的相关文章、下载和专题,供大家免费下载体验。

    766

    2023.07.05

    java正则表达式匹配字符串
    java正则表达式匹配字符串

    在Java中,我们可以使用正则表达式来匹配字符串。本专题为大家带来java正则表达式匹配字符串的相关内容,帮助大家解决问题。

    219

    2023.08.11

    正则表达式空格
    正则表达式空格

    正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。本专题为大家提供正则表达式相关的文章、下载、课程内容,供大家免费下载体验。

    357

    2023.08.31

    Python爬虫获取数据的方法
    Python爬虫获取数据的方法

    Python爬虫可以通过请求库发送HTTP请求、解析库解析HTML、正则表达式提取数据,或使用数据抓取框架来获取数据。更多关于Python爬虫相关知识。详情阅读本专题下面的文章。php中文网欢迎大家前来学习。

    293

    2023.11.13

    正则表达式空格如何表示
    正则表达式空格如何表示

    正则表达式空格可以用“s”来表示,它是一个特殊的元字符,用于匹配任意空白字符,包括空格、制表符、换行符等。想了解更多正则表达式空格怎么表示的内容,可以访问下面的文章。

    245

    2023.11.17

    正则表达式中如何匹配数字
    正则表达式中如何匹配数字

    正则表达式中可以通过匹配单个数字、匹配多个数字、匹配固定长度的数字、匹配整数和小数、匹配负数和匹配科学计数法表示的数字的方法匹配数字。更多关于正则表达式的相关知识详情请看本专题下面的文章。php中文网欢迎大家前来学习。

    547

    2023.12.06

    C# ASP.NET Core微服务架构与API网关实践
    C# ASP.NET Core微服务架构与API网关实践

    本专题围绕 C# 在现代后端架构中的微服务实践展开,系统讲解基于 ASP.NET Core 构建可扩展服务体系的核心方法。内容涵盖服务拆分策略、RESTful API 设计、服务间通信、API 网关统一入口管理以及服务治理机制。通过真实项目案例,帮助开发者掌握构建高可用微服务系统的关键技术,提高系统的可扩展性与维护效率。

    76

    2026.03.11

    热门下载

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

    精品课程

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

    共46课时 | 3.6万人学习

    AngularJS教程
    AngularJS教程

    共24课时 | 4.1万人学习

    CSS教程
    CSS教程

    共754课时 | 42.4万人学习

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

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