使用JavaScript實現ES數組的常見操作

一、創建數組

在JavaScript中,通過[]或Array()函數可以創建一個新的數組。如果想要定長的空數組,可以使用new Array(length)來創建。

let arr1 = []; //空數組
let arr2 = Array(); //空數組
let arr3 = new Array(3); //長度為3的空數組
console.log(arr1); // []
console.log(arr2); // []
console.log(arr3); // [undefined, undefined, undefined]

如果想要指定數組中的元素,可以直接使用數組字面量或者在Array()函數中傳入元素。

let arr4 = ['apple', 'banana', 'orange']; //包含3個元素的數組
let arr5 = Array('dog', 'cat', 'fish'); //包含3個元素的數組
console.log(arr4); // ["apple", "banana", "orange"]
console.log(arr5); // ["dog", "cat", "fish"]

二、遍曆數組

遍曆數組是常見的操作之一,可以使用for循環或者foreach函數。for循環可以通過下標來訪問數組元素,而foreach函數則可以直接訪問每個元素。

let arr = ['apple', 'banana', 'orange'];
//使用for循環遍曆數組
for(let i=0; i<arr.length; i++){
  console.log(arr[i]);
}
//使用foreach函數遍曆數組
arr.forEach(function(item) {
  console.log(item);
})

三、添加/刪除元素

1. push/pop

push方法可以向數組尾部添加一個或多個元素,同時修改原數組;pop方法可以刪除數組尾部的元素並返回刪除的元素。這兩個方法都可以方便地處理棧。

let arr = ['apple', 'banana', 'orange'];
arr.push('grape'); //返回新數組長度
console.log(arr); // ["apple", "banana", "orange", "grape"]
let lastItem = arr.pop(); //返回刪除的元素
console.log(lastItem); // "grape"
console.log(arr); // ["apple", "banana", "orange"]

2. unshift/shift

unshift方法可以向數組頭部添加一個或多個元素,同時修改原數組;shift方法可以刪除數組頭部的元素並返回刪除的元素。這兩個方法都可以方便地處理隊列。

let arr = ['apple', 'banana', 'orange'];
arr.unshift('grape'); //返回新數組長度
console.log(arr); // ["grape", "apple", "banana", "orange"]
let firstItem = arr.shift(); //返回刪除的元素
console.log(firstItem); // "grape"
console.log(arr); // ["apple", "banana", "orange"]

3. splice

splice方法可以在指定的位置添加/刪除元素。可以通過splice(index, count, item1, item2…)來在index處刪除count個元素,並添加item1, item2…。如果只是想刪除元素,則可以使用splice(index, count)。

let arr = ['apple', 'banana', 'orange'];
arr.splice(1, 1, 'grape', 'kiwi'); //在index=1處刪除1個元素,然後添加兩個元素
console.log(arr); // ["apple", "grape", "kiwi", "orange"]
arr.splice(2, 1); //在index=2處刪除1個元素
console.log(arr); // ["apple", "grape", "orange"]

四、轉換數組

1. join/split

join方法可以將數組中的元素以指定的分隔符連接成字元串,split方法可以將字元串按照指定的分隔符切分成數組。

let arr = ['apple', 'banana', 'orange'];
let joinStr = arr.join(', '); //使用指定的分隔符連接數組元素
console.log(joinStr); // "apple, banana, orange"
let splitArr = joinStr.split(', '); //使用指定的分隔符切分字元串為數組
console.log(splitArr); // ["apple", "banana", "orange"]

2. map/filter/reduce

這三個函數是用於遍曆數組並操作每個元素的常見函數之一。map函數可以根據指定的函數對數組中的每個元素進行操作並返回操作後的數組;filter函數可以根據指定的函數對數組中的元素進行篩選返回符合條件的元素集合;reduce函數可以根據指定的函數對數組中的元素進行累積計算,並返回計算結果。

let arr = [1, 2, 3, 4, 5];
let mapArr = arr.map(function(item){
  return item*2;
});//對數組中的每個元素進行操作
console.log(mapArr); // [2, 4, 6, 8, 10]
let filterArr = arr.filter(function(item){
  return item%2==0;
});//篩選出數組中符合條件的元素
console.log(filterArr); // [2, 4]
let reduceSum = arr.reduce(function(total, item){
  return total + item;
});//對數組中的元素進行累積計算
console.log(reduceSum); // 15

五、排序/查找元素

1. sort/reverse

sort函數可以根據指定的排序規則對數組中的元素進行排序,默認是按照unicode編碼進行排序;reverse函數可以將數組中的元素反轉。

