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);
理论上,调用一个函数,应该是functionName(),这样的形式才可以,这里直接使用了函数本身,应该里面做了处理,为了得到所有默认参数,类似js的方法。
如果这里使用内部函数的话,参数不会丢失,如果这里使用fn()的话,相当于调用普通的函数。
函数和方法的区别:
函数:fn()不能引用对象的this,当然可以做特殊处理,把对象传给它。
方法:基本上是 obj.method();这时候方法里面可以使用对象,也就是this.property
根据多次测试由输出结果可以得出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];
});