JavaScript 12個有用的數組技巧
數組是Javascript最常見的概念之一,它為我們提供瞭處理數據的許多可能性,熟悉數組的一些常用操作是很有必要的。
數組去重
1、from()疊加new Set()方法
字符串或數值型數組的去重可以直接使用from方法。
var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter']; var uniquePlants = Array.from(new Set(plants)); console.log(uniquePlants); // [ 'Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Mars', 'Jupiter' ]
2、spread操作符(…)
擴展運算符是ES6的一大創新,還有很多強大的功能。
var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter']; var uniquePlants = [...new Set(plants)]; console.log(uniquePlants); // [ 'Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Mars', 'Jupiter' ]
替換數組中的特定值
splice() 方法向/從數組中添加/刪除項目,然後返回被刪除的項目。該方法會改變原始數組。特別需要註意插入值的位置!
// arrayObject.splice(index,howmany,item1,.....,itemX) var plants = ['Saturn', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter']; var result = plants.splice(2, 1, 'www.shanzhonglei.com') console.log(plants); // ['Saturn','Uranus','www.shanzhonglei.com','Mercury','Venus','Earth','Mars','Jupiter'] console.log(result); // ['Mercury']
沒有map()的映射數組
我們先介紹一下map方法。map()方法返回一個新數組,數組中的元素為原始數組元素調用函數處理後的值,它會按照原始數組元素順序依次處理元素。註意: map()不會改變原始數組,也不會對空數組進行檢測。
下面我們來實現一個沒有map的數組映射:
// array.map(function(currentValue,index,arr), thisValue) var plants = [ { name: "Saturn" }, { name: "Uranus" }, { name: "Mercury" }, { name: "Venus" }, ] var plantsName = Array.from(plants, ({ name }) => name); console.log(plantsName); // [ 'Saturn', 'Uranus', 'Mercury', 'Venus' ]
空數組
如果要清空一個數組,將數組的長度設置為0即可,額,這個有點簡單。
var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter']; plants.length = 0; console.log(plants); // []
將數組轉換為對象
如果要將數組轉換為對象,最快的方法莫過於spread運算符(…)。
var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter']; var plantsObj = {...plants } console.log(plantsObj); // {'0': 'Saturn','1': 'Earth', '2': 'Uranus','3': 'Mercury','4': 'Venus','5': 'Earth','6': 'Mars','7': 'Jupiter'}
用數據填充數組
如果我們需要用一些數據來填充數組,或者需要一個具有相同值的數據,我們可以用fill()方法。
var plants = new Array(8).fill('8'); console.log(plants); // ['8', '8', '8','8', '8', '8','8', '8']
合並數組
當然你會想到concat()方法,但是哦,spread操作符(…)也很香的,這也是擴展運算符的另一個應用。
var plants1 = ['Saturn', 'Earth', 'Uranus', 'Mercury']; var plants2 = ['Venus', 'Earth', 'Mars', 'Jupiter']; console.log([...plants1, ...plants2]); // ['Saturn', 'Earth','Uranus', 'Mercury','Venus', 'Earth','Mars', 'Jupiter']
兩個數組的交集
要求兩個數組的交集,首先確保數組不重復,然後使用filter()方法和includes()方法。
var plants1 = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter']; var plants2 = ['Saturn', 'Earth', 'Uranus']; var alonePlants = [...new Set(plants1)].filter(item => plants2.includes(item)); console.log(alonePlants); // [ 'Saturn', 'Earth', 'Uranus' ]
刪除數組中的假值
我們時常需要在處理數據的時候要去掉假值。在Javascript中,假值是false, 0, ” “, null, NaN, undefined。
var plants = ['Saturn', 'Earth', null, undefined, false, "", NaN, 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter']; var trueArr = plants.filter(Boolean); console.log(trueArr); // ['Saturn', 'Earth','Uranus', 'Mercury','Venus', 'Earth','Mars', 'Jupiter']
獲取數組中的隨機值
我們可以根據數組長度獲得一個隨機索引號。
var plants = ['Saturn', 'Earth', 'Uranus', 'Mercury', 'Venus', 'Earth', 'Mars', 'Jupiter']; console.log(plants[Math.floor(Math.random() * (plants.length + 1))])
lastIndexOf()方法
lastIndexOf()可以幫助我們查找元素最後一次出現的索引。
// array.reduce(function(total, currentValue, currentIndex, arr), initialValue) var nums = [1, 2, 3, 4, 5]; var sum = nums.reduce((x, y) => x + y); console.log(sum); // 15
將數組中的所有值相加
reduce()方法接收一個函數作為累加器,數組中的每個值(從左到右)開始縮減,最終計算為一個值。
// array.reduce(function(total, currentValue, currentIndex, arr), initialValue) var nums = [1, 2, 3, 4, 5]; var sum = nums.reduce((x, y) => x + y); console.log(sum); // 15
到此這篇關於JavaScript 12個有用的數組技巧的文章就介紹到這瞭,更多相關JavaScript 數組內容請搜索WalkonNet以前的文章或繼續瀏覽下面的相關文章希望大傢以後多多支持WalkonNet!
推薦閱讀:
- JavaScript循環遍歷的24個方法,你都知道嗎
- 梳理總結25JavaScript數組操作方法實例
- js如何查找json數據中的最大值和最小值方法
- javascript數組includes、reduce的基本使用
- javascript的數組方法大全