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

JavaScript中的函數(shù)申明、函數(shù)表達(dá)式、箭頭函數(shù)

 更新時(shí)間:2019年12月06日 15:02:27   作者:吾日三省吾身,兩頓飯  
js中的函數(shù)可以通過(guò)幾種方式創(chuàng)建,具體創(chuàng)建方法通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),文中通過(guò)例子給大家介紹了函數(shù)聲明和表達(dá)式之間的差別,感興趣的朋友跟隨小編一起看看吧

JavaScript中的函數(shù)可以通過(guò)幾種方式創(chuàng)建,如下。

// 函數(shù)聲明
function getName() {
  return 'Michael'
}
// 函數(shù)表達(dá)式
const getName = function() {
  return 'Michael'
}
// 箭頭函數(shù)(同樣也是表達(dá)式)
const getName = () => {
  return 'Michael'
}

函數(shù)聲明和表達(dá)式之間的差別是

JavaScript 解釋器中存在一種變量聲明被提升的機(jī)制,也就是說(shuō)函數(shù)聲明會(huì)被提升到作用域的最前面,即使寫代碼的時(shí)候是寫在最后面,也還是會(huì)被提升至最前面。而用函數(shù)表達(dá)式創(chuàng)建的函數(shù)是在運(yùn)行時(shí)進(jìn)行賦值,且要等到表達(dá)式賦值完成后才能調(diào)用

看一個(gè)例子

getName()//oaoafly
var getName = function() {
  console.log('wscat')
}
getName()//wscat
function getName() {
  console.log('oaoafly')
}
getName()//wscat

上面的問(wèn)題可以分解成兩個(gè)簡(jiǎn)單的問(wèn)題,有助于你更清楚的看出函數(shù)聲明和表達(dá)式之間的區(qū)別

var getName;
console.log(getName)//undefined
getName()//Uncaught TypeError: getName is not a function
var getName = function() {
  console.log('wscat')
}

var getName;
console.log(getName)//function getName() {console.log('oaoafly')}
getName()//oaoafly
function getName() {
  console.log('oaoafly')
}

這個(gè)區(qū)別看似微不足道,但在某些情況下確實(shí)是一個(gè)難以察覺(jué)并且“致命“的陷阱。出現(xiàn)這個(gè)陷阱的本質(zhì)原因體現(xiàn)在這兩種類型在函數(shù)提升和運(yùn)行時(shí)機(jī)(解析時(shí)/運(yùn)行時(shí))上的差異。

箭頭函數(shù)

箭頭函數(shù)是語(yǔ)法和函數(shù)表達(dá)式比起來(lái)稍有不同的函數(shù)表達(dá)式。在上面的示例中,你可以看到箭頭函數(shù)看起來(lái)像函數(shù)表達(dá)式,但沒(méi)有單詞function,然后在括號(hào)和大括號(hào)之間帶有粗箭頭=>。

你可能聽(tīng)說(shuō)過(guò),在JavaScript中,函數(shù)會(huì)創(chuàng)建自己的作用域。這意味著JavaScript函數(shù)會(huì)創(chuàng)建自己的上下文this,如果我們需要一個(gè)函數(shù)但是這個(gè)函數(shù)卻沒(méi)有自己的上下this,那么就可能會(huì)遇到問(wèn)題。箭頭函數(shù)的特征之一是它們不創(chuàng)建上下文,因此箭頭函數(shù)的內(nèi)部this與外部的this相同。

箭頭函數(shù)也可以很小巧。查看下面兩個(gè)完全相同的示例:

const getName = () => {
  return 'Michael'
}
// 和上面的相同,但是更小巧
const getName = () => 'Michael'

當(dāng)箭頭函數(shù)忽略其大括號(hào)時(shí),表示我們希望粗箭頭右側(cè)的內(nèi)容為返回值(不用加return)。這稱為隱式返回值。關(guān)于箭頭函數(shù),還有一些更細(xì)微的細(xì)節(jié)需要了解,例如如何返回對(duì)象以及如何省略單個(gè)參數(shù)的括號(hào)。

// 箭頭函數(shù)直接返回對(duì)象
const getStudent = () => ({ name: 'Michael', age: 18, });
 
// 省略單個(gè)參數(shù)的括號(hào)
const addOne = (n) => n+1;
const addOne = n => n+1;

總結(jié)

