字符串对象的`replace`方法可以替换匹配的值。它接受两个参数,第一个是正则表达式,表示搜索模式,第二个是替换的内容。
~~~
str.replace(search, replacement)
~~~
正则表达式如果不加`g`修饰符,就替换第一个匹配成功的值,否则替换所有匹配成功的值。
~~~
'aaa'.replace('a', 'b') // "baa"
'aaa'.replace(/a/, 'b') // "baa"
'aaa'.replace(/a/g, 'b') // "bbb"
~~~
上面代码中,最后一个正则表达式使用了`g`修饰符,导致所有的`a`都被替换掉了。
`replace`方法的一个应用,就是消除字符串首尾两端的空格。
~~~
var str = ' #id div.class ';
str.replace(/^\s+|\s+$/g, '')
// "#id div.class"
~~~
`replace`方法的第二个参数可以使用美元符号`$`,用来指代所替换的内容。
* `$&`:匹配的子字符串。
* \`$\`\`:匹配结果前面的文本。
* `$'`:匹配结果后面的文本。
* `$n`:匹配成功的第`n`组内容,`n`是从1开始的自然数。
* `$$`:指代美元符号`$`。
~~~
'hello world'.replace(/(\w+)\s(\w+)/, '$2 $1')
// "world hello"
'abc'.replace('b', '[$`-$&-$\']')
// "a[a-b-c]c"
~~~
上面代码中,第一个例子是将匹配的组互换位置,第二个例子是改写匹配的值。
`replace`方法的第二个参数还可以是一个函数,将每一个匹配内容替换为函数返回值。
~~~
'3 and 5'.replace(/[0-9]+/g, function (match) {
return 2 * match;
})
// "6 and 10"
var a = 'The quick brown fox jumped over the lazy dog.';
var pattern = /quick|brown|lazy/ig;
a.replace(pattern, function replacer(match) {
return match.toUpperCase();
});
// The QUICK BROWN fox jumped over the LAZY dog.
~~~
作为`replace`方法第二个参数的替换函数,可以接受多个参数。其中,第一个参数是捕捉到的内容,第二个参数是捕捉到的组匹配(有多少个组匹配,就有多少个对应的参数)。此外,最后还可以添加两个参数,倒数第二个参数是捕捉到的内容在整个字符串中的位置(比如从第五个位置开始),最后一个参数是原字符串。下面是一个网页模板替换的例子。
~~~
var prices = {
'p1': '$1.99',
'p2': '$9.99',
'p3': '$5.00'
};
var template = '<span id="p1"></span>'
+ '<span id="p2"></span>'
+ '<span id="p3"></span>';
template.replace(
/(<span id=")(.*?)(">)(<\/span>)/g,
function(match, $1, $2, $3, $4){
return $1 + $2 + $3 + prices[$2] + $4;
}
);
// "<span id="p1">$1.99</span><span id="p2">$9.99</span><span id="p3">$5.00</span>"
~~~
上面代码的捕捉模式中,有四个括号,所以会产生四个组匹配,在匹配函数中用`$1`到`$4`表示。匹配函数的作用是将价格插入模板中。
- 第一章:变量与作用域
- 第一节:变量
- 第二节:执行环境及作用域
- 第三节:JS 解析机制
- 第四节:垃圾收集
- 第二章:深入函数
- 第一节:概述
- 第二节:函数声明
- 第三节:函数调用
- 第四节:函数参数
- 第五节:函数返回值
- 第三章:面向对象
- 第一节:概述
- 第二节:对象声明
- 第三节:this 关键字
- 第四节:对象遍历
- 第五节:对象继承
- 第六节:模块
- 第四章:正则表达式
- 第一节:概述
- 第二节:实例属性
- 第三节:实例方法
- 第一课时:测试
- 第二课时:执行
- 第四节:匹配规则
- 第一课时:字面量字符和元字符
- 第二课时:转义符
- 第三课时:特殊字符
- 第四课时:字符类
- 第五课时:预定义模式
- 第六课时:重复类
- 第七课时:量词符
- 第八课时:贪婪模式
- 第九课时:修饰符
- 第十课时:组匹配
- 第五节:字符串的实例方法
- 第一课时:匹配
- 第二课时:搜索
- 第三课时:替换
- 第四课时:分割