js使用Replace结合正则替换重复出现的字符串功能示例
本文实例讲述了js使用replace结合正则替换重复出现的字符串功能。分享给大家供大家参考,具体如下:
今天想把网站上关于用户搜索资料后的结果列表进行处理,如同百度搜索一样,加入我搜索框中输入“我要日日发网络”,点击搜索按钮所得的结果列表中将会出现“我要日日发网络”字符串为红色。
我今天想到用js来进行处理,就是利用js内的replace函数对结果列表内的字符串进行指定字符串的替换工作,开始我是这样写的
<script type="text/javascript" language="javascript"> <!-- function replacestr(str) { var content = document.getelementbyid("content").innerhtml; content = content.replace(str, "<font color='red'>" + str + "</font>"); document.getelementbyid("content").innerhtml = content; } replacestr("日日发"); // --> </script>
最后运行页面发现只替换掉了第一个“日日发”字符串,其他“日日发”字符串没有被替换掉,开始百思不得其解,后来在朋友的帮助下了解到js内的replace和c#内的replace有很大的不同,js内的replace默认的只是对字符串进行一次扫描。那么利用js的replace函数如何才能够达到字符串全部替换的效果呢? 这里我们就必须引入正则式了的,修改后的js函数如下所示:
<script type="text/javascript" language="javascript"> <!-- function replacestr(str) { var content = document.getelementbyid("content").innerhtml; content = content.replace(new regexp(str,"gi"), "<font color='red'>" + str + "</font>"); document.getelementbyid("content").innerhtml = content; } replacestr("日日发"); // --> </script>
这两者一比较就很清楚问题出在哪里了的,利用正则式很轻松地解决了问题,在这里 new regexp(str,"gi") 这句话是什么意思呢?
后来查阅了一些资料,g - 从头至尾扫描完一次整个字符串,i- 不区分替换字符串的大小写。那么整个语句的意思就好理解了的。
ps:这里再为大家提供2款非常方便的正则表达式工具供大家参考使用:
javascript正则表达式在线测试工具:
正则表达式在线生成工具:
更多关于javascript相关内容感兴趣的读者可查看本站专题:《javascript正则表达式技巧大全》、《javascript替换操作技巧总结》、《javascript查找算法技巧总结》、《javascript数据结构与算法技巧总结》、《javascript遍历算法与技巧总结》、《javascript中json操作技巧总结》、《javascript错误与调试技巧总结》及《javascript数学运算用法总结》
希望本文所述对大家javascript程序设计有所帮助。