亚洲乱码中文字幕综合,中国熟女仑乱hd,亚洲精品乱拍国产一区二区三区,一本大道卡一卡二卡三乱码全集资源,又粗又黄又硬又爽的免费视频

JavaScript箭頭函數(shù)與普通函數(shù)的區(qū)別示例詳解

 更新時間:2022年10月27日 10:21:27   作者:格斗家不愛在外太空沉思  
這篇文章主要為大家介紹了JavaScript箭頭函數(shù)與普通函數(shù)的區(qū)別示例詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步,早日升職加薪

箭頭函數(shù)與普通函數(shù)的區(qū)別

要討論箭頭函數(shù)和普通函數(shù)的區(qū)別,首先來看看兩者的基本格式

普通函數(shù)和箭頭共同點就是圓括號和大括號,圓括號里面一般放置參數(shù),大括號一般放置函數(shù)主體,很明顯箭頭函數(shù)不需要寫那么長,舉個例子,有一個數(shù)組,使用map方法為數(shù)組的每個元素增加字符

let arr=['昨天','今天','明天']
let newarr=arr.map(function(item){
  return item+='放假'
})
console.log(newarr);

用普通函數(shù)閱讀起來的話不太友好,使用箭頭函數(shù)看起來并沒有感覺閱讀起來很流暢,實際上只有一個參數(shù)的時候我們不需要為參數(shù)添加上括號,而且只有一個表達式的時候可以步添加大括號,他們的結(jié)果是一樣的

let newarr1=arr.map((item)=>{return item += '放假'})
let newarr2=arr.map(item =>  item += '放假')

箭頭函數(shù)的理解

我們并不能為箭頭函數(shù)命名,箭頭函數(shù)是函數(shù)表達式,而且是匿名的。既然是匿名的我們經(jīng)常用new來構(gòu)造函數(shù)的實例在箭頭函數(shù)上是不行的,箭頭函數(shù)不是構(gòu)造函數(shù),創(chuàng)建的時候并不會為箭頭函數(shù)創(chuàng)建Construct方法

在函數(shù)的內(nèi)部有個特殊對象arguments,一個類似數(shù)組的對象,但是箭頭函數(shù)沒有自己的arguments對象,匿名函數(shù)一般不用參數(shù)或者限定參數(shù)

箭頭函數(shù)里的this指向

this的指向一直讓很多人頭疼,箭頭函數(shù)被設(shè)計出來主要的原因是解決this的問題

為了查看this的指向,分別創(chuàng)建普通函數(shù)和箭頭函數(shù)的表達式,并且為兩個按鈕注冊點擊事件,鼠標點擊按鈕就會執(zhí)行函數(shù)表達式

<button class="pt">普通函數(shù)</button>
<p class="ptP"></p>
<button class="jt">箭頭函數(shù)</button>
<p class="jtP"></p>
<script>
const pt=document.querySelector('.pt')
const ptP=document.querySelector('.ptP')
const jt=document.querySelector('.jt')
const jtP=document.querySelector('.jtP')
let ptFunction=function(){
  ptP.innerHTML='普通函數(shù):'+this
}
let jtFunction=()=>{
  jtP.innerHTML='箭頭函數(shù):'+this
}
pt.addEventListener('click',ptFunction,false)
jt.addEventListener('click',jtFunction,false)
</script>

點擊第一個按鈕的時候,這個this是綁定按鈕的,在普通函數(shù)里this的值是動態(tài)的,定義this的時候這個值不會被馬上確認,而是會在執(zhí)行的時候才確認,所以this值指向按鈕對象

點擊第二個按鈕的時候顯示window,也就是說this的值沒有動態(tài)生成,而是在定義的時候就確認了,第二個按鈕綁定的函數(shù)是屬于window的,this自然指向window,在箭頭函數(shù)可以避免查找代碼時因找this指向的煩惱

為了this的硬綁定我們經(jīng)常會用到call,apply,bind三種方法,下面例子一個對象里面有兩個屬性,一個字符串,一個數(shù)組和一個方法,方法主要對數(shù)組進行map方法的遍歷,為每一個元素添加對象的字符串

