Reflect.deleteProperty()
Baseline
Widely available
This feature is well established and works across many devices and browser versions. Itâs been available across browsers since 2016å¹´9æ.
Reflect.deleteProperty() ã¯éçã¡ã½ããã§ãdelete æ¼ç®åã¨åæ§ã«å®è£
ããã¦ãã¾ããã颿°ã¨ãã¦åä½ãã¾ãããªãã¸ã§ã¯ãããããããã£ãåé¤ãã¾ãã
試ãã¦ã¿ã¾ããã
const object = {
foo: 42,
};
Reflect.deleteProperty(object, "foo");
console.log(object.foo);
// äºæ³ãããçµæ: undefined
const array = [1, 2, 3, 4, 5];
Reflect.deleteProperty(array, "3");
console.log(array);
// äºæ³ãããçµæ: Array [1, 2, 3, <1 empty slot>, 5]
æ§æ
Reflect.deleteProperty(target, propertyKey)
弿°
target-
ããããã£ãå®ç¾©ãã対象ã®ãªãã¸ã§ã¯ãã§ãã
propertyKey-
å®ç¾©ã¾ãã¯ä¿®æ£ãããããããã£åã§ãã
è¿å¤
ããããã£ã®å®ç¾©ã«æåãããã©ããã示ãè«çå¤ã§ãã
ä¾å¤
TypeError-
targetããªãã¸ã§ã¯ãã§ã¯ãªãã£ãå ´åã
解説
Reflect.deleteProperty() ã¯ãdelete æ¼ç®åã®åå°çæå³ã¥ããæä¾ãã¾ããã¤ã¾ããReflect.deleteProperty(target, propertyKey) ã¯æå³çã«ä»¥ä¸ã¨åçã§ãã
delete target.propertyKey;
ããåºæ¬çãªã¬ãã«ã§ã¯ãããããã£ã®åé¤ã¯è«çå¤ãè¿ãã¾ãï¼ãããã·ã¼ãã³ãã©ã¼ã®å ´åã¨åæ§ã§ãï¼ãReflect.deleteProperty() ã¯çµæãç´æ¥è¿ãã¾ãããdelete ã¯çµæã false ã®å ´åã峿 ¼ã¢ã¼ã ã§ã¯ TypeError ãçºçãã¾ãã峿 ¼ã¢ã¼ãã§ãªãå ´åã¯ãdelete 㨠Reflect.deleteProperty() ã®åä½ã¯åãã§ãã
Reflect.deleteProperty() ã¯ãtarget ã® [[Delete]] ãªãã¸ã§ã¯ãå
é¨ã¡ã½ãã ãå¼ã³åºãã¾ãã
ä¾
>Reflect.deleteProperty() ã®ä½¿ç¨
const obj = { x: 1, y: 2 };
Reflect.deleteProperty(obj, "x"); // true
console.log(obj); // { y: 2 }
const arr = [1, 2, 3, 4, 5];
Reflect.deleteProperty(arr, "3"); // true
console.log(arr); // [1, 2, 3, <1 empty slot>, 5]
// ãã®ãããªããããã£ãåå¨ããªãå ´åã« true ãè¿ã
Reflect.deleteProperty({}, "foo"); // true
// ããããã£ãè¨å®ä¸å¯ã®å ´åãfalse ãè¿ã
Reflect.deleteProperty(Object.freeze({ foo: 1 }), "foo"); // false
仿§æ¸
| Specification |
|---|
| ECMAScript® 2027 Language Specification> # sec-reflect.deleteproperty> |