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);
第一个参数为匹配到的字符串,如{wo}和{ni};
第二个参数可以有0-n个,为第一个参数中匹配到一个括号正则的字符串,如第一个参数中的wo和ni,能匹配([a-z]+),
括号有几组,则参数有几个;
第三个参数为第一个参数中匹配到的字符串所在位置,如{wo}返回9,{no}返回16;
第四个参数为用来匹配的字符串,在这个例子中就是<div id="{wo}" >{ni}</div>.
看一个实例
<!doctype html public "-//w3c//dtd html 4.0 transitional//en">
<html>
<head>
<title> new document </title>
<meta name="generator" content="editplus">
<meta name="author" content="">
<meta name="keywords" content="">
<meta name="description" content="">
<script language="网页特效" type="text/javascript">
string.prototype.replaceall = stringreplaceall;
function stringreplaceall(afindtext,areptext){
var raregexp = new regexp(afindtext.replace(/([()[]{}^$+-*?."'|/])/g,"$1"),"ig");
return this.replace(raregexp,areptext);
}
function myreplace(){
var content=document.getelementbyid("content").value;
var rel_con=content.replaceall("$name","wwww");
document.getelementbyid("content2").value=rel_con;
}
</script>
</head>
<body>
<input type="text" id="content" name="contxt" value="$name 客户姓名" /> <input type="button" value="replace"
onclick="myreplace()"/><br/>
<input type="text" id="content2" value=""/>
</body>
</html>