日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区

您的位置:首頁技術文章
文章詳情頁

JavaScript手寫數組的常用函數總結

瀏覽:156日期:2023-06-14 15:27:24
前言

在開發過程中,我們常常使用數組的一些 api 相關操作,其中包含 forEach 、 filter 、 find 、 findIndex 、 map 、 some 、 every 、 reduce 、 reduceRight 等函數方法。

今天,我們試試手寫這些函數,實現數組這些函數方法。為了方便,直接在數組原型對象 prototype 上擴展。

本文 Githab 已上傳,更多往期文章已分類整理。

正文

參數說明

callbackFn 回調函數

thisArg 執行 callbackFn 時使用的 this 值

currentValue 數組中正在處理的元素

index 當前索引

array 源數組

accumulator 累加器

initialValue reduce reduceRight 第一次調用 callbackFn 函數時的第一個參數的值默認值

element 自己實現的 this 對象

forEach 函數

語法: arr.forEach(callbackFn(currentValue [, index [, array]])[, thisArg])

方法功能: 對數組的每個元素執行一次給定的函數。

返回:undefined。

自定義函數:myForEach。

Array.prototype.myForEach = function(callbackFn, thisArg) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element && element.length || 0; if (!thisArg) thisArg = element; for (let index = 0; index < len; index++) { callbackFn.call(thisArg, element[index], index, element); }};filter 函數

語法: var newArray = arr.filter(callbackFn(currentValue[, index[, array]])[, thisArg])

方法功能: 創建一個新數組, 其包含通過所提供函數實現的測試的所有元素。

返回:一個新的、由通過測試的元素組成的數組,如果沒有任何數組元素通過測試,則返回空數組。

自定義函數:myFilter。

Array.prototype.myFilter = function(callbackFn, thisArg) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element && element.length || 0, result = []; if (!thisArg) thisArg = element; for (let index = 0; index < len; index++) { if (callbackFn.call(thisArg, element[index], index, element)) result.push(element[index]); } return result;};find 函數

語法: arr.find(callbackFn[, thisArg])

方法功能: 返回數組中滿足提供的測試函數的第一個元素的值。否則返回 undefined。

返回:數組中第一個滿足所提供測試函數的元素的值,否則返回 undefined。

自定義函數:myFind。

Array.prototype.myFind = function(callbackFn, thisArg) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element && element.length || 0; if (!thisArg) thisArg = element; for (let index = 0; index < len; index++) { if (callbackFn.call(thisArg, element[index], index, element)) { return element[index]; } } return}findIndex 函數

語法: arr.findIndex(callbackFn[, thisArg])

方法功能: 返回數組中滿足提供的測試函數的第一個元素的值。否則返回 undefined。

返回:數組中通過提供測試函數的第一個元素的索引。否則,返回-1。

自定義函數:myFindIndex。

Array.prototype.myFindIndex = function(callbackFn, thisArg) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element && element.length || 0; if (!thisArg) thisArg = element; for (let index = 0; index < len; index++) { if (callbackFn.call(thisArg, element[index], index, element)) return index; } return -1;}fill函數

語法: arr.fill(value[, start[, end]])

方法功能: 用一個固定值填充一個數組中從起始索引到終止索引內的全部元素。不包括終止索引。

返回:返回替換的值,原數組發生改變。

自定義函數:myFill。

Array.prototype.myFill = function(value, start = 0, end) { let element = this, len = element && element.length || 0; end = end || len; let loopStart = start < 0 ? 0 : start, // 設置循環開始值 loopEnd = end >= len ? len : end; // 設置循環結束值 for (; loopStart < loopEnd; loopStart++) { element[loopStart] = value; } return element;}map 函數

語法: var new_array = arr.map(function callbackFn(currentValue[, index[, array]]) {// Return element for new_array }[, thisArg])

方法功能: 創建一個新數組,其結果是該數組中的每個元素是調用一次提供的函數后的返回值。

返回:測試數組中是不是至少有1個元素通過了被提供的函數測試。它返回的是一個Boolean類型的值。 一個由原數組每個元素執行回調函數的結果組成的新數組。

自定義函數:myMap。

Array.prototype.myMap = function(callbackFn, thisArg) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element && element.length || 0, result = []; if (!thisArg) thisArg = element; for (let index = 0; index < len; index++) { result[index] = callbackFn.call(thisArg, element[index], index, element); } return result;}some 函數

語法: arr.some(callbackFn(currentValue[, index[, array]])[, thisArg])

方法功能: 測試數組中是不是至少有1個元素通過了被提供的函數測試。它返回的是一個Boolean類型的值。

返回:數組中有至少一個元素通過回調函數的測試就會返回true;所有元素都沒有通過回調函數的測試返回值才會為false。

自定義函數:mySome。

Array.prototype.mySome = function(callbackFn, thisArg) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element && element.length || 0; if (!thisArg) thisArg = element; for (let index = 0; index < len; index++) { if (callbackFn.call(thisArg, element[index], index, element)) return true; } return false;}every 函數

語法: arr.every(callbackFn(currentValue[, index[, array]])[, thisArg])

方法功能 :測試一個數組內的所有元素是否都能通過某個指定函數的測試。它返回一個布爾值。

返回:如果回調函數的每一次返回都為 true 值,返回 true,否則返回 false。

自定義函數:myEvery。

Array.prototype.myEvery = function(callbackFn, thisArg) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element && element.length || 0; if (!thisArg) thisArg = element; for(let index = 0; index < len; index++) { if (!callbackFn.call(thisArg, element[index], index, element)) return false; } return true;}reduce 函數

