Reflect.preventExtensions()

Baseline Widely available

This feature is well established and works across many devices and browser versions. It’s been available across browsers since September 2016.

La méthode statique Reflect.preventExtensions() permet d'empêcher d'ajouter de nouvelles propriétés à un objet. Cette méthode est semblable à la méthode Object.preventExtensions() (modulo quelques différences).

Exemple interactif

const object1 = {};

console.log(Reflect.isExtensible(object1));
// Expected output: true

Reflect.preventExtensions(object1);

console.log(Reflect.isExtensible(object1));
// Expected output: false

Syntaxe

js
Reflect.preventExtensions(cible);

Paramètres

cible

L'objet cible dont on veut empêcher l'ajout d'autres propriétés.

Valeur de retour

Un booléen qui indique si l'interdiction a bien été mise en place sur l'objet cible.

Exceptions

Une erreur TypeError si cible n'est pas un Object.

Description

La méthode Reflect.preventExtensions permet d'empêcher l'ajout de nouvelles propriétés sur un objet. Cette méthode est semblable à Object.preventExtensions().

Exemples

Utiliser Reflect.preventExtensions()

Voir aussi Object.preventExtensions().

js
// Par défaut les objets sont extensibles
var vide = {};
Reflect.isExtensible(vide); // === true

// ...mais cela peut être modifié
Reflect.preventExtensions(vide);
Reflect.isExtensible(vide); // === false

Différences avec Object.preventExtensions()

Si le premier argument de cette méthode n'est pas un objet (autrement dit c'est une valeur primitive), cela provoquera une TypeError. Object.preventExtensions(), quant à elle, convertira l'argument passé en un objet.

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

Object.preventExtensions(1);
// 1

Spécifications

Specification
ECMAScript® 2025 Language Specification
# sec-reflect.preventextensions

Compatibilité des navigateurs

Report problems with this compatibility data on GitHub
desktopmobileserver
Chrome
Edge
Firefox
Opera
Safari
Chrome Android
Firefox for Android
Opera Android
Safari on iOS
Samsung Internet
WebView Android
WebView on iOS
Deno
Node.js
preventExtensions

Legend

Tip: you can click/tap on a cell for more information.

Full support
Full support

Voir aussi