JS-正则表达式-替换

利用正则表达式将源字符串中的某一部分替换成另一部分(只能替换文字字母,字符不能替换):

var sToChange = "The sky is red";

var result = sToChange.replace("red", "blue");

alert(result); //输出:The sky is blue
上面的 replace 方法第一个参数是一个字符串,第二个是要替换的部分,但这样只能替换一次.要将源字符串中所有的red都替换成blud,可以这样:

var sToChange = "The sky is red really red";

var reg = /red/gi

var result = sToChange.replace(reg, "blue");

alert(result); //输出:The sky is blue really blue
上面第一个参数是一个正则表达式,第二个是要替换成的部分.还有另一种做法,第一个参数是正则表达式,第二个是处理函数:

var sToChange = "The sky is red really red";

var reg = /red/gi

var result = sToChange.replace(reg, function(sMatch){ return "blue"; });

alert(result); //输出:The sky is blue really blue

上面函数里面的sMatch表示通过匹配,从源字符串中获得到的已匹配的字符.如上例中,模式从源字符串中匹配出来的始终都是"red";更直观的例子如下:

var sTo = /(fuck|shit|ahswhole|bitch)/g;

var sMyStr = "the son of the bitch,fuck you ,like a piece of shit!ahswhole!";

var resultStr = sMyStr.replace(sTo, function(sMatch){ return sMatch.replace(/./g, "*"); });

alert(resultStr); //输出:the son of the *****,**** you ,like a piece of ****!********!

可以看出输出的星号是不等的,因为匹配的时候,当表达式匹配到bitch的时候,传入函数的就是bitch,然后函数将它替换成:*****,五个星号,然后返回;然后继续匹配,碰到fuck,然后传入函数,这时sMatch就是:fuck,然后将它替换成:****四个星号.依此类推.

 
另一实例;
var sToChange = document.getElementByIdx_x("abc").innerHTML;
var reg = /<img.*?src="(.*?)".*?>/gi
var result = sToChange.replace(reg, function(sMatch){
  var backStr = "<a href=\"" + RegExp.$1 + "\" class=\"highslide\" onclick=\"return hs.expand(this)\">";
  backStr += sMatch;
  backStr += "</a>";
  backStr += "";
  return backStr;
});
document.getElementByIdx_x("abc").innerHTML = result;
posted @ 2014-02-17 14:50  xjt360  阅读(481)  评论(0编辑  收藏  举报