const arr=document.querySelector('.arr')//p標簽
let calendar={
  name:'2022-10-',
  lately:['10-25','10-26','10-27'],
  add:function(){
    this.lately.map(function(item){
      arr.innerHTML+=this.name+item+'<br>'
    })
  }
} 
calendar.add()

第一個指向是正確的,因為這個this是直接在add函數(shù)里執(zhí)行的,但是第二個this指向不是我們想要的,于是使用call,apply或者bind方法就可以解決了

add:function(){
    this.lately.map(function(item){
        arr.innerHTML+=this.name+item+'<br>'
    }.bind(this))
}
calendar.add()

但是用箭頭函數(shù)就不用那么麻煩,僅僅把map方法里的function改為箭頭函數(shù)就簡單解決了問題,還有箭頭函數(shù)不能通過call,apply,bind來改變this的值

add:function(){
    this.lately.map(item => arr.innerHTML+=this.name+item+'<br>')
}

總結(jié)

以上就是JavaScript箭頭函數(shù)與普通函數(shù)的區(qū)別示例詳解的詳細內(nèi)容,更多關(guān)于JavaScript箭頭函數(shù)普通函數(shù)的資料請關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

  • JavaScript Dom實現(xiàn)輪播圖原理和實例

    JavaScript Dom實現(xiàn)輪播圖原理和實例

    這篇文章主要為大家詳細介紹了JavaScript Dom實現(xiàn)輪播圖原理和實例,文中示例代碼介紹的非常詳細,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2021-02-02
  • js實現(xiàn)獲取焦點后光標在字符串后

    js實現(xiàn)獲取焦點后光標在字符串后

    這篇文章主要介紹了js實現(xiàn)獲取焦點后光標在字符串后,原理就是獲得焦點后重新把自己復制粘帖一下,喜歡的朋友可以看看
    2014-09-09
  • 基于JavaScript實現(xiàn)無縫滾動效果

    基于JavaScript實現(xiàn)無縫滾動效果

    這篇文章主要為大家詳細介紹了基于JavaScript實現(xiàn)無縫滾動效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下
    2017-07-07
  • Bootstrap每天必學之導航條(二)

    Bootstrap每天必學之導航條(二)

    Bootstrap每天必學之導航條,進一步向大家講解了導航條養(yǎng)殖,以及導航條中元素的使用方法,感興趣的小伙伴們可以參考一下
    2016-03-03
  • JavaScript era庫的使用詳解

    JavaScript era庫的使用詳解

    這篇本文主要給大家介紹了JavaScript era庫的使用,使用 ora 這個 JavaScript 庫可以在命令行應用程序中提供漂亮的加載狀態(tài)提示,本文詳細介紹如何使用該庫,并結(jié)合多個例子演示其功能,需要的朋友可以參考下
    2024-02-02
  • 詳解tween.js 中文使用指南

    詳解tween.js 中文使用指南

    本篇文章主要介紹了詳解tween.js 中文使用指南,小編覺得挺不錯的,現(xiàn)在分享給大家,也給大家做個參考。一起跟隨小編過來看看吧
    2018-01-01
  • ajax請求前端跨域問題原因及解決方案

    ajax請求前端跨域問題原因及解決方案

    這篇文章主要為大家介紹了ajax請求前端跨域問題原因及解決方案,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進步
    2021-10-10
  • 間隔滾動效果-兼容IE和FireFox

    間隔滾動效果-兼容IE和FireFox

    間隔滾動效果-兼容IE和FireFox...
    2006-12-12
  • JS 實現(xiàn)圖片直接下載示例代碼

    JS 實現(xiàn)圖片直接下載示例代碼

    本文為大家詳細介紹下使用JS實現(xiàn)圖片直接下載,具體實現(xiàn)代碼如下,感興趣的朋友可以參考下哈,希望對大家有所幫助
    2013-07-07
  • 重構(gòu)Javascript代碼示例(重構(gòu)前后對比)

    重構(gòu)Javascript代碼示例(重構(gòu)前后對比)

    回顧頭來看看那些Javascript腳本,有寫得不太理想,過于復雜?,F(xiàn)抽取出來,重構(gòu)它們,想學習javascript重構(gòu)的朋友可以參考下啊,網(wǎng)本文可以幫助你的
    2013-01-01

最新評論