ホームページ > ウェブフロントエンド > jsチュートリアル > 20 の一般的な JavaScript 配列操作のまとめ

20 の一般的な JavaScript 配列操作のまとめ

藏色散人
リリース: 2023-04-20 15:43:34
転載
1643 人が閲覧しました

配列JavaScript のオブジェクトは、他のプログラミング言語の配列と同様、データのコレクションです。 JavaScript では、配列内のデータはさまざまな型にすることができ、配列に対して一般的な操作を実行するメソッドがあります。

配列の宣言

宣言方法は 3 種類あります

1. 従来の方法

const hobbys = new Array()
hobbys[0] = 'Basketball'
hobbys[1] = 'Badminton'
hobbys[2] = 'swimming'
console.log(hobbys)
// [ 'Basketball', 'Badminton', 'swimming' ]
ログイン後にコピー

2. 簡潔な方法

const hobbys = new Array('Basketball', 'Badminton','swimming')
console.log(hobbys)
// [ 'Basketball', 'Badminton', 'swimming' ]
ログイン後にコピー

3.リテラル

const hobbys = ['Basketball','Badminton','swimming']
console.log(hobbys)
// [ 'Basketball', 'Badminton', 'swimming' ]
ログイン後にコピー

配列オブジェクト メソッド

1. forEach

forEach() メソッドは、配列の各要素を呼び出し、その要素をコールバック関数に渡すために使用されます。 。戻り値はありません。これは基本的に、各項目に対して関数関数を実行する for ループと同等です。元の配列は変更されません。

// currentValue:必需,当前元素 index:可选,当前元素的索引值 arr:可选,当前元素所属的数组对象。
array.forEach(function(currentValue, index, arr))
ログイン後にコピー
let array = ['a', 'b', 'c']
let func = (currentValue, index, arr) => {
  currentValue += 's'  
  console.log('currentValue:' + currentValue + ' index:' + index + ' arr:' + arr)
}
array.forEach(func)
console.log(array)

// 控制台输出:
// currentValue:as index:0 arr:a,b,c
// currentValue:bs index:1 arr:a,b,c
// currentValue:cs index:2 arr:a,b,c
// [ 'a', 'b', 'c' ]
ログイン後にコピー

2.map

指定された関数を通じて配列の各要素を処理し、処理された配列を返します。

map() メソッドは新しい配列を返し、配列内の要素は関数呼び出し後の元の配列要素の値になります。このメソッドは、元の配列要素の順序で要素を順番に処理します。元の配列は変更されません。

// currentValue:必须,当前元素的值  index:可选,当前元素的索引值 arr:可选,当前元素属于的数组对象
array.map(function(currentValue,index,arr))
ログイン後にコピー
let array = [1, 2, 3, 4, 5]
let result = array.map((item) => { 
  return item += 5
})
console.log(array)
console.log(result)
// [ 1, 2, 3, 4, 5 ]
// [ 6, 7, 8, 9, 10 ]
ログイン後にコピー

3. concat

JavaScript の concat() メソッドは、2 つ以上の配列を連結して結果を返すために使用されます。

// array1, array2, ..., arrayN 必需,该参数可以是具体的值,也可以是数组对象,可以是任意多个
array1.concat(array2,array3,...,arrayN)
ログイン後にコピー
const array1 = ['a', 'b', 'c']
const array2 = ['d', 'e', 'f']
const array3 = array1.concat(array2)
console.log(array3)
const array4 = array1.concat('123')
console.log(array4)
// [ 'a', 'b', 'c', 'd', 'e', 'f' ]
// [ 'a', 'b', 'c', '123' ]
ログイン後にコピー

4.push

JavaScript 配列の push() メソッドは、配列の末尾に 1 つ以上の要素を追加するために使用されます。 、新しい長さを返します。

let fruits = ["Banana", "Orange", "Apple", "Mango"]
let length = fruits.push("Kiwi")
console.log(fruits)
console.log(length)
// [ 'Banana', 'Orange', 'Apple', 'Mango', 'Kiwi' ]
// 5
ログイン後にコピー

5. unshift

unshift() メソッドは、配列の先頭に 1 つ以上の要素を追加し、新しい長さを返します。

