regExp.@@replace

regExp.@@replace

[@@replace]() 方法会在一个字符串中用给定的替换器,替换所有符合正则模式的匹配项,并返回替换后的新字符串结果。用来替换的参数可以是一个字符串或是一个针对每次匹配的回调函数。

语法

regexp[Symbol.replace](str, newSubStr|function)

参数

str正则替换的目标字符串。newSubStr (replacement)类型为String的替换器。支持大多数特殊的替换匹配模式; 见String.prototype.replace()页的Specifying a string as a parameter部分。function (replacement)生成新的子字符串的回调函数替换器。作用于该函数的参数的详细描述见String.prototype.replace()页的 Specifying a function as a parameter部分。

返回值

用替换器替换相应匹配项后的新字符串。

描述

如果匹配模式也是RegExp对象,这个方法在String.prototype.replace()的内部调用。例如,下面的两个方法返回相同结果。

'abc'.replace(/a/, 'A' /a/[Symbol.replace]('abc', 'A'

该方法是为了在RegExp子类中自定义匹配的替换模式。

如果匹配模式不是一个RegExp对象,String.prototype.replace()就不会调用该方法,也不会创建一个RegExp对象。

示例

直接调用

这个方法基本可以和 String.prototype.replace()一样使用, 不同之处是this和参数顺序。

var re = /-/g; var str = '2016-01-01'; var newstr = re[Symbol.replace](str, '.' console.log(newstr // 2016.01.01

在子类中使用@@replace

RegExp的子类可以覆写[@@replace]()方法来修改默认行为。

class MyRegExp extends RegExp { constructor(pattern, flags, count) { super(pattern, flags this.count = count; } [Symbol.replace](str, replacement) { // Perform @@replace |count| times. var result = str; for (var i = 0; i < this.count; i++) { result = RegExp.prototype[Symbol.replace].call(this, result, replacement } return result; } } var re = new MyRegExp('\\d', '', 3 var str = '01234567'; var newstr = str.replace(re, '#' // String.prototype.replace calls re[@@replace]. console.log(newstr // ###34567

规范

SpecificationStatusComment
ECMAScript 2015 (6th Edition, ECMA-262)The definition of 'RegExp.prototype@@replace' in that specification.StandardInitial definition.
ECMAScript 2017 Draft (ECMA-262)The definition of 'RegExp.prototype@@replace' in that specification.Draft

浏览器兼容性

FeatureChromeFirefox (Gecko)Internet ExplorerOperaSafari
Basic support?49 (49)???

FeatureAndroidChrome for AndroidFirefox Mobile (Gecko)IE MobileOpera MobileSafari Mobile
Basic support??49.0 (49)???