成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

四種不應(yīng)該使用箭頭函數(shù)的情況

開(kāi)發(fā) 前端
今天這篇文章,我就跟大家匯總了4種場(chǎng)景下,不建議使用箭頭函數(shù)的情況,希望對(duì)你有用。

箭頭函數(shù)給我們的工作帶來(lái)了極大的方便,但是它們有什么缺點(diǎn)呢?我們應(yīng)該一直使用箭頭函數(shù)嗎?我們應(yīng)該在哪些場(chǎng)景中停止使用箭頭函數(shù)?

現(xiàn)在,我們開(kāi)始吧。

箭頭函數(shù)的一些缺點(diǎn)

1、不支持參數(shù)對(duì)象

在箭頭函數(shù)中,我們不能像在普通函數(shù)中那樣使用 arguments 對(duì)象。

const fn1 = () => {
console.log('arguments', arguments)
}
fn1('fatfish', 'medium')
function fn2(){
console.log('arguments', arguments)
}
fn2('fatfish', 'medium')

可以看到,fn1箭頭函數(shù)報(bào)錯(cuò),但是fn2可以正常讀取arguments對(duì)象。

我們?nèi)绾尾拍茉诩^函數(shù)中獲取所有傳遞給函數(shù)的參數(shù)?

是的,沒(méi)錯(cuò),你可以使用Spread Operator來(lái)解決它。

const fn3 = (...values) => {
console.log('values', values)
}
fn3('fatfish', 'medium')

2、無(wú)法通過(guò)apply、call、bind來(lái)改變this指針

我相信你可以很容易地知道下面的代碼會(huì)輸出什么。

const fn1 = () => {
console.log('this-fn1', this)
}
fn1()
function fn2(){
console.log('this-fn2', this)
}
fn2()

{
name: 'fatfish'
}

我們希望 fn1 和 fn2 都打印對(duì)象,我們應(yīng)該怎么做?

代碼:

const thisObj = {
name: 'fatfish'
}
const fn1 = () => {
console.log('this-fn1', this)
}
fn1.call(thisObj)
function fn2(){
console.log('this-fn2', this)
}
fn2.call(thisObj)

因?yàn)榧^函數(shù)在定義的時(shí)候就決定了它的this指向誰(shuí),所以沒(méi)有辦法用fn1.call(thisObj)再次改變它。

什么時(shí)候不能使用箭頭功能?

箭頭函數(shù)不是萬(wàn)能的,至少有 4 種情況我們不應(yīng)該使用它們。

1、請(qǐng)不要在構(gòu)造函數(shù)中使用箭頭函數(shù)

function Person (name, age) {
this.name = name
this.age = age
}
const Person2 = (name, sex) => {
this.name = name
this.sex = sex
}
console.log('Person', new Person('fatfish', 100))
console.log('Person2', new Person2('fatfish', 100))

為什么 new Person2 會(huì)拋出錯(cuò)誤?

因?yàn)闃?gòu)造函數(shù)通過(guò) new 關(guān)鍵字生成一個(gè)對(duì)象實(shí)例。生成對(duì)象實(shí)例的過(guò)程也是通過(guò)構(gòu)造函數(shù)將this綁定到實(shí)例的過(guò)程。

但是箭頭函數(shù)沒(méi)有自己的this,所以不能作為構(gòu)造函數(shù)使用,也不能通過(guò)new操作符調(diào)用。

2、請(qǐng)不要在點(diǎn)擊事件中操作this

我們經(jīng)常在 click 事件中通過(guò) this 讀取元素本身。

const $body = document.body
$body.addEventListener('click', function () {
// this and $body elements are equivalent
this.innerHTML = 'fatfish'
})

但是如果你使用箭頭函數(shù)給 DOM 元素添加回調(diào),這將等同于全局對(duì)象窗口。

const $body = document.body
$body.addEventListener('click', () => {
this.innerHTML = 'fatfish'
})

3、請(qǐng)不要在對(duì)象的方法中使用箭頭函數(shù)。

