Symbol.match
well-known symbol specifies the matching of a regular expression against a string. This function is called by the
String.prototype.match()
方法。
The source for this interactive example is stored in a GitHub repository. If you'd like to contribute to the interactive examples project, please clone https://github.com/mdn/interactive-examples and send us a pull request.
This function is also used to identify if objects have the behavior of regular expressions. For example, the methods
String.prototype.startsWith()
,
String.prototype.endsWith()
and
String.prototype.includes()
, check if their first argument is a regular expression and will throw a
TypeError
if they are. Now, if the
match
symbol is set to
false
(or a
Falsy
value), it indicates that the object is not intended to be used as a regular expression object.
特性属性在
Symbol.match
|
|
|---|---|
| 可写 | no |
| 可枚举 | no |
| 可配置 | no |
isRegExp
check
The following code will throw a
TypeError
:
'/bar/'.startsWith(/bar/); // Throws TypeError, as /bar/ is a regular expression // and Symbol.match is not modified.
However, if you set
Symbol.match
to
false
,
isRegExp
check (that uses the
match
property) will indicate that the object is not a regular expression object. The methods
startsWith
and
endsWith
won't throw a
TypeError
as a consequence.
var re = /foo/; re[Symbol.match] = false; '/foo/'.startsWith(re); // true '/baz/'.endsWith(re); // false
| 规范 |
|---|
|
ECMAScript (ECMA-262)
The definition of 'Symbol.match' in that specification. |
| Desktop | Mobile | Server | |||||||||||
|---|---|---|---|---|---|---|---|---|---|---|---|---|---|
match
|
Chrome 50 | Edge 79 | Firefox 40 | IE No | Opera 37 | Safari 10 | WebView Android 50 | Chrome Android 50 | Firefox Android 40 | Opera Android 37 | Safari iOS 10 | Samsung Internet Android 5.0 | nodejs 6.0.0 |
完整支持
不支持
Symbol
Function
Object
Object.prototype.__defineGetter__()
Object.prototype.__defineSetter__()
Object.prototype.__lookupGetter__()
Object.prototype.__lookupSetter__()
Object.prototype.hasOwnProperty()
Object.prototype.isPrototypeOf()
Object.prototype.propertyIsEnumerable()
Object.prototype.toLocaleString()
Object.prototype.toSource()
Object.prototype.toString()
Object.prototype.valueOf()
Object.setPrototypeOf()