
正则表达式提取html标签属性
您提到正则表达式代码不能达到预期效果,具体问题在于未能过滤掉不需要的属性。下面提供一个修改后的代码,可以完成您所描述的任务:
$re = '/\bon\w+=([\'"]).*?\1/m'; $str = '<strong style="white-space: normal;" class="123" onload="asdasdas()"> </strong><div class="ccc">aaaaa</div> <p style="white-space: normal;">bbbbb</p> <strong class="123" style="white-space: normal;" onload="asdasdas()">12313123 </strong> <strong onload=\'asdasdas()\' >eeeeee </strong><a href="http://www.xxx.com" target="_blank" class="aaaa">链接链接</a><p>ffff</p>'; $subst = ''; $result = preg_replace($re, $subst, $str); echo "替换的结果是 ".$result;
此代码将匹配所有以"on"开头的属性,并删除其值。也可以通过修改正则表达式来匹配其他不需要的属性。
匹配详情
立即学习“前端免费学习笔记(深入)”;
点按此链接查看此正则表达式的匹配项:https://hiregex.com/r/hxner1/1
以上就是如何用正则表达式高效地去除HTML标签中特定属性?的详细内容,更多请关注php中文网其它相关文章!
HTML怎么学习?HTML怎么入门?HTML在哪学?HTML怎么学才快?不用担心,这里为大家提供了HTML速学教程(入门课程),有需要的小伙伴保存下载就能学习啦!
Copyright 2014-2025 https://www.php.cn/ All Rights Reserved | php.cn | 湘ICP备2023035733号