javascript 正则替换 replace(regExp, function)用法

2019-12-24,,,

复制代码 代码如下:
function fn()
{
for(var i = 0;i < arguments.length;i++){
  alert("第"+(i+1)+"个参数的值:"+arguments[i]);
  }
}
var str = '<div id="{wo}" >{ni}</div>';
str.replace(/\{([a-z]+)\}/ig, fn);

根据多次测试由输出结果可以得出fn中:

  第一个参数为匹配到的字符串,如{wo}和{ni};

  第二个参数可以有0-N个,为第一个参数中匹配到一个括号正则的字符串,如第一个参数中的wo和ni,能匹配([a-z]+),

    括号有几组,则参数有几个;

  第三个参数为第一个参数中匹配到的字符串所在位置,如{wo}返回9,{no}返回16;

  第四个参数为用来匹配的字符串,在这个例子中就是<div id="{wo}" >{ni}</div>.

本例中对于一个包含wo和ni的json对象可以简单地用:

复制代码 代码如下:
str.replace(/\{([a-z]+)\}/ig, function(s, t){
return json[t];
});

来替换.

您可能感兴趣的文章:

  • JS正则替换去空格的方法
  • JavaScript正则替换HTML标签功能示例
  • js使用Replace结合正则替换重复出现的字符串功能示例
  • JS正则替换掉小括号及内容的方法
  • JavaScript字符串对象replace方法实例(用于字符串替换或正则替换)
  • JavaScript replace(rgExp,fn)正则替换的用法
  • javascript replace()正则替换实现代码
  • C#正则函数用法实例【匹配、替换、提取】
  • JS和C#实现的两个正则替换功能示例分析

《javascript 正则替换 replace(regExp, function)用法.doc》

下载本文的Word格式文档,以方便收藏与打印。