let fruits = ["Banana", "Orange", "Apple", "Mango"]
let length = fruits.unshift("Lemon", "Pineapple")
console.log(fruits)
console.log(length)
// [ 'Lemon', 'Pineapple', 'Banana', 'Orange', 'Apple', 'Mango' ]
// 6
ログイン後にコピー

6.pop

pop() メソッドは、配列の最後の要素を削除し、削除された要素を返すために使用されます。

let sites = ['Google', 'Runoob', 'Taobao', 'Zhihu', 'Baidu']
let result = sites.pop()
console.log(sites)
console.log(result)
// [ 'Google', 'Runoob', 'Taobao', 'Zhihu' ]
// Baidu
ログイン後にコピー

7.shift

shift() メソッドは、配列の最初の要素を削除し、最初の要素の値を返すために使用されます

let fruits = ["Banana", "Orange", "Apple", "Mango"];
let result = fruits.shift()
console.log(fruits)
console.log(result)
// [ 'Orange', 'Apple', 'Mango' ]
// Banana
ログイン後にコピー

8. splice

splice() メソッドは、配列内の要素を追加または削除し、削除された要素を返すために使用されます。 array

// 参数 Values: index: 必需,规定从何处添加/删除元素
// howmany: 可选,规定应该删除多少元素 必须是数字,但可以是 "0"
// item1, ..., itemX 可选,要添加到数组的新元素
array.splice(index,howmany,item1,.....,itemX)
ログイン後にコピー
let fruits = ["Banana", "Orange", "Apple", "Mango"]
let result = fruits.splice(1, 2, "Lemon", "Kiwi")
console.log(fruits)
console.log(result)
// [ 'Banana', 'Lemon', 'Kiwi', 'Mango' ]
// [ 'Orange', 'Apple' ]
ログイン後にコピー

9 lice

slice() メソッドは、既存の配列から選択された要素を返します。文字列の一部を抽出し、抽出された部分を新しい文字列として返すこともできます。元の配列は変更されません。

// start: 可选,规定从何处开始选取 若为负值,表示从原数组中的倒数第几个元素开始提取
// end: 可选,规定从何处结束选取 如果没有指定该参数,那么切分的数组包含从start到数组结束的所有元素
array.slice(start, end)
ログイン後にコピー
let fruits = ["Banana", "Orange", "Lemon", "Apple", "Mango"]
let result1 = fruits.slice(1, 3)
let result2 = fruits.slice(2)
console.log(fruits)
console.log(result1)
console.log(result2)
// [ 'Banana', 'Orange', 'Lemon', 'Apple', 'Mango' ]
// [ 'Orange', 'Lemon' ]
// [ 'Lemon', 'Apple', 'Mango' ]
ログイン後にコピー

10. join

join() メソッドは、すべての配列要素を文字列に結合します。 toString() のように動作しますが、区切り文字

// separator: 可选,指定要使用的分隔符 如果省略该参数,则使用逗号作为分隔符
array.join(separator)
ログイン後にコピー
let fruits = ["Banana", "Orange", "Apple", "Mango"];
let energy1 = fruits.join();
let energy2 = fruits.join('-');
console.log(energy1)
console.log(energy2)
// Banana,Orange,Apple,Mango
// Banana-Orange-Apple-Mango
ログイン後にコピー

11 を指定することもできます。every

every() メソッドは、 array match 条件を指定します(関数を通じて提供されます)。

array.every(function(currentValue,index,arr))
ログイン後にコピー
let ages = [32, 33, 16, 40]
let nums = [32, 33, 19, 40]
function checkAdult(age) {
  return age >= 18
}
function checkNums(num) {
  return num >= 18
}
// 16不满足大于18,故结果false
let result1 = ages.every(checkAdult)
// 每一项都满足条件,故结果true
let result2 = nums.every(checkNums)
console.log(result1)
console.log(result2)
// false
// true
ログイン後にコピー

12. filter

filter() メソッドは新しい配列を作成します。新しい配列の要素は、指定された配列内の条件を満たすすべての要素についてチェックされます。条件。元の配列は変更されません。

array.filter(function(currentValue,index,arr), thisValue)
ログイン後にコピー
let ages = [32, 33, 16, 40];
function checkAdult(age) {
  return age >= 18;
}
let result = ages.filter(checkAdult)
console.log(result)
// [ 32, 33, 40 ]
ログイン後にコピー

13.indexOf

