輪読メモ|JavaScript|オブジェクトと配列におけるdelete演算子の結果
7900 ワード
開眼! JavaScript――言語仕様から学ぶJavaScriptの本質を輪読会で読み進めている最中です。
本書の中で紹介されていたdelete演算子について、Chromeのデベロッパーコンソールを利用して復習・確認した📝になります。
オブジェクトと配列に対してdelete演算子を利用する
オブジェクトの場合
const obj = {1:1, 2:2, 3:3, 4:4};
console.log(obj); // {1: 1, 2: 2, 3: 3, 4: 4}
delete obj['2']; // true
console.log(obj); // {1: 1, 3: 3, 4: 4}
console.log(obj[2]); // undefined
const obj2 = {test: 'aaa'};
console.log(obj2); // {test: 'aaa'}
obj2[test] = undefined;
console.log(obj2); // {test: undefined}
obj2[test] = null;
console.log(obj2); // {test: null}
delete演算子はオブジェクトからプロパティの存在を削除する唯一の方法。
プロパティの値にundefined
やnull
を設定しても、プロパティ値を変更することにすぎない。削除するにはdelete演算子を利用する必要がある。
配列の場合
const ary = [1,2,3,4,5];
console.log(ary); // (5) [1, 2, 3, 4, 5]
delete ary[2]; // true
console.log(ary); // (5) [1, 2, empty, 4, 5]
console.log(ary[2]); // undefined
console.log(ary.length); // 5
delete ary.length; // false
console.log(ary.length); // 5
配列の削除も可能だが、配列の指定要素はundefined
になり、length
は維持される。
プロトタイプチェーンで継承するプロパティは削除できない。
2次元配列の場合
const ary_two = [[1,2,3,4],[5,6,7,8]];
console.log(ary_two); // (2) [Array(4), Array(4)]
delete ary_two[1][2] // true
console.log(ary_two); // (2) [Array(4), Array(4)]
/*
(2) [Array(4), Array(4)]
0: (4) [1, 2, 3, 4]
1: (4) [5, 6, empty, 8]
*/
delete ary_two[1] // true
console.log(ary_two); // (2) [Array(4), empty]
/*
(2) [Array(4), empty]
0: (4) [1, 2, 3, 4]
*/
2次元配列も配列と同様入れ物としての長さは元のまま残ってしまう。
配列とオブジェクトの組み合わせ
オブジェクトのプロパティであれば削除可能だが、配列の場合は通常の配列と同様に入れ物の形は残ってしまう。
現時点でdelete
演算子を利用する機会が無かったために、現環境における運用のイメージは湧いていないが、配列とオブジェクトでdelete
演算子を利用した場合の結果が異なることを理解することができた。
Author And Source
この問題について(輪読メモ|JavaScript|オブジェクトと配列におけるdelete演算子の結果), 我々は、より多くの情報をここで見つけました https://qiita.com/nononosuque/items/0c86bd46c487efd34fd6著者帰属:元の著者の情報は、元のURLに含まれています。著作権は原作者に属する。
Content is automatically searched and collected through network algorithms . If there is a violation . Please contact us . We will adjust (correct author information ,or delete content ) as soon as possible .