2024-03-19 分類: 網(wǎng)站建設(shè)
前端同學(xué)想要進(jìn)階的話,避免不了要學(xué)習(xí)高階函數(shù),但是高階函數(shù)是什么呢,接下來就由成都網(wǎng)站建設(shè)工程師講解一下javaScript高階函數(shù)入門。
高階函數(shù)可以接收函數(shù)作為參數(shù),同時(shí)也可以返回一個(gè)新的函數(shù)。
高階函數(shù)之所以高階,是因?yàn)楦唠A函數(shù)的參數(shù)和返回值對(duì)象可以是函數(shù),這超越了普通函數(shù)處理的數(shù)據(jù)類型,例如字符串(strings)、數(shù)字(numbers)、布爾值(booleans)等。
JavaScript 中,函數(shù)的應(yīng)用場景很豐富:
作為變量存儲(chǔ)
在數(shù)組中使用
作為對(duì)象屬性(即方法)
作為參數(shù)傳遞
作為其他函數(shù)的返回值
理解高階函數(shù)的關(guān)鍵在于,函數(shù)即數(shù)據(jù)。
數(shù)據(jù)是函數(shù)運(yùn)作的基本
數(shù)據(jù):字符串(Strings)
數(shù)據(jù):數(shù)字(Numbers)
數(shù)據(jù):布爾值(booleans)
數(shù)據(jù):對(duì)象(Objects)
數(shù)據(jù):數(shù)組(Arrays)
在所有的主流語言中,以上這五種數(shù)據(jù)類型被稱為 “頭等對(duì)象”。
為什么是“頭等”呢?因?yàn)檫@五種數(shù)據(jù)類型既可以作為參數(shù)傳遞,又可以存儲(chǔ)在變量或者數(shù)組中,還可以作為變量用于計(jì)算,是數(shù)據(jù)的基本形式。
函數(shù)作為參數(shù)
請(qǐng)觀察 filter 函數(shù)是如何使用 isEven 函數(shù)來判斷要保留哪些內(nèi)容的。這里的 isEven 是一個(gè)函數(shù),作為參數(shù)傳入了 filter 函數(shù)中。
filter 函數(shù)每次在做判斷的時(shí)候都會(huì)調(diào)用 isEven 函數(shù),用 isEven 函數(shù)返回的布爾值來決定當(dāng)前數(shù)值的去留。
總結(jié)
字符串(strings)、數(shù)字(numbers)、布爾值(booleans)、數(shù)組(arrays)、對(duì)象(objects)可以作為變量(variables)、數(shù)組(arrays)、屬性( properties)或者方法(methods)存儲(chǔ)起來。
JavaScript 語言中,函數(shù)也是像數(shù)據(jù)一樣同等對(duì)待的。
因此函數(shù)可以作為另外一個(gè)函數(shù)的參數(shù)或者返回值使用,這樣的做法叫高階函數(shù)。
map、filter、 reduce 等函數(shù)就是高階函數(shù)的最佳代表,它們讓數(shù)組的處理(改變,搜索,相加等)變得簡單不少!
以上關(guān)于javaScript高階函數(shù)入門淺析屬成都網(wǎng)站建設(shè)工程師的個(gè)人觀點(diǎn),大家如果對(duì)此有著不同的見解,可以關(guān)注公眾號(hào)“創(chuàng)新互聯(lián)”給我留言,大家可以交流一下自己的心德體會(huì),共同學(xué)習(xí)進(jìn)步。
分享名稱:JavaScript高階函數(shù)入門淺析
地址分享:http://www.rwnh.cn/news2/320852.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、搜索引擎優(yōu)化、小程序開發(fā)、關(guān)鍵詞優(yōu)化、品牌網(wǎng)站設(shè)計(jì)、商城網(wǎng)站
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場,如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容