indexOf() メソッドは、指定された文字列値が文字列内で最初に出現する位置を返します。見つからない場合、-1

// searchvalue: 必需。规定需检索的字符串值。
// start: 可选的整数参数。规定在字符串中开始检索的位置。值:0~array.length-1
string.indexOf(searchvalue,start)
ログイン後にコピー
let str = "Hello world, welcome to the universe.";
// 输出w所在的下标索引13(空格也算),没有找到会返回-1
let n = str.indexOf("welcome");
console.log(n)
console.log(str[n])
// 13
// w
ログイン後にコピー

14。reduce

reduce() メソッドは、配列内の各値 (左から右) として関数をアキュムレータとして受け取ります。減少が始まり、最終的に値が計算されます。

array.reduce(function(total, currentValue, currentIndex, arr), initialValue)
ログイン後にコピー
let numbers = [2, 3, 5, 6]
function getSum(total, num) {
  return total + num
}
let result = numbers.reduce(getSum, 0)
console.log(result)
// 16
ログイン後にコピー

15. reverse

reverse() メソッドは、配列内の要素の順序を逆にするために使用されます。元の配列を変更し、変更された順序で配列を返します。

let fruits = ["Banana", "Orange", "Apple", "Mango"]
let resut = fruits.reverse()
console.log(fruits)
console.log(resut)
// [ 'Mango', 'Apple', 'Orange', 'Banana' ]
// [ 'Mango', 'Apple', 'Orange', 'Banana' ]
ログイン後にコピー

16. sort

sort() メソッドは、配列の要素をソートするために使用されます。並べ替え順序は、アルファベット順または数値順、および昇順または降順にすることができます。

// sortfunction: 可选。规定排序顺序。必须是函数。
array.sort(sortfunction)
ログイン後にコピー
let fruits = ["Banana", "Orange", "Apple", "Mango"]
let ages = [9, 3, 4, 5, 7, 10]
// 升序
let agesFunAsc = function (ag1,ag2) {
  return ag1 - ag2
}
// 降序
let agesFunDes= function (ag1,ag2) {
  return -(ag1 - ag2)
}
fruits.sort()
ages.sort(agesFunAsc)
console.log(fruits)
console.log(ages)
ages.sort(agesFunDes)
console.log(ages)
// [ 'Apple', 'Banana', 'Mango', 'Orange' ]
// [ 3, 4, 5, 7, 9, 10 ]
// [ 10, 9, 7, 5, 4, 3 ]
ログイン後にコピー

17. toString

toString() メソッドは、数値を文字列に変換するために使用されます。

number.toString(radix)
ログイン後にコピー
let num = 15
let n = num.toString()
// 也可以使用不同的进制把一个数字转换为字符串
// 2进制
let b = num.toString(2);
// 8进制
let c = num.toString(8);
// 16进制
let d = num.toString(16);
console.log(n)
console.log(b)
console.log(c)
console.log(d)
// 15
// 1111
// 17
// f
ログイン後にコピー

18. at

at() メソッドは整数値を受け取り、at インデックスの値を返します。正と負の整数の両方が受け入れられます。負の整数は、配列内の最後の項目からカウントダウンすることを意味します。

array.at(index)
ログイン後にコピー
let str = 'helso word'
let item1 = str.at(2)
let item2 = str.at(-1)
console.log(item1)
console.log(item2)
// l
// d
ログイン後にコピー

19. find

find() メソッドは、テストに合格した (関数内で判定された) 配列の最初の要素の値を返します。

array.find(function(currentValue, index, arr),thisValue)
ログイン後にコピー
let ages = [3, 10, 18, 20];
function checkAdult(age) {
  return age >= 18;
}
let value = ages.find(checkAdult)
console.log(value)
// 18
ログイン後にコピー

20. some

some() メソッドは、配列内の要素が指定された条件 (関数によって提供される) を満たしているかどうかを検出するために使用されます。

ああああああ

以上が20 の一般的な JavaScript 配列操作のまとめの詳細内容です。詳細については、PHP 中国語 Web サイトの他の関連記事を参照してください。

関連ラベル:
ソース:juejin.im
このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。
最新の問題
人気のチュートリアル
詳細>
最新のダウンロード
詳細>
ウェブエフェクト
公式サイト
サイト素材
フロントエンドテンプレート