--- title: Reflect.preventExtensions() slug: Web/JavaScript/Reference/Global_Objects/Reflect/preventExtensions tags: - ECMAScript 2015 - JavaScript - Method - Reference - Reflect translation_of: Web/JavaScript/Reference/Global_Objects/Reflect/preventExtensions ---
静的な Reflect.preventExtensions()
メソッドは、すでにプロパティが追加されたオブジェクトに、新しいプロパティを抑制します (つまり、オブジェクトのさらなる拡張を抑制します)。 {{jsxref("Object.preventExtensions()")}} に似ていますが、違いがあります。
Reflect.preventExtensions(target)
target
{{jsxref("Boolean")}} で、対象が拡張の抑止の設定に成功したかどうかを表します。
{{jsxref("TypeError")}}: target
が {{jsxref("Object")}} ではない場合
Reflect.preventExtensions
メソッドは、すでにプロパティが追加されたオブジェクトに、新しいプロパティを抑制します (つまり、オブジェクトのさらなる拡張を抑制します)。これは {{jsxref("Object.preventExtensions()")}} と同様のメソッドです。
{{jsxref("Object.preventExtensions()")}} も参照してください。
// オブジェクトは既定で拡張可能。 let empty = {} Reflect.isExtensible(empty) // === true // ...しかし、変更できる。 Reflect.preventExtensions(empty) Reflect.isExtensible(empty) // === false
このメソッドへの最初の引数がオブジェクトではない (プリミティブである) 場合、 {{jsxref("TypeError")}} が発生します。 {{jsxref("Object.preventExtensions()")}} では、 target
がオブジェクトではない場合はオブジェクトに強制的に変換されます。
Reflect.preventExtensions(1) // TypeError: 1 is not an object Object.preventExtensions(1) // 1
仕様書 |
---|
{{SpecName('ESDraft', '#sec-reflect.preventextensions', 'Reflect.preventExtensions')}} |
{{Compat("javascript.builtins.Reflect.preventExtensions")}}