Symbol.unscopables

Symbol.unscopables

Symbol.unscopables 指用于指定对象值,其对象自身和继承的从关联对象的 with 环境绑定中排除的属性名称。

| Symbol.unscopables 属性的属性特性: |

|:----|

| Writable | no |

| Enumerable | no |

| Configurable | no |

描述

可以在任何对象上定义 @@unscopables symbol (Symbol.unscopables),用于排除属性名称并与 with 环境绑定在一起作为词法变量公开。 请注意,如果使用 Strict mode,语句将不可用,并且可能也不需要 symbol。

在 unscopables 对象上设置属性为 true,将使其 unscopable并且因此该属性也将不会在词法环境变量中出现。 如果设置属性为 false ,则将使其可 scopable 并且该属性会出现在词法环境变量中。

示例

以下代码在ES5及以下版本中正常工作。但是,在ECMAScript 2015及更高版本中,Array.prototype.keys()引入了该方法。这意味着内部with环境“键”现在将是方法而不是变量。这unscopable就是引入s符号的时候。内置unscopables设置的实现是Array.prototype[@@unscopables]为了防止某些Array方法被限制在with语句中。

var keys = []; with (Array.prototype) { keys.push('something' } Object.keys(Array.prototype[Symbol.unscopables] // ["copyWithin", "entries", "fill", "find", "findIndex", // "includes", "keys", "values"]

你也可以为你自己的对象设置 unscopables 。

var obj = { foo: 1, bar: 2 }; obj[Symbol.unscopables] = { foo: false, bar: true }; with (obj) { console.log(foo // 1 console.log(bar // ReferenceError: bar is not defined }

规范

SpecificationStatusComment
ECMAScript 2015 (6th Edition, ECMA-262)The definition of 'Symbol.unscopables' in that specification.StandardInitial definition.
ECMAScript Latest Draft (ECMA-262)The definition of 'Symbol.unscopables' in that specification.Draft

浏览器兼容性

FeatureChromeEdgeFirefox (Gecko)Internet Explorer/EdgeOperaSafari
Basic support38(Yes)48 (48)12No support9

FeatureAndroidChrome for AndroidEdgeFirefox Mobile (Gecko)IE/Edge MobileOpera MobileSafari Mobile
Basic supportNo supportNo support(Yes)48.0 (48)12No support9