語法: arr.reduce(callback(accumulator, currentValue[, index[, array]])[, initialValue])

方法功能: 對數組中的每個元素執行一個由您提供的reducer函數(升序執行),將其結果匯總為單個返回值。

返回:函數累計處理的結果。

自定義函數:myReduce。

Array.prototype.myReduce = function(callbackFn, initialValue) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element.length || 0, index = 0, result; if (arguments.length >= 2) { result = arguments[1]; } else { while (index < len && !(index in element)) index++; if (index >= len) throw new TypeError(’Reduce of empty array ’ + ’with no initial value’); result = element[index++]; } while (index < len) { if (index in element) result = callbackFn(result, element[index], index, element); index++; } return result;}reduceRight 函數

語法: arr.reduceRight(callback(accumulator, currentValue[, index[, array]])[, initialValue])

方法功能: 接受一個函數作為累加器(accumulator)和數組的每個值(從右到左)將其減少為單個值。

返回:執行之后的返回值。

自定義函數:myReduceRight。

Array.prototype.myReduceRight = function(callbackFn, initialValue) { if (typeof callbackFn !== ’function’) throw (’callbackFn參數必須是函數’); let element = this, len = element.length || 0, index = len - 1, result; if (arguments.length >= 2) { result = arguments[1]; } else { while (index >= 0 && !(index in element)) { index--; } if (index < 0) { throw new TypeError(’reduceRight of empty array with no initial value’); } result = element[index--]; } for (; index >= 0; index--) { if (index in element) { result = callbackFn(result, element[index], index, element); } } return result;}最后

到此這篇關于JavaScript手寫數組常用函數總結的文章就介紹到這了,更多相關JS手寫數組常用函數內容請搜索好吧啦網以前的文章或繼續瀏覽下面的相關文章希望大家以后多多支持好吧啦網!

