文章详情页
javascript - js正则替换问题
浏览:172日期: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. css - 文字排版问题,内容都是动态抓出来的,字数不一定。如何对齐啊2. git - 在web应用分布式部署的情况下怎么进行配置更新3. css3 - 微信前端页面遇到的transition过渡动画的bug4. 网页爬虫 - 关于Python的编码与解码问题5. 前端 - WebStrom安装了angularjs插件,但是没有语法提示6. 微信开放平台 - ios APP能不能打开微信然后通过微信跳转到指定的URL?7. selenium-selenium-webdriver - python 将当前目录加入到 环境变量8. css - input间的间距和文字上下居中9. javascript - imgzoom插件所引发的bug血案!!!!10. php ZipArchive关于不同目录文件压缩
排行榜

网公网安备