欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

詳解es6新增數(shù)組方法簡(jiǎn)便了哪些操作

 更新時(shí)間:2019年05月09日 09:26:35   作者:一個(gè)搬磚工  
這篇文章主要介紹了詳解es6新增數(shù)組方法簡(jiǎn)便了哪些操作,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧

什么是es6?

在這里不過(guò)多闡述,我也是跟著阮一峰大佬的《es6入門 》來(lái)學(xué)習(xí)的,es6新增了很多的方法、屬性,讓我們?cè)诰幋a中得到了很高的提升,在這里只對(duì)array這塊進(jìn)行闡述,其他的就過(guò)不多介紹了。

言歸正傳,在項(xiàng)目中,經(jīng)常會(huì)遇到處理數(shù)據(jù),篩選數(shù)據(jù)的要求,我們更多的會(huì)借助于for循環(huán)來(lái)完成,比如:數(shù)組去重,傳統(tǒng)方法如下(以下所有實(shí)例只列舉一種)

let a = [1,2,2,3,3,4,5];
let b = [a[0]];
for(let i = 0; i < a.length; i++){
  let flag = false;
  for(let j = 0; j < b.length; j++){
    if( a[i] === b[j] ){
      flag = true;
      break;
    }
  }
  if( !flag ){
    b.push(a[i])
  }
}
console.log(b) // [1,2,3,4,5]

上面的是es6之前的處理方法,可以解決問(wèn)題,但代碼量可著實(shí)不少啊!在es6中,只需要一行代碼就可以搞定!

Array.from &&  newSet()

let a = [1,2,2,3,3,4,5];
let b = Array.from(new Set(a))
console.log(b) // [1,2,3,4,5]

是不是及其簡(jiǎn)單!其中 new Set()會(huì)把重復(fù)的數(shù)據(jù)過(guò)濾到,得到一個(gè)類數(shù)組的對(duì)象,Array.from()可以把類數(shù)組的對(duì)象轉(zhuǎn)換為真正的數(shù)組對(duì)象,有興趣的同學(xué)可以對(duì)這兩個(gè)屬性進(jìn)行更加深入的了解。

數(shù)組過(guò)濾

在我們拿到后端數(shù)據(jù)的時(shí)候,可能會(huì)對(duì)數(shù)據(jù)進(jìn)行一些篩選、過(guò)濾,傳統(tǒng)的做法如下

// 取出數(shù)組中name為kele的數(shù)組集合
let a = [
  {
    name: 'kele',
    title: '可口可樂(lè)'
  },
  {
    name: 'kele',
    title: '芬達(dá)'
  },
  {
    name: 'wlg',
    title: '王老吉'
  }
]

let b = [];

for(let i = 0; i < a.length; i++){
  if( a[i].name === 'kele' ){
    b.push(a[i])
  }
}

console.log(b) //[{name: 'kele', title: '可口可樂(lè)'},{name: 'kele', title: '芬達(dá)'}]

es6中的處理方法如下

Array.filter(callback)

let a = [
  {
    name: 'kele',
    title: '可口可樂(lè)'
  },
  {
    name: 'kele',
    title: '芬達(dá)'
  },
  {
    name: 'wlg',
    title: '王老吉'
  }
]

let b = a.filter(item => item.name === 'kele');

console.log(b) //[{name: 'kele', title: '可口可樂(lè)'},{name: 'kele', title: '芬達(dá)'}]

同樣的,Array.filter()讓我們擺脫了for循環(huán),代碼看起來(lái)更加的清爽!

Array.every(callback)

這個(gè)方法主要是判斷數(shù)組中所有的元素都符合條件時(shí),返回true

let a = [1,2,3,4,5];
let b = a.every(item => item > 2);
console.log(b) // false

Array.some(callback)

這個(gè)方法和上一個(gè)略有區(qū)別,這個(gè)方法主要判斷數(shù)組中有一個(gè)元素符合條件,就返回true

let a = [1,2,3,4,5];
let b = a.some(item => item > 2);
console.log(b) // true

Array.find(callback)

這個(gè)方法是返回?cái)?shù)組中符合條件的第一個(gè)元素,否則就返回undefined

let a = [1,2,3,4,5];
let b = a.find(item => item > 2);
console.log(b) // 3

Array.findIndex(callback)

這個(gè)方法是返回?cái)?shù)組中符合條件的第一個(gè)元素的索引值,否則就返回-1

let a = [1,2,3,4,5];
let b = a.findIndex(item => item > 2);
console.log(b) // 2 符合條件的為元素3 它的索引為2

Array.includes(item, finIndex)

這個(gè)方法是判斷數(shù)組中是否包含有指定的值,包含就返回true,否則就是false,它接受兩個(gè)參數(shù),第一個(gè)為搜索的值(必填),第二個(gè)為搜索開始的位置(選填,默認(rèn)從0開始)

let a = [1,2,3,4,5];
let b = a.includes(2);
console.log(b) // true

Array.map(callback)

這個(gè)方法是返回一個(gè)根據(jù)你callback函數(shù)中的條件,返回一個(gè)全新的數(shù)組

let a = [1,2,3,4,5];
let b = a.map(item => item * 2);
console.log(b) // [2,4,6,8,10]

Array.reduce(callback)

這個(gè)方法是根據(jù)callback中的條件對(duì)數(shù)組中的每個(gè)元素都進(jìn)行類加的操作,返回一個(gè)全新的值,下面做兩個(gè)不同的例子,便于理解

/** 第一種 **/
let a = [1,2,3];
let b = a.reduce((i, j) => {
 return i + j;
}, 0);
console.log(b) // b
/** 第二種 **/
let a = [1,2,3];
let b = a.reduce((i,j) => {
 i.push(j)
 return i
},[0])
console.log(b) // [0,1,2,3]

...擴(kuò)展運(yùn)算符

這個(gè)可以很方便的幫我們實(shí)現(xiàn)合并兩個(gè)數(shù)組

let a = [1,2,3];
let b = [4,5,6];
let c = [...a,...b];
console.log(c) // [1,2,3,4,5,6];

小結(jié):基本上新增的一些方法用到的就是這些,一些老的方法例如push、shift、sort等等就不一一列舉了。

以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。

相關(guān)文章

最新評(píng)論