標簽: JavaScript
相關文章:
日本不卡不码高清免费观看,久久国产精品久久w女人spa,黄色aa久久,三上悠亚国产精品一区二区三区
日本一不卡视频| 国产精品白浆| 高清久久精品| 日本va欧美va欧美va精品| 五月天激情综合网| 黑丝一区二区三区| 欧美.日韩.国产.一区.二区| 亚洲福利国产| 99亚洲视频| 亚洲精品成人一区| 国产剧情一区二区在线观看| 久久国内精品自在自线400部| 婷婷综合成人| 久久精品一本| 91精品国产调教在线观看| 伊人久久婷婷| 国产日韩一区二区三区在线播放 | 日韩精品麻豆| 日av在线不卡| 精品视频91| 亚洲视频播放| 国产精品一区二区三区av| 国产欧美一区二区三区精品酒店| 91tv亚洲精品香蕉国产一区| 中文字幕一区二区精品区| 国产精品入口久久| 欧美~级网站不卡| 日韩**一区毛片| 三上悠亚国产精品一区二区三区 | 国产精品日韩精品在线播放| 欧美午夜精彩| 国产精品白丝一区二区三区| 欧美福利在线| 精品一级视频| 亚洲18在线| 亚洲精品电影| 成人在线视频中文字幕| 亚洲一区二区三区无吗| 亚洲天堂av影院| 国产精选久久| 亚洲人成亚洲精品| 国产一区二区亚洲| 日韩美女精品| 免费美女久久99| re久久精品视频| 日韩久久一区二区三区| 国产精品免费不| 日韩区欧美区| 亚洲综合激情在线| 国产亚洲精品美女久久| 日韩精品欧美精品| 蜜桃久久久久| 手机精品视频在线观看| 美女少妇全过程你懂的久久| 91亚洲一区| 麻豆国产精品视频| 少妇精品久久久一区二区| 中文在线不卡| 黄色日韩在线| 国产亚洲精品久久久久婷婷瑜伽| 婷婷成人在线| 久久中文字幕av| 午夜电影亚洲| 久久av一区| 亚洲欧洲日韩| 奇米亚洲欧美| 国产一区丝袜| 97精品一区| 日韩精品一区二区三区免费观看| 日本蜜桃在线观看视频| 亚洲播播91| 久久中文字幕二区| 亚洲一区二区免费在线观看| 日本强好片久久久久久aaa| 国产精区一区二区| 国产中文在线播放| 蜜臀av免费一区二区三区| 日韩午夜一区| 日韩国产在线观看| 精品国产乱码久久久| 色偷偷色偷偷色偷偷在线视频| 四虎4545www国产精品 | 91亚洲无吗| 精品亚洲a∨一区二区三区18| 亚洲精品福利电影| 亚洲美女91| 福利一区二区免费视频| 蜜桃一区二区三区| 国产欧美日韩在线观看视频| 日韩黄色大片| 免费观看在线综合| 久久只有精品| 美女精品网站| 精品一区二区三区视频在线播放| 午夜久久免费观看| 日韩成人午夜精品| 粉嫩av一区二区三区四区五区 | 精品在线99| 国产精品国码视频| 日韩一区二区久久| 日本黄色精品| 亚洲三级观看| 日韩精品首页| 精品视频在线你懂得| 尹人成人综合网| 你懂的亚洲视频| 日韩一区二区三区高清在线观看| 久久裸体视频| 精品黄色一级片| 91免费精品国偷自产在线在线| 在线看片不卡| 亚洲不卡av不卡一区二区| 国产精品伦一区二区| 一区二区三区国产在线| 国产精品av久久久久久麻豆网| 美女在线视频一区| 18国产精品| 日韩va亚洲va欧美va久久| 影音先锋久久精品| 亚洲欧洲一区二区天堂久久| 成人午夜亚洲| 久久超碰99| 欧美激情精品| 激情综合婷婷| 精品一区视频| 亚洲综合电影| 日韩精品诱惑一区?区三区| 国内精品伊人| av在线资源| 久久高清免费| 亚洲国产综合在线看不卡| 久久久一二三| 亚洲欧美日本日韩| 亚洲精品进入| 国产伦精品一区二区三区在线播放 | 婷婷综合五月| 蜜桃视频在线观看一区| 日韩精品久久理论片| 亚洲综合婷婷| 91欧美极品| 中文在线а√在线8| 日韩国产欧美视频| 欧美日韩一区二区三区不卡视频| 日本午夜精品| 神马久久午夜| 国产毛片久久| 日韩精品免费视频人成| 日韩1区2区日韩1区2区| 黄色网一区二区| 久久成人亚洲| 欧美1区二区| 午夜久久免费观看| 欧美亚洲一级| 久久久人人人| 日韩有吗在线观看| 精品国产不卡一区二区| 亚洲激情国产| 国产精品久久亚洲不卡| 日韩a一区二区| 国产伦久视频在线观看| 亚洲电影在线一区二区三区| 91成人精品在线| 日韩成人精品一区| 免费视频国产一区| 麻豆中文一区二区| 久久男人av| 免费成人在线视频观看| 精品国产欧美日韩| 亚洲乱码一区| 日韩精品永久网址| 国产欧美激情| 91成人精品在线| 不卡在线一区| 亚洲国产福利| 日韩一区二区三区免费视频| 99久久久久国产精品| 麻豆精品少妇| 在线视频精品| 亚洲黄色免费av| 国产一区精品福利| 欧美黄色一区| 日韩精品导航| 亚洲欧洲一区| a日韩av网址| 国产精品国产三级国产在线观看| 日韩一区二区三免费高清在线观看 | 国产精品巨作av| 蜜臀国产一区二区三区在线播放| 国产色播av在线| 欧美国产视频| 欧美影院视频| 日韩 欧美一区二区三区| 首页亚洲欧美制服丝腿| 欧美日韩国产传媒| 久久人人99| 久久中文亚洲字幕| 国产高清久久| 亚洲精品888| 亚洲精品电影| 日韩精品一区二区三区免费视频|