--- title: Reflect.preventExtensions() slug: Web/JavaScript/Reference/Global_Objects/Reflect/preventExtensions translation_of: Web/JavaScript/Reference/Global_Objects/Reflect/preventExtensions ---
{{JSRef}}

静态方法 Reflect.preventExtensions() 方法阻止新属性添加到对象 (例如:防止将来对对象的扩展被添加到对象中)。该方法与 {{jsxref("Object.preventExtensions()")}}相似,但有一些不同点。详情可见 {{anch("与_Object.preventExtensions_的不同点", "differences")}}。

{{EmbedInteractiveExample("pages/js/reflect-preventextensions.html")}}

语法

Reflect.preventExtensions(target)

参数

target
阻止扩展的目标对象。

返回值

返回一个 {{jsxref("Boolean")}} 值表明目标对象是否成功被设置为不可扩展。

异常

抛出一个 {{jsxref("TypeError")}} 错误,如果 target 不是 {{jsxref("Object")}}。

描述

Reflect.preventExtensions 方法阻止新属性添加到对象 (例如:防止将来对对象的扩展被添加到对象中)。该方法与  {{jsxref("Object.preventExtensions()")}} 方法相似。

示例

使用 Reflect.preventExtensions()

详情可见 {{jsxref("Object.preventExtensions()")}}.

// Objects are extensible by default.
var empty = {};
Reflect.isExtensible(empty); // === true

// ...but that can be changed.
Reflect.preventExtensions(empty);
Reflect.isExtensible(empty); // === false

与 Object.preventExtensions() 的不同点

如果该方法的 target 参数不是一个对象(是原始值),那么将造成一个 {{jsxref("TypeError")}} 异常。 对于{{jsxref("Object.preventExtensions()")}} 方法, 非对象的 target 参数将被强制转换为对象。

Reflect.preventExtensions(1);
// TypeError: 1 is not an object

Object.preventExtensions(1);
// 1

规范

Specification Status Comment
{{SpecName('ES6', '#sec-reflect.preventextensions', 'Reflect.preventExtensions')}} {{Spec2('ES6')}} Initial definition.
{{SpecName('ESDraft', '#sec-reflect.preventextensions', 'Reflect.preventExtensions')}} {{Spec2('ESDraft')}}

浏览器兼容性

{{Compat("javascript.builtins.Reflect.preventExtensions")}}

相关链接