let arr = ['c', 'a', 'd', 'b'];
arr.sort(); //按照unicode編碼進行排序
console.log(arr); // ["a", "b", "c", "d"]
arr.reverse(); //反轉數組
console.log(arr); // ["d", "c", "b", "a"]

2. indexOf/lastIndexOf

indexOf函數可以返回指定元素在數組中的索引值,lastIndexOf函數可以返回從末尾開始的第一個指定元素在數組中的索引值。如果數組中不存在該元素,則返回-1。

let arr = ['apple', 'banana', 'orange', 'apple'];
let index1 = arr.indexOf('apple'); //返回元素在數組中的索引值
console.log(index1); // 0
let index2 = arr.lastIndexOf('apple'); //返回倒數第一個元素在數組中的索引值
console.log(index2); // 3
let index3 = arr.indexOf('grape'); //元素不存在,返回-1
console.log(index3); // -1

3. includes

includes函數可以判斷指定元素是否存在於數組中,並返回布爾值。

let arr = ['apple', 'banana', 'orange'];
let isInclude = arr.includes('apple'); //判斷元素是否存在於數組中
console.log(isInclude); // true
let isInclude2 = arr.includes('grape');
console.log(isInclude2); // false

原創文章,作者:VENUM,如若轉載,請註明出處:https://www.506064.com/zh-tw/n/316411.html

(0)
打賞 微信掃一掃 微信掃一掃 支付寶掃一掃 支付寶掃一掃
VENUM的頭像VENUM
上一篇 2025-01-09 12:14
下一篇 2025-01-09 12:14

相關推薦

  • Python棧操作用法介紹

    如果你是一位Python開發工程師,那麼你必須掌握Python中的棧操作。在Python中,棧是一個容器,提供後進先出(LIFO)的原則。這篇文章將通過多個方面詳細地闡述Pytho…

    編程 2025-04-29
  • Python導入數組

    本文將為您詳細闡述Python導入數組的方法、優勢、適用場景等方面,並附上代碼示例。 一、numpy庫的使用 numpy是Python中一個強大的數學庫,其中提供了非常豐富的數學函…

    編程 2025-04-29
  • Python返回數組:一次性搞定多種數據類型

    Python是一種多用途的高級編程語言,具有高效性和易讀性的特點,因此被廣泛應用於數據科學、機器學習、Web開發、遊戲開發等各個領域。其中,Python返回數組也是一項非常強大的功…

    編程 2025-04-29
  • Python去掉數組的中括弧

    在Python中,被中括弧包裹的數據結構是列表,列表是Python中非常常見的數據類型之一。但是,有些時候我們需要將列表展開成一維的數組,並且去掉中括弧。本文將為大家詳細介紹如何用…

    編程 2025-04-29
  • Python操作數組

    本文將從多個方面詳細介紹如何使用Python操作5個數組成的列表。 一、數組的定義 數組是一種用於存儲相同類型數據的數據結構。Python中的數組是通過列表來實現的,列表中可以存放…

    編程 2025-04-29
  • Python操作MySQL

    本文將從以下幾個方面對Python操作MySQL進行詳細闡述: 一、連接MySQL資料庫 在使用Python操作MySQL之前,我們需要先連接MySQL資料庫。在Python中,我…

    編程 2025-04-29
  • Python磁碟操作全方位解析

    本篇文章將從多個方面對Python磁碟操作進行詳細闡述,包括文件讀寫、文件夾創建、刪除、文件搜索與遍歷、文件重命名、移動、複製、文件許可權修改等常用操作。 一、文件讀寫操作 文件讀寫…

    編程 2025-04-29
  • Python代碼實現迴文數最少操作次數

    本文將介紹如何使用Python解決一道經典的迴文數問題:給定一個數n,按照一定規則對它進行若干次操作,使得n成為迴文數,求最少的操作次數。 一、問題分析 首先,我們需要了解迴文數的…

    編程 2025-04-29
  • Python元祖操作用法介紹

    本文將從多個方面對Python元祖的操作進行詳細闡述。包括:元祖定義及初始化、元祖遍歷、元祖切片、元祖合併及比較、元祖解包等內容。 一、元祖定義及初始化 元祖在Python中屬於序…

    編程 2025-04-29
  • Python列表的讀寫操作

    本文將針對Python列表的讀取與寫入操作進行詳細的闡述,包括列表的基本操作、列表的增刪改查、列表切片、列表排序、列表反轉、列表拼接、列表複製等操作。 一、列表的基本操作 列表是P…

    編程 2025-04-29

發表回復

登錄後才能評論