以上所述是小編給大家介紹的JavaScript中的函數(shù)申明、函數(shù)表達(dá)式、箭頭函數(shù),希望對(duì)大家有所幫助,如果大家有任何疑問(wèn)請(qǐng)給我留言,小編會(huì)及時(shí)回復(fù)大家的。在此也非常感謝大家對(duì)腳本之家網(wǎng)站的支持!如果你覺(jué)得本文對(duì)你有幫助,歡迎轉(zhuǎn)載,煩請(qǐng)注明出處,謝謝!

相關(guān)文章

  • WebGL 顏色與紋理使用介紹

    WebGL 顏色與紋理使用介紹

    這篇文章主要為大家介紹了WebGL 顏色與紋理使用介紹,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪
    2023-04-04
  • 關(guān)于JS中setTimeout()無(wú)法調(diào)用帶參函數(shù)問(wèn)題的解決方法

    關(guān)于JS中setTimeout()無(wú)法調(diào)用帶參函數(shù)問(wèn)題的解決方法

    這篇文章主要介紹了關(guān)于JS中setTimeout()無(wú)法調(diào)用帶參函數(shù)問(wèn)題的解決方法,提供了2種解決方法供大家對(duì)比參考,需要的朋友可以參考下
    2016-06-06
  • JavaScript中的class類詳解

    JavaScript中的class類詳解

    JavaScript?中的類(Class)是一種新的語(yǔ)言特性,它讓我們可以使用面向?qū)ο缶幊痰乃枷雭?lái)更加方便地組織和管理代碼。在本文中,我們將詳細(xì)介紹?JavaScript?中的類特性,感興趣的同學(xué)可以借鑒閱讀
    2023-05-05
  • 工作中常用到的ES6語(yǔ)法

    工作中常用到的ES6語(yǔ)法

    ECMAScript 6是JavaScript語(yǔ)言的下一代標(biāo)準(zhǔn),已經(jīng)在2015年6月正式發(fā)布了。這篇文章主要介紹了工作中常用到的ES6語(yǔ)法,需要的朋友可以參考下
    2018-09-09
  • three.js引入glsl文件并高亮顯示代碼的完整步驟

    three.js引入glsl文件并高亮顯示代碼的完整步驟

    這篇文章主要給大家介紹了關(guān)于three.js引入glsl文件并高亮顯示代碼的相關(guān)資料,文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友可以參考下
    2022-03-03
  • javascript中in運(yùn)算符用法分析

    javascript中in運(yùn)算符用法分析

    這篇文章主要介紹了javascript中in運(yùn)算符用法,實(shí)例分析了in運(yùn)算符的相關(guān)使用技巧,非常具有實(shí)用價(jià)值,需要的朋友可以參考下
    2015-04-04
  • JS網(wǎng)頁(yè)播放聲音實(shí)現(xiàn)代碼兼容各種瀏覽器

    JS網(wǎng)頁(yè)播放聲音實(shí)現(xiàn)代碼兼容各種瀏覽器

    JS網(wǎng)頁(yè)播放聲音有多種方法可以實(shí)現(xiàn),不過(guò)兼容各種瀏覽器的就沒(méi)有幾個(gè)了,不過(guò)本文的這個(gè)示例或許對(duì)大家有所幫助
    2013-09-09
  • JavaScript類型系統(tǒng)之布爾Boolean類型詳解

    JavaScript類型系統(tǒng)之布爾Boolean類型詳解

    這篇文章主要介紹了JavaScript類型系統(tǒng)之布爾Boolean類型詳解的相關(guān)資料,非常不錯(cuò),具有參考借鑒價(jià)值,需要的朋友可以參考下
    2016-06-06
  • 微信小程序 select 下拉框組件功能

    微信小程序 select 下拉框組件功能

    這篇文章主要介紹了微信小程序 select 下拉框組件功能,本文通過(guò)實(shí)例代碼給大家介紹的非常詳細(xì),具有一定的參考借鑒價(jià)值,需要的朋友可以參考下
    2019-09-09
  • JavaScript表單驗(yàn)證的兩種實(shí)現(xiàn)方法

    JavaScript表單驗(yàn)證的兩種實(shí)現(xiàn)方法

    這篇文章主要為大家詳細(xì)介紹了JavaScript表單驗(yàn)證的兩種實(shí)現(xiàn)方法,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下
    2017-02-02

最新評(píng)論