JavaScript 的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、$3...$99 与regexp中的第1到第99个子表达式想匹配的文本。
$& 与regexp相匹配的子串。
$` 位于匹配子串左侧的文本
$'  位于匹配串右侧的文本
 $$  直接量符号

 

 

 

 

 

 

 

 

列子:
var str = "你好,暖暖风";
var newstr = str.replace(/(暖暖风)/g,'<span>$1</span>')
// newstr:"你好,<span>暖暖风</span>"
//str:"你好,暖暖风";
var str = '1 3 6 3'
str.replace(/\s+/g,',')
//1,3,6,3

replacement:字符串

var str = "<span>{{name}}+{{age}}</span>"
var reg = /\\?\{\{([^{}]+)\}\}/gm
str.replace(reg,"##")
//<span>##+##</span>

 replacement:函数

var html = format("<span>#{name}</span><span>#{age}</span>",{name:'暖风',age:18})
function format(str, object) {
    var array = Array.prototype.slice.call(arguments, 1);
    return str.replace(/\\?\#{([^{}]+)\}/gm, function(match, name) {
    //注意当没有匹配的时候,不执行这个函数 console.log(match)//#{name},#{age} console.log(name)//name,age
     console.log(arguments);//输出如下图
if (match.charAt(0) == '\\') return match.slice(1); var index = Number(name) if (index >= 0) return array[index]; if (object && object[name] !== void 0) return object[name]; return ''; }); }

arguments参数如下:

上面的函数的参数如下:

  第1个参数:匹配的字符串

  第2个参数:匹配的名字

  第3个参数:匹配的字符串所在的位置

  第4个参数:字符串本身

var str="他今年22岁,她今年20岁,他的爸爸今年45岁,她的爸爸今年44岁,一共有4人";
var newstr = str.replace(/(\d+)岁/g,function(m,n){
  console.log(arguments); var year = new Date().getYear()+1-parseInt(m);
  return m+"("+year+"年出生)";
});
console.log(newstr)//他今年22岁(97年出生),她今年20岁(99年出生),他的爸爸今年45岁(74年出生),她的爸爸今年44岁(75年出生),一共有4人
arguments如下:

var str='讨论一下正则表达式中的replace的用法';
str.replace(/(正则).+?(式)/,function() {
    console.log(arguments);
});
// ["正则表达式", "正则", "式", 4, "讨论一下正则表达式中的replace的用法"]

由此可见,第二个或后面的参数,为分组匹配的值

此文仅代表本人意见,如有异议,欢迎提出指正!


免责声明!

本站转载的文章为个人学习借鉴使用,本站对版权不负任何法律责任。如果侵犯了您的隐私权益,请联系本站邮箱yoyou2525@163.com删除。



 
粤ICP备18138465号  © 2018-2025 CODEPRJ.COM