真实的国产乱ⅩXXX66竹夫人,五月香六月婷婷激情综合,亚洲日本VA一区二区三区,亚洲精品一区二区三区麻豆

成都創(chuàng)新互聯(lián)網(wǎng)站制作重慶分公司

JS高階函數(shù)原理與用法實(shí)例分析

本文實(shí)例講述了JS高階函數(shù)原理與用法。分享給大家供大家參考,具體如下:

創(chuàng)新互聯(lián)服務(wù)項(xiàng)目包括陜州網(wǎng)站建設(shè)、陜州網(wǎng)站制作、陜州網(wǎng)頁(yè)制作以及陜州網(wǎng)絡(luò)營(yíng)銷策劃等。多年來(lái),我們專注于互聯(lián)網(wǎng)行業(yè),利用自身積累的技術(shù)優(yōu)勢(shì)、行業(yè)經(jīng)驗(yàn)、深度合作伙伴關(guān)系等,向廣大中小型企業(yè)、政府機(jī)構(gòu)等提供互聯(lián)網(wǎng)行業(yè)的解決方案,陜州網(wǎng)站推廣取得了明顯的社會(huì)效益與經(jīng)濟(jì)效益。目前,我們服務(wù)的客戶以成都為中心已經(jīng)輻射到陜州省份的部分城市,未來(lái)相信會(huì)繼續(xù)擴(kuò)大服務(wù)區(qū)域并繼續(xù)獲得客戶的支持與信任!

如果您正在學(xué)習(xí)JavaScript,那么您必須遇到高階函數(shù)這個(gè)術(shù)語(yǔ)。這聽起來(lái)復(fù)雜,其實(shí)不然。

使JavaScript適合函數(shù)式編程的原因是它接受高階函數(shù)。

高階函數(shù)在JavaScript中廣泛使用。如果你已經(jīng)用JavaScript編程了一段時(shí)間,你可能已經(jīng)使用它們甚至不知道。

要完全理解這個(gè)概念,首先必須了解函數(shù)式編程是什么一等函數(shù)(first-Class Function)以及的概念。

函數(shù)式編程

在大多數(shù)簡(jiǎn)單的術(shù)語(yǔ)中,函數(shù)編程是一種編程形式,您可以將函數(shù)作為參數(shù)傳遞給其他函數(shù),并將它們作為值返回。在函數(shù)式編程中,我們根據(jù)函數(shù)思考和編碼。

JavaScript,Haskell,Clojure,Scala和Erlang是實(shí)現(xiàn)函數(shù)式編程的一些語(yǔ)言。

一等函數(shù)

如果您一直在學(xué)習(xí)JavaScript,您可能聽說(shuō)過JavaScript將函數(shù)視為一等公民。那是因?yàn)樵贘avaScript或任何其他函數(shù)式編程語(yǔ)言中,函數(shù)是對(duì)象。

在JavaScript中,函數(shù)是一種特殊類型的對(duì)象。他們是Function對(duì)象。

在JavaScript中,您可以使用其他類型(如對(duì)象,字符串或數(shù)字)執(zhí)行的所有操作函數(shù)都可以執(zhí)行。您可以將它們作為參數(shù)傳遞給其他函數(shù)(回調(diào)函數(shù)),將它們分配給變量并傳遞它們等等。這就是JavaScript中的函數(shù)被稱為First-Class函數(shù)(一等函數(shù))的原因。

高階函數(shù)

高階函數(shù)是對(duì)其他函數(shù)進(jìn)行操作的函數(shù),可以將它們作為參數(shù)或通過返回它們。簡(jiǎn)單來(lái)說(shuō),高階函數(shù)是一個(gè)函數(shù),它接收函數(shù)作為參數(shù)或?qū)⒑瘮?shù)作為輸出返回。

例如Array.prototype.map,Array.prototype.filter并且Array.prototype.reduce是一些高階功能,內(nèi)置的語(yǔ)言。

運(yùn)行高階函數(shù)

讓我們看一下內(nèi)置高階函數(shù)的一些例子,看看它與我們不使用高階函數(shù)的解決方案的比較。

Array.prototype.map

