BACK
Featured image of post JavaScript 中關於 Array 的 13 個入門小技巧!

JavaScript 中關於 Array 的 13 個入門小技巧!

Array 是 JavaScript 中最常用到的概念之一,處理資料時很常用到這種資料結構;這篇文章介紹一些陣列操作的基本方法,希望對你有幫助!

參考網站
參考網站

陣列是 JavaScript 中最常用到的概念之一。處理資料時很常用到這種資料結構。這篇文章介紹一些陣列操作的基本方法,希望對你有幫助!


從陣列中移除重複項目

很經典的面試問題,需要從陣列中找出獨立值。使用 Set 資料型態,可以輕易完成這任務。這邊介紹兩種方法,一個使用 .from() 一個使用 … 展開運算子

1
2
3
4
5
6
7
8
9
var fruits = ["banana", "apple", "orange", "watermelon", "apple", "orange", "grape", "apple"];

// First method
var uniqueFruits = Array.from(new Set(fruits));
console.log(uniqueFruits); // returns ["banana", "apple", "orange", "watermelon", "grape"]

// Second method
var uniqueFruits2 = [...new Set(fruits)];
console.log(uniqueFruits2); // returns ["banana", "apple", "orange", "watermelon", "grape"]

從陣列中抽換掉某個元素

這個情境也很常見。有一個簡單的好方法,就是使用 .splice ,參數分別是開始修改的位置、修改幾個元素、要更改成哪些值。

1
2
3
var fruits = ["banana", "apple", "orange", "watermelon", "apple", "orange", "grape", "apple"];
fruits.splice(0, 2, "potato", "tomato");
console.log(fruits); // returns ["potato", "tomato", "orange", "watermelon", "apple", "orange", "grape", "apple"]

不用 .map() 的 map 功能

.map() 很常用、大家都會用,但有一個方法也很不錯,也很簡潔,就是 .from()

 1
 2
 3
 4
 5
 6
 7
 8
 9
10
11
12
var friends = [
  { name: "John", age: 22 },
  { name: "Peter", age: 23 },
  { name: "Mark", age: 24 },
  { name: "Maria", age: 22 },
  { name: "Monica", age: 21 },
  { name: "Martha", age: 19 },
]


var friendsNames = Array.from(friends, ({name}) => name);
console.log(friendsNames); // returns ["John", "Peter", "Mark", "Maria", "Monica", "Martha"]

清空陣列

有時候你會需要清空一個陣列。一個一個把元素刪掉太慢了,下面這個方法快多了:直接把長度設為 0 吧!

1
2
3
4
5
var fruits = ["banana", "apple", "orange", "watermelon", "apple", "orange", "grape", "apple"];


fruits.length = 0;
console.log(fruits); // returns []

把陣列轉換為物件

有時需要把陣列轉成物件。使用 … 展開運算子可以很快完成這任務。

1
2
3
var fruits = ["banana", "apple", "orange", "watermelon"];
var fruitsObj = { ...fruits };
console.log(fruitsObj); // returns {0: "banana", 1: "apple", 2: "orange", 3: "watermelon", 4: "apple", 5: "orange", 6: "grape", 7: "apple"}

陣列塞滿資料

有時需要把一個陣列塞滿某些資料。使用 .fill() 可以快速完成這任務:

1
2
var newArray = new Array(10).fill("1");
console.log(newArray); // returns ["1", "1", "1", "1", "1", "1", "1", "1", "1", "1", "1"]

合併陣列

老方法是使用 .concat() 來合併。但有個新方法,就是用 … 展開運算子,非常簡單俐落:

1
2
3
4
5
var fruits = ["apple", "banana", "orange"];
var meat = ["poultry", "beef", "fish"];
var vegetables = ["potato", "tomato", "cucumber"];
var food = [...fruits, ...meat, ...vegetables];
console.log(food); // ["apple", "banana", "orange", "poultry", "beef", "fish", "potato", "tomato", "cucumber"]

找出陣列交集

這也是 JavaScript 面試最常見的問題。這邊使用 filter.includes() 來完成這任務。

1
2
3
4
var numOne = [0, 2, 4, 6, 8, 8];
var numTwo = [1, 2, 3, 4, 5, 6];
var duplicatedValues = [...new Set(numOne)].filter(item => numTwo.includes(item));
console.log(duplicatedValues); // returns [2, 4, 6]

false 相關的值從陣列移除

false 相關值包含 false0""nullNaNundefined

使用 .filter() 可以俐落地過濾陣列。

1
2
3
var mixedArr = [0, "blue", "", NaN, 9, true, undefined, "white", false];
var trueArr = mixedArr.filter(Boolean);
console.log(trueArr); // returns ["blue", 9, true, "white"]

從陣列撈出隨機元素

有時需要隨機撈元素出來。根據陣列長度,隨機撈一個索引出來,就可以囉。

1
2
var colors = ["blue", "white", "green", "navy", "pink", "purple", "orange", "yellow", "black", "brown"];
var randomColor = colors[(Math.floor(Math.random() * (colors.length)))]

逆轉陣列

不需要複雜的迴圈跟函數,也能逆轉一個陣列。這樣一行就可以:

1
2
3
var colors = ["blue", "white", "green", "navy", "pink", "purple", "orange", "yellow", "black", "brown"];
var reversedColors = colors.reverse();
console.log(reversedColors); // returns ["brown", "black", "yellow", "orange", "purple", "pink", "navy", "green", "white", "blue"]

.lastIndexOf() 方法

這個有趣的方法,可以找到特定元素最後一次出現的索引。如果陣列中有重複值,就可用上這方法。

1
2
3
var nums = [1, 5, 2, 6, 3, 5, 2, 3, 6, 5, 2, 7];
var lastIndex = nums.lastIndexOf(5);
console.log(lastIndex); // returns 9

陣列中全部數值加總

這也是面試常見考題。使用 .reduce 可以快速解決這問題。

1
2
3
var nums = [1, 5, 2, 6];
var sum = nums.reduce((x, y) => x + y);
console.log(sum); // returns 14

comments powered by Disqus