您的位置:首页 > Web前端 > JavaScript

js Replace结合正则 替换掉重复出现的字符串

2011-02-15 15:58 363 查看
今天想把网站上关于用户搜索资料后的结果列表进行处理,如同百度搜索一样,加入我搜索框中输入“我要日日发网络”,点击搜索按钮所得的结果列表中将会出现“我要日日发网络”字符串为红色。

我今天想到用js来进行处理,就是利用js内的replace函数对结果列表内的字符串进行指定字符串的替换工作,开始我是这样写的

<mce: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("日日发");

// --></mce:script>


最后运行页面发现只替换掉了第一个“日日发”字符串,其他“日日发”字符串没有被替换掉,开始百思不得其解,后来在朋友的帮助下了解到js内的replace和c#内的replace有很大的不同,js内的replace默认的只是对字符串进行一次扫描。那么利用js的replace函数如何才能够达到字符串全部替换的效果呢? 这里我们就必须引入正则式了的,修改后的js函数如下所示:

<mce: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("日日发");

// --></mce:script>


这两者一比较就很清楚问题出在哪里了的,利用正则式很轻松地解决了问题,在这里 new RegExp(str,"gi") 这句话是什么意思呢?

后来查阅了一些资料,g - 从头至尾扫描完一次整个字符串,i- 不区分替换字符串的大小写。那么整个语句的意思就好理解了的。

希望我的经验能够给大家带来方便。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: