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

范例

Disabling the 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.

浏览器兼容性

The compatibility table on this page is generated from structured data. If you'd like to contribute to the data, please check out https://github.com/mdn/browser-compat-data and send us a pull request. 更新 GitHub 上的兼容性数据
Desktop Mobile Server
Chrome Edge Firefox Internet Explorer Opera Safari Android webview Chrome for Android Firefox for Android Opera for Android Safari on iOS Samsung Internet Node.js
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

图例

完整支持

完整支持

不支持

不支持

另请参阅

元数据

  • 最后修改: