JS的replace方法

时间: 作者:级名

  

[replace]JS的replace方法

  

定义和用法  
replace() 方法用于在字符串中用一些字符替换另一些字符,或替换一个与正则表达式匹配的子串。

  
  
语法  
stringObject.replace(regexp/substr,replacement)  
  
  

                    
参数描述
regexp/substr  

必需。规定子字符串或要替换的模式的 RegExp 对象。

  

  

请注意,如果该值是一个字符串,则将它作为要检索的直接量文本模式,而不是首先被转换为 RegExp 对象。

  

replacement必需。一个字符串值。规定了替换文本或生成替换文本的函数。
  
  

  

返回值

  

一个新的字符串,是用 replacement 替换了 regexp 的第一次匹配或所有匹配之后得到的。

  

  

说明

  

字符串 stringObject 的 replace() 方法执行的是查找并替换的操作。它将在 stringObject 中查找与 regexp 相匹配的子字符串,然后用 replacement 来替换这些子串。如果 regexp 具有全局标志 g,那么 replace() 方法将替换所有匹配的子串。否则,它只替换第一个匹配子串。

  

  

replacement 可以是字符串,也可以是函数。如果它是字符串,那么每个匹配都将由字符串替换。但是 replacement 中的 $ 字符具有特定的含义。如下表所示,它说明从模式匹配得到的字符串将用于替换。

  

  

  

                                      
字符替换文本
$1、$2、...、$99与 regexp 中的第 1 到第 99 个子表达式相匹配的文本。
$&与 regexp 相匹配的子串。
$`位于匹配子串左侧的文本。
$'位于匹配子串右侧的文本。
$$直接量符号。
  

  

注意:ECMAScript v3 规定,replace() 方法的参数 replacement 可以是函数而不是字符串。在这种情况下,每个匹配都调用该函数,它返回的字符串将作为替换文本使用。该函数的第一个参数是匹配模式的字符串。接下来的参数是与模式中的子表达式匹配的字符串,可以有 0 个或多个这样的参数。接下来的参数是一个整数,声明了匹配在 stringObject 中出现的位置。最后一个参数是 stringObject 本身。

  

  

更多基础实例可以到这里查看:  
  
replace() 方法的参数 replacement 可以是函数而不是字符串。在这种情况下,每个匹配都调用该函数,它返回的字符串将作为替换文本使用。该函数的第一个参数是匹配模式的字符串。接下来的参数 是与模式中的子表达式匹配的字符串,可以有 0 个或多个这样的参数。接下来的参数是一个整数,声明了匹配在 stringObject 中出现的位置。最后一个参数是 stringObject 本身。

  

  

下文展示了几种javascript正则表示式的repalce方式,有些方式我们很少在别的地方看到,如第二种和第三方中方法。

  

  

代码如下:

  
//下面的例子用来获取url的两个参数,并返回urlRewrite之前的真实Url  
var reg=new RegExp("()(\\d+),(\\d+).aspx","gmi");  
var url="";  

  

//方式一,最简单常用的方式  
var rep=url.replace(reg,"$1ShowBook.aspx?bookId=$2&chapterId=$3");  
alert(rep);  

  

//方式二 ,采用固定参数的回调函数  
var rep2=url.replace(reg,function(m,p1,p2,p3){return p1+"ShowBook.aspx?bookId="+p3+"&chapterId="+p3});  
alert(rep2);  

  

//方式三,采用非固定参数的回调函数  
var rep3=url.replace(reg,function(){var args=arguments; return args[1]+"ShowBook.aspx?bookId="+args[2]+"&chapterId="+args[3];});  
alert(rep3);  

  

  
//方法四  
//方式四和方法三很类似, 除了返回替换后的字符串外,还可以单独获取参数  

  

[code]  
var bookId;  
var chapterId;  
function capText()  
{  
var args=arguments;  
bookId=args[2];  
chapterId=args[3];  
return args[1]+"ShowBook.aspx?bookId="+args[2]+"&chapterId="+args[3];  
}  

  

var rep4=url.replace(reg,capText);  
alert(rep4);  
alert(bookId);  
alert(chapterId);  

  

  
//除了使用replace方法获取正则表示式的分组外,还可以使用test ,exec方法获取分组,只是手法有所不同而已   (责任编辑:admin)

推荐图片Related

相关文章Related

查看更多热门新闻


首页 | js代码 | jQuery特效 | 其他代码 | 关于我们

Copyright © 2010-2019 菲娱国际平台 版权所有

系统要求:本站自适应各终端浏览器分辨率

请使用Google、Firefox、IE9、百度浏览器登录网站

网站地图 | RSS订阅 | 菲娱国际平台