const obj = {
name: 'fatfish',
getName () {
return this.name
},
getName2: () => {
return this.name
}
}
console.log('getName', obj.getName())
console.log('getName2', obj.getName2())

你知道這段代碼會(huì)輸出什么嗎?

是的,getName2方法不會(huì)打印“fatfish”,因?yàn)榇藭r(shí)this和window是等價(jià)的,不等于obj。

4、請(qǐng)不要在原型鏈中使用箭頭函數(shù)

const Person = function (name) {
this.name = name
}
Person.prototype.showName = function () {
console.log('showName', this, this.name)
}
Person.prototype.showName2 = () => {
console.log('showName2', this, this.name)
}
const p1 = new Person('fatfish', 100)
p1.showName()
p1.showName2()

寫(xiě)在最后

以上這4種情況中,不建議使用箭頭函數(shù),如果你還了解其他的情況的話,也請(qǐng)你在留言區(qū)給我留言,我們一起學(xué)習(xí)進(jìn)步;如果你覺(jué)得我今天的內(nèi)容對(duì)你有幫助的話,請(qǐng)記得點(diǎn)贊我,關(guān)注我,并將它分享給你身邊的朋友,也許能夠幫助到他。

最后,感謝你的閱讀,祝編程愉快!

責(zé)任編輯:龐桂玉 來(lái)源: web前端開(kāi)發(fā)
相關(guān)推薦

2020-06-05 14:09:42

Kubernetes容器應(yīng)用程序

2009-01-03 15:07:38

ibmdwAIX

2023-03-24 12:52:22

2013-05-29 10:10:05

醫(yī)療搜索互聯(lián)網(wǎng)大數(shù)據(jù)

2020-06-21 21:25:14

物聯(lián)網(wǎng)WiFiIOT

2020-06-17 10:35:16

機(jī)器學(xué)習(xí)AI人工智能

2020-06-09 09:19:14

數(shù)據(jù)庫(kù)

2019-04-04 14:33:19

云計(jì)算云端企業(yè)

2023-08-01 08:18:09

CSSUnset

2016-11-03 19:52:45

2015-10-21 16:11:49

理念實(shí)踐運(yùn)維

2009-07-16 10:53:11

iBATIS 使用

2020-05-06 15:15:33

Python開(kāi)發(fā)工具

2022-03-09 08:14:24

CSS容器container

2020-09-18 07:01:38

分頁(yè)offsetlimit

2022-12-16 09:47:29

2019-09-02 09:30:40

2010-07-05 14:47:26

Gartner社交網(wǎng)絡(luò)

2022-08-24 10:03:18

CSS文本按鈕

2018-09-28 16:17:20

Java 11升級(jí)Oracle
點(diǎn)贊
收藏

51CTO技術(shù)棧公眾號(hào)

主站蜘蛛池模板: 久久久久久国模大尺度人体 | 国产四虎| 亚洲精品大片 | 日韩欧美大片 | 亚洲天堂网站 | 麻豆av一区二区三区久久 | 日本三级电影在线看 | 性高朝久久久久久久3小时 av一区二区三区四区 | 亚洲精品久久久久久久久久久久久 | 99精品久久久久久中文字幕 | 91电影在线 | 少妇精品久久久久久久久久 | 国产在线精品一区二区三区 | 一区二区三区日 | 国产婷婷色综合av蜜臀av | 人人玩人人添人人澡欧美 | 久久午夜精品福利一区二区 | 亚洲一区综合 | 日韩电影免费观看中文字幕 | 男人的天堂久久 | 日本中文字幕在线观看 | 国产亚洲精品精品国产亚洲综合 | 日韩视频一级 | 极情综合网| 九九热久久免费视频 | 欧美va大片 | 久久综合影院 | 最新国产福利在线 | 精品成人一区二区 | 欧美激情视频网站 | 国产激情视频在线观看 | 中日韩毛片| 成人av影院 | 成人久久久久 | 另类二区 | 亚洲综合一区二区三区 | 亚洲日本一区二区三区四区 | 久久久亚洲一区 | 就操在线| www.日韩 | 99精品欧美一区二区蜜桃免费 |