文章详情页
javascript - js正则替换问题
浏览:122日期:2023-03-07 18:22:03
问题描述
<!DOCTYPE html><html><head> <title>内容</title></head><body>中文<p>内容<i>内容</i></p></body></html>
将标签里面的内容替换为
<!DOCTYPE html><html><head> <title>{{#内容#}}</title></head><body>{{#中文#}}<p>{{#内容#}}<i>{{#内容#}}</i></p></body></html>
求解正则该怎么写?
问题解答
回答1:第一,学过编译原理的话,你就会知道,正则是没有能力处理嵌套的数据结构的。也就是说,你想通过正则实现【选中 body 中嵌套的 p 的第一个 i 标签】这样的需求,在原理上是行不通的。
第二,你要处理的是一个结构化的 DOM 文本,因此可以使用 jQuery 的 parseHTML 方法来实现。通过 jQuery parse 后得到的对象是可以使用 $ 来进一步选择 p 或 i 等节点的。这就能够简单有效地解决你的文本替换问题了。
如果你在 Node 服务端,那么 jQuery 换成 cheerio 即可。
回答2:如果只在当前你给的测试文本里你想做替换,因为情况比较简单,所以只要写个([u4e00-u9fa5]+)这样的正则匹配用{{#$1#}}去替换就行
标签:
JavaScript
相关文章:
1. macos - mac下docker如何设置代理2. docker网络端口映射,没有方便点的操作方法么?3. css3 - div中的div无法控制高度?我想控制右边几个蓝色div的高度4. MySQL的SELECT...FOR UPDATE究竟起什么作用5. angular.js - $emit(,)的具体意思是什么作用呢?6. 为什么要使用javascript函数包装器(添加在coffeescript中)“。call(this)”7. docker-compose 为何找不到配置文件?8. javascript - 小米浏览器中,图片导致fixed定位的元素无法显示9. javascript - vue使用keep-alive不能保持滚动位置问题。10. javascript - 在vuejs中如何根据变量去引用不同的css样式呢
排行榜

网公网安备