--- title: 'RegExp.prototype[@@replace]()' slug: Web/JavaScript/Reference/Global_Objects/RegExp/@@replace tags: - JavaScript - RegExp - 正则表达式 translation_of: Web/JavaScript/Reference/Global_Objects/RegExp/@@replace ---
[@@replace]() 方法会在一个字符串中用给定的替换器,替换所有符合正则模式的匹配项,并返回替换后的新字符串结果。用来替换的参数可以是一个字符串或是一个针对每次匹配的回调函数。
{{EmbedInteractiveExample("pages/js/regexp-prototype-@@replace.html")}}
regexp[Symbol.replace](str, newSubStr|function)
strnewSubStr (replacement)function (replacement)用替换器替换相应匹配项后的新字符串。
如果匹配模式也是{{jsxref("RegExp")}}对象,这个方法在 {{jsxref("String.prototype.replace()")}} 的内部调用。例如,下面的两个方法返回相同结果。
'abc'.replace(/a/, 'A');
/a/[Symbol.replace]('abc', 'A');
该方法是为了在RegExp子类中自定义匹配的替换模式。
如果匹配模式不是一个{{jsxref("RegExp")}} 对象, {{jsxref("String.prototype.replace()")}} 就不会调用该方法,也不会创建一个 {{jsxref("RegExp")}}对象。
这个方法基本可以和 {{jsxref("String.prototype.replace()")}} 一样使用, 不同之处是 this 和参数顺序。
var re = /-/g; var str = '2016-01-01'; var newstr = re[Symbol.replace](str, '.'); console.log(newstr); // 2016.01.01
{{jsxref("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
| 规范 | 状态 | 备注 |
|---|---|---|
| {{SpecName('ES6', '#sec-regexp.prototype-@@replace', 'RegExp.prototype[@@replace]')}} | {{Spec2('ES6')}} | 初始定义 |
| {{SpecName('ESDraft', '#sec-regexp.prototype-@@replace', 'RegExp.prototype[@@replace]')}} | {{Spec2('ESDraft')}} |
{{Compat("javascript.builtins.RegExp.@@replace")}}