成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專(zhuān)欄INFORMATION COLUMN

JavaScript數(shù)組的9個(gè)方法示例

3403771864 / 352人閱讀

  今天主要就是匯總JavaScript數(shù)組的9中不同方法匯總,也將詳細(xì)示例展示給大家。

202271395325056.png  

如果你還不知道數(shù)組實(shí)例中迭代方法有什么區(qū)別,可以看下面這張圖:202271395325057.png


  map

  代表返回一個(gè)新的數(shù)組,且數(shù)組中的每一項(xiàng)都是執(zhí)行過(guò)map提供的回調(diào)函數(shù)結(jié)果。

  實(shí)現(xiàn)代碼如下:


  const map = (array, fun) => {
  // 類(lèi)型約束
  if (Object.prototype.toString.call(array) !== '[object Array]')
  throw new TypeError(array + ' is not a array')
  if (typeof fun !== 'function') throw new TypeError(fun + ' is not a function')
  // 定義一個(gè)空數(shù)組,用于存放修改后的數(shù)據(jù)
  let res = []
  for (let i = 0; i < array.length; i++) {
  res.push(fun(array[i]))
  }
  return res
  }
  // 測(cè)試
  let res = map(

[1, 2, 3], item => {

  return item * 2

  })

  console.log(res) // [ 2, 4, 6 ]

  filter

  這個(gè)也是返回一個(gè)新的數(shù)組,但不同的是這個(gè)數(shù)組中的值是滿(mǎn)足filter提供的回調(diào)函數(shù)的值,

  實(shí)現(xiàn)代碼如下:


  const filter = (array, fun) => {
  // 類(lèi)型約束
  if (Object.prototype.toString.call(array) !== '[object Array]')
  throw new TypeError(array + ' is not a array')
  if (typeof fun !== 'function') throw new TypeError(fun + ' is not a function')
  // 定義一個(gè)空數(shù)組,用于存放符合條件的數(shù)組項(xiàng)
  let res = []
  for (let i = 0; i < array.length; i++) {
  // 將數(shù)組中的每一項(xiàng)都調(diào)用傳入的函數(shù),如果返回結(jié)果為true,則將結(jié)果push進(jìn)數(shù)組,最后返回
  fun(array[i]) && res.push(array[i])
  }
  return res
  }
  // 測(cè)試
  let res = filter([1, 2, 3], item => {
  return item > 2
  })
  console.log(res) // [ 3 ]

  some

  這是判斷數(shù)組中的每一項(xiàng),當(dāng)有一項(xiàng)滿(mǎn)足回調(diào)函數(shù)中條件就返回true都不滿(mǎn)足則返回false。

  實(shí)現(xiàn)代碼如下:

  const some = (array, fun) => {
  // 類(lèi)型約束
  if (Object.prototype.toString.call(array) !== '[object Array]')
  throw new TypeError(array + ' is not a array')
  if (typeof fun !== 'function') throw new TypeError(fun + ' is not a function')
  let flag = false
  for (let i of array) {
  if (fun(i)) {
  flag = true
  break
  }
  }
  return flag
  }
  let res = some([1, 2, 3], item => {
  return item > 2
  })
  console.log(res) // true

  every

  這也是判斷數(shù)組中的每一項(xiàng),只是它表示的是如果所有項(xiàng)滿(mǎn)足回調(diào)函數(shù)中條件就返回true否則返回false。

  實(shí)現(xiàn)代碼如下:


  const every = (array, fun) => {
  // 類(lèi)型約束
  if (Object.prototype.toString.call(array) !== '[object Array]')
  throw new TypeError(array + ' is not a array')
  if (typeof fun !== 'function') throw new TypeError(fun + ' is not a function')
  let flag = true
  for (let i of array) {
  if (!fun(i)) {
  flag = false
  break
  }
  }
  return flag
  }
  let res = every([1, 2, 3], item => {
  return item > 0
  })
  console.log(res) // true

  reduce

  這個(gè)就是讓數(shù)組中的每個(gè)元素執(zhí)行我們提供的回調(diào)函數(shù),并將結(jié)果匯總返回,實(shí)現(xiàn)代碼如下:

  const reduce = (array, fun, initialValue) => {
  // 類(lèi)型約束
  if (Object.prototype.toString.call(array) !== '[object Array]')
  throw new TypeError(array + ' is not a array')
  if (typeof fun !== 'function') throw new TypeError(fun + ' is not a function')
  let accumulator = initialValue
  for (let i = 0; i < array.length; i++) {
  accumulator = fun(accumulator, array[i], i, array)
  }
  return accumulator
  }
  const arr = [1, 2, 3]
  console.log(arr.reduce(v => v + 10, 10)) // 40
  console.log(reduce(arr, v => v + 10, 10)) // 40

  forEach

  這個(gè)就是遍歷數(shù)組方法,數(shù)組中的每一項(xiàng)都執(zhí)行回調(diào)函數(shù),實(shí)現(xiàn)代碼如下: 

 const forEach = (array, fun) => {
  // 類(lèi)型約束
  if (Object.prototype.toString.call(array) !== '[object Array]')
  throw new TypeError(array + ' is not a array')
  if (typeof fun !== 'function') throw new TypeError(fun + ' is not a function')
  for (let i of array) {
  fun(i)
  }
  }
  let res = forEach([1, 2, 3], item => {
  console.log(item)
  })

  find和findIndex

  這兩個(gè)方法比較類(lèi)似,一個(gè)返回元素,一個(gè)返回元素的索引,這里就編寫(xiě)一個(gè),實(shí)現(xiàn)代碼如下:

  const myFind = (array, fun) => {
  // 類(lèi)型約束
  if (Object.prototype.toString.call(array) !== '[object Array]')
  throw new TypeError(array + ' is not a array')
  if (typeof fun !== 'function') throw new TypeError(fun + ' is not a function')
  let res
  for (let i = 0; i < array.length; i++) {
  if (fun(array[i])) {
  res = array[i]
  }
  }
  return res
  }
  // 測(cè)試
  let res = myFind([1, 2, 3], item => {
  return item > 2
  })
  console.log(res) // 3

  join

  該方法可以將數(shù)組中的所有元素根據(jù)指定的字符串進(jìn)行拼接,并返回拼接后的字符串,

  實(shí)現(xiàn)代碼如下:


  const join = (array, separator = ',') => {
  // 類(lèi)型約束
  if (Object.prototype.toString.call(array) !== '[object Array]')
  throw new TypeError(array + ' is not a array')
  if (typeof separator !== 'string')
  throw new TypeError(separator + ' is not a string')
  let res = array[0].toString()
  for (let i = 0; i < array.length - 1; i++) {
  res += separator + array[i + 1].toString()
  }
  return res
  }
  // 測(cè)試
  let res = join([1, 2, 3], '-')
  console.log(res) // 1-2-3

  總結(jié)

  這九種數(shù)組都已示例,希望大家在運(yùn)用中可以對(duì)每個(gè)都熟練掌握。