map()方法通過調(diào)用作為輸入數(shù)組中每個(gè)元素的參數(shù)提供的回調(diào)函數(shù)來(lái)創(chuàng)建一個(gè)新數(shù)組。該map()方法將從回調(diào)函數(shù)中獲取每個(gè)返回值,并使用這些值創(chuàng)建一個(gè)新數(shù)組。

傳遞給回調(diào)函數(shù)map()方法接受3個(gè)參數(shù):element,index,和array。

假設(shè)我們有一個(gè)數(shù)組,我們想要?jiǎng)?chuàng)建一個(gè)新數(shù)組,其中包含第一個(gè)數(shù)組的每個(gè)值的兩倍。讓我們看看如何使用和不使用高階函數(shù)來(lái)解決問題。

不用高階函數(shù)

const arr1 = [1,2,3]; 
const arr2 = [];
for(let i = 0; i 

使用高階函數(shù)

const arr1 = [1,2,3];
const arr2 = arr1.map (function (item) { 
 return item * 2; 
}
console.log(arr2)

我們可以使用箭頭函數(shù)語(yǔ)法使其更短

const arr1 = [1, 2, 3];
const arr2 = arr1.map(item => item * 2);
console.log(arr2);

創(chuàng)建我們自己的高階函數(shù)

到目前為止,我們看到了語(yǔ)言中內(nèi)置的各種高階函數(shù)?,F(xiàn)在讓我們創(chuàng)建自己的高階函數(shù)。

我們假設(shè)JavaScript沒有原生map方法。我們可以自己構(gòu)建它,從而創(chuàng)建我們自己的高階函數(shù)。

假設(shè)我們有一個(gè)字符串?dāng)?shù)組,我們希望將此數(shù)組轉(zhuǎn)換為整數(shù)數(shù)組,其中每個(gè)元素表示原始數(shù)組中字符串的長(zhǎng)度。

const strArray = ['JavaScript', 'Python', 'PHP', 'Java', 'C'];
function mapForEach(arr, fn) {
 const newArray = [];
 for(let i = 0; i < arr.length; i++) {
 newArray.push(
  fn(arr[i])
 );
 }
 return newArray;
}
const lenArray = mapForEach(strArray, function(item) {
 return item.length;
});
// prints [ 10, 6, 3, 4, 1 ]
console.log(lenArray);

在上面的例子中,我們創(chuàng)建了一個(gè)高階函數(shù)mapForEach,它接受一個(gè)數(shù)組和一個(gè)回調(diào)函數(shù)fn。此函數(shù)循環(huán)遍歷提供的數(shù)組,并在每次迭代時(shí)調(diào)用函數(shù)調(diào)用fn內(nèi)的回調(diào)函數(shù)newArray.push

回調(diào)函數(shù)fn接收數(shù)組的當(dāng)前元素并返回該元素的長(zhǎng)度,該元素存儲(chǔ)在newArray。for循環(huán)完成后,newArray返回并分配給lenArray。

結(jié)論

我們已經(jīng)了解了高階函數(shù)和一個(gè)內(nèi)置的高階函數(shù)。我們還學(xué)習(xí)了如何創(chuàng)建自己的高階函數(shù)。

簡(jiǎn)而言之,高階函數(shù)是一個(gè)函數(shù),它可以接收函數(shù)作為參數(shù),甚至可以返回一個(gè)函數(shù)。高階函數(shù)就像常規(guī)函數(shù)一樣,具有接收和返回其他函數(shù)的附加能力,即參數(shù)和輸出。

更多關(guān)于JavaScript相關(guān)內(nèi)容可查看本站專題:《JavaScript常用函數(shù)技巧匯總》、《javascript面向?qū)ο笕腴T教程》、《JavaScript錯(cuò)誤與調(diào)試技巧總結(jié)》、《JavaScript數(shù)據(jù)結(jié)構(gòu)與算法技巧總結(jié)》及《JavaScript數(shù)學(xué)運(yùn)算用法總結(jié)》

希望本文所述對(duì)大家JavaScript程序設(shè)計(jì)有所幫助。


網(wǎng)頁(yè)名稱:JS高階函數(shù)原理與用法實(shí)例分析
轉(zhuǎn)載注明:http://weahome.cn/article/jeepjc.html

其他資訊

在線咨詢

微信咨詢

電話咨詢

028-86922220(工作日)

18980820575(7×24)

提交需求

返回頂部