--- title: 'RegExp.prototype[@@split]()' slug: Web/JavaScript/Reference/Global_Objects/RegExp/@@split translation_of: Web/JavaScript/Reference/Global_Objects/RegExp/@@split ---
[@@split]()
方法切割 {{jsxref("String")}} 对象为一个其子字符串的数组 。
regexp[Symbol.split](str[, limit])
str
limit
可选。一个为了限制切割数量的特定整数。 [@@split]()
防范仍会切割每个匹配正则模式的匹配项,直到切割数量达到该限制数,除非提前切割完字符串。
包含其子字符串的{{jsxref("Array")}} 。
如果切割器是一个{{jsxref("RegExp")}}对象,这个方法就将在 {{jsxref("String.prototype.split()")}} 的内部调用。例如,下面的两个方法返回相同结果。
'a-b-c'.split(/-/); /-/[Symbol.split]('a-b-c');
这个方法为自定义 RegExp
子类中的匹配行为而存在。
如果str参数不是一个{{jsxref("RegExp")}} 对象, {{jsxref("String.prototype.split()")}} 就不会调用该方法,也不会创建一个 {{jsxref("RegExp")}} 对象。示例
这个方法的使用方式和 {{jsxref("String.prototype.split()")}} 相同,不同之处是 this
和参数顺序。
var re = /-/g; var str = '2016-01-02'; var result = re[Symbol.split](str); console.log(result); // ["2016", "01", "02"]
@@split
{{jsxref("RegExp")}} 的子类可以覆写 [@@split]()
方法来修改默认行为。
class MyRegExp extends RegExp { [Symbol.split](str, limit) { var result = RegExp.prototype[Symbol.split].call(this, str, limit); return result.map(x => "(" + x + ")"); } } var re = new MyRegExp('-'); var str = '2016-01-02'; var result = str.split(re); // String.prototype.split calls re[@@split]. console.log(result); // ["(2016)", "(01)", "(02)"]
Specification | Status | Comment |
---|---|---|
{{SpecName('ES6', '#sec-regexp.prototype-@@split', 'RegExp.prototype[@@split]')}} | {{Spec2('ES6')}} | 初始定义 |
{{SpecName('ESDraft', '#sec-regexp.prototype-@@split', 'RegExp.prototype[@@split]')}} | {{Spec2('ESDraft')}} |