文章版權(quán)歸作者所有,未經(jīng)允許請(qǐng)勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。

轉(zhuǎn)載請(qǐng)注明本文地址:http://systransis.cn/yun/127984.html

相關(guān)文章

  • JavaScript Puzzlers! 解惑(一):為什么 ["1", &qu

    摘要:第一題為的返回值。返回值其中的每個(gè)元素均為關(guān)聯(lián)的原始數(shù)組元素的回調(diào)函數(shù)返回值的新數(shù)組。修改數(shù)組對(duì)象數(shù)組對(duì)象可由回調(diào)函數(shù)修改。方法啟動(dòng)后的條件元素是否傳遞給回調(diào)函數(shù)在數(shù)組的原始長(zhǎng)度之外添加元素。 JavaScript Puzzlers! 被稱(chēng)為 javascript 界的專(zhuān)業(yè)八級(jí)測(cè)驗(yàn),感興趣的 jser 可以去試試。 我試了一下, 36 道題只做對(duì)了 19 道, 算下來(lái)正確率為 53%,...

    k00baa 評(píng)論0 收藏0
  • JavaScript中操作數(shù)組常用函數(shù)匯總

    摘要:示例語(yǔ)法作用方法用于刪除并返回?cái)?shù)組的最后一個(gè)元素。返回值一個(gè)新的字符串,該字符串值包含的一個(gè)子字符串,其內(nèi)容是從處到處的所有字符,其長(zhǎng)度為減。返回值一個(gè)新的字符串,包含從的包括所指的字符處開(kāi)始的個(gè)字符。 1.concat()語(yǔ)法:arrayObject.concat(array1,array2,......,arrayn)作用:concat() 方法用于連接兩個(gè)或多個(gè)數(shù)組。特征:該方法...

    beita 評(píng)論0 收藏0
  • JavaScript 基礎(chǔ)知識(shí) - 入門(mén)篇(二)

    摘要:函數(shù)可以沒(méi)有返回值,會(huì)在最后面返回一個(gè)。事物的行為在對(duì)象中用方法來(lái)表示。 11. 函數(shù) 11.1 函數(shù)的基礎(chǔ)知識(shí) 為什么會(huì)有函數(shù)? 在寫(xiě)代碼的時(shí)候,有一些常用的代碼需要書(shū)寫(xiě)很多次,如果直接復(fù)制粘貼的話(huà),會(huì)造成大量的代碼冗余;函數(shù)可以封裝一段重復(fù)的javascript代碼,它只需要聲明一次,就可以多次調(diào)用; 冗余代碼: 冗余:多余的重復(fù)或啰嗦內(nèi)容 缺點(diǎn): 代碼重復(fù),可閱讀性差 ...

    niuxiaowei111 評(píng)論0 收藏0
  • JavaScript 編程精解 中文第三版 四、數(shù)據(jù)結(jié)構(gòu):對(duì)象和數(shù)組

    摘要:本章將介紹基本的數(shù)據(jù)結(jié)構(gòu)。松鼠人一般在晚上八點(diǎn)到十點(diǎn)之間,雅克就會(huì)變身成為一只毛茸茸的松鼠,尾巴上的毛十分濃密。我們將雅克的日記表示為對(duì)象數(shù)組。 來(lái)源:ApacheCN『JavaScript 編程精解 中文第三版』翻譯項(xiàng)目原文:Data Structures: Objects and Arrays 譯者:飛龍 協(xié)議:CC BY-NC-SA 4.0 自豪地采用谷歌翻譯 部分參考了《Jav...

    kamushin233 評(píng)論0 收藏0
  • JavaScript必會(huì)技能——正則表達(dá)式

    摘要:語(yǔ)法參數(shù)必填項(xiàng),字符串或正則表達(dá)式,該參數(shù)指定的地方分割可選該參數(shù)指定返回的數(shù)組的最大長(zhǎng)度,如果設(shè)置了該參數(shù),返回的子字符串不會(huì)多于這個(gè)參數(shù)指定的數(shù)組。該數(shù)組通過(guò)在指定的邊界處將字符串分割成子字符串。把正則表達(dá)式拆分成小表達(dá)式。 正則表達(dá)式是什么 RegExp 對(duì)象表示正則表達(dá)式,它是對(duì)字符串執(zhí)行模式匹配的強(qiáng)大工具。 為什么使用正則表達(dá)式 測(cè)試字符串內(nèi)的模式。例如,可以測(cè)試輸入字符串...

    FrozenMap 評(píng)論0 收藏0

發(fā)表評(píng)論

0條評(píng)論

最新活動(dòng)
閱讀需要支付1元查看
<