JavaScript 配列
JavaScript 配列
JavaScript 配列には任意のデータ型を含めることができ、インデックスを通じて各要素にアクセスできます。
配列の長さを取得するには、長さ属性に直接アクセスします:
var arr = [1, 2, 3.14, 'Hello', null, true]; arr.length; // 6
配列の長さに新しい値を直接割り当てると、配列のサイズが変更されることに注意してください:
var arr = [1, 2, 3]; arr.length; // 3 arr.length = 6; arr; // arr变为[1, 2, 3, undefined, undefined, undefined] arr.length = 2; arr; // arr变为[1, 2]
配列は対応する要素を変更できますしたがって、配列のインデックスに値を割り当てると、配列が直接変更されます:
var arr = ['A', 'B', 'C']; arr[1] = 99; arr; // arr现在变为['A', 99, 'C']
インデックスで割り当てるときにインデックスが範囲を超えると、サイズも変更されることに注意してください。変更する配列:
var arr = [1, 2, 3]; arr[5] = 'x'; arr; // arr变为[1, 2, 3, undefined, undefined, 'x']
他のほとんどのプログラミング言語 配列のサイズを直接変更することは許可されておらず、範囲外のインデックスにアクセスするとエラーが報告されます。ただし、JavaScript 配列にはエラーはありません。コードを記述するとき、配列のサイズを直接変更することは推奨されません。インデックスにアクセスするときは、インデックスが範囲外にならないようにしてください。
indexOf
String と同様に、Array も、indexOf() を通じて指定された要素の位置を検索できます。
var arr = [10, 20, '30', 'xyz']; arr.indexOf(10); // 元素10的索引为0 arr.indexOf(20); // 元素20的索引为1 arr.indexOf(30); // 元素30没有找到,返回-1 arr.indexOf('30'); // 元素'30'的索引为2
数値 30 と文字列 '30' は異なる要素であることに注意してください。
slice
slice() は String の substring() バージョンで、Array のいくつかの要素をインターセプトし、新しい Array を返します。
var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G']; arr.slice(0, 3); // 从索引0开始,到索引3结束,但不包括索引3: ['A', 'B', 'C'] arr.slice(3); // 从索引3开始到结束: ['D', 'E', 'F', 'G']
slice() の開始パラメータと終了パラメータには開始インデックスが含まれることに注意してください。 、終了インデックスではありません。
slice() にパラメータを渡さない場合、最初から最後まですべての要素がインターセプトされます。これを使用すると、配列を簡単にコピーできます:
var arr = ['A', 'B', 'C', 'D', 'E', 'F', 'G']; var aCopy = arr.slice(); aCopy; // ['A', 'B', 'C', 'D', 'E', 'F', 'G'] aCopy === arr; // false
push と Pop
push() は配列の末尾にいくつかの要素を追加し、pop() は配列の最後の要素を削除します:
var arr = [1, 2]; arr.push('A', 'B'); // 返回Array新的长度: 4 arr; // [1, 2, 'A', 'B'] arr.pop(); // pop()返回'B' arr; // [1, 2, 'A'] arr.pop(); arr.pop(); arr.pop(); // 连续pop 3次 arr; // [] arr.pop(); // 空数组继续pop不会报错,而是返回undefined arr; // []
unshift配列の先頭にいくつかの要素を追加したい場合は、unshift() メソッドを使用します。shift() メソッドは配列の最初の要素を削除します。
var arr = [1, 2]; arr.unshift('A', 'B'); // 返回Array新的长度: 4 arr; // ['A', 'B', 1, 2] arr.shift(); // 'A' arr; // ['B', 1, 2] arr.shift(); arr.shift(); arr.shift(); // 连续shift 3次 arr; // [] arr.shift(); // 空数组继续shift不会报错,而是返回undefined arr; // []
sort
sort( ) 現在の配列はソートできます。直接呼び出すと、デフォルトの順序でソートされます。
var arr = ['B', 'C', 'A']; arr.sort(); arr; // ['A', 'B', 'C']指定した順序でソートできますか?もちろん、それについては次の関数で説明します。
reverse
reverse() は、配列全体の要素を削除します。つまり、反転します。
var arr = ['one', 'two', 'three']; arr.reverse(); arr; // ['three', 'two', 'one']
splice
splice() メソッドは、配列を変更するための「汎用メソッド」であり、以下から指定できます。インデックスから開始していくつかの要素を削除し、その位置からいくつかの要素を追加します:
var arr = ['Microsoft', 'Apple', 'Yahoo', 'AOL', 'Excite', 'Oracle']; // 从索引2开始删除3个元素,然后再添加两个元素: arr.splice(2, 3, 'Google', 'Facebook'); // 返回删除的元素 ['Yahoo', 'AOL', 'Excite'] arr; // ['Microsoft', 'Apple', 'Google', 'Facebook', 'Oracle'] // 只删除,不添加: arr.splice(2, 2); // ['Google', 'Facebook'] arr; // ['Microsoft', 'Apple', 'Oracle'] // 只添加,不删除: arr.splice(2, 0, 'Google', 'Facebook'); // 返回[],因为没有删除任何元素 arr; // ['Microsoft', 'Apple', 'Google', 'Facebook', 'Oracle']
concat
concat() メソッド
現在の配列を別の配列に接続し、新しい配列を返します:var arr = ['A', 'B', 'C']; var added = arr.concat([1, 2, 3]); added; // ['A', 'B', 'C', 1, 2, 3] arr; // ['A', 'B', 'C']次の点に注意してください。 concat() メソッドは現在の配列を変更しませんが、新しい配列を返します。 実際、 concat() メソッドは任意の数の要素と配列を受け取ることができ、自動的に配列を分割し、それらをすべて新しい配列に追加します:
var arr = ['A', 'B', 'C']; arr.concat(1, 2, [3, 4]); // ['A', 'B', 'C', 1, 2, 3, 4]
join
join() メソッドは非常に便利です。現在の配列の各要素を指定された文字列と連結し、連結された文字列を返す実用的な 1 つのメソッド:
var arr = ['A', 'B', 'C', 1, 2, 3]; arr.join('-'); // 'A-B-C-1-2-3'
配列の要素が文字列でない場合は、連結前に自動的に文字列に変換されます。
多次元配列
配列の要素も配列である場合、多次元配列を形成できます。例:
var arr = [[1, 2, 3], [400, 500, 600], '-'];
上記の配列には 3 つの要素が含まれており、そのうち最初の 2 つの要素はそれ自体が配列です。