es6箭頭函數(shù)

前言

最近學(xué)習(xí)了慕課網(wǎng)上的vue仿餓了嗎的視頻,體會到了es6的箭頭函數(shù)的妙用莱褒,因此特別總結(jié)了一下箭頭函數(shù)的用法。

首先看一下es6的箭頭函數(shù)語法

<pre>
([param] [, param]) => {
statements
}
param => expression
</pre>

aram 是參數(shù)勾笆,根據(jù)參數(shù)個數(shù)不同梧宫,分這幾種情況:
1, () => { … } // 零個參數(shù)用或多個參數(shù) () 表示且()不能省略;
2, x => { … } // 一個參數(shù)可以省略 ()蛇尚;

看第一種情況

<pre>
var f = () => 5;
// 等同于
var f = function () { return 5 };
var sum = (num1, num2) => num1 + num2;
// 等同于
var sum = function(num1, num2) {
return num1 + num2;
};
</pre>

第二種情況

<pre>
var f = v => v;
上面箭頭函數(shù)等價于
var f = function(v) {
return v;
};
</pre>

當(dāng)然=>后面也不一定非得接return 之后的語句芽唇,看下面:

<pre>
// ES5
$("#confetti-btn").click(function (event) {
playTrumpet();
fireConfettiCannon();
});
// ES6
$("#confetti-btn").click(event => {
playTrumpet();
fireConfettiCannon();
});</pre>

但是需要注意的是,多行語句需要用{}括起來佣蓉,單行表達(dá)式不需要{}披摄,并且會作為函數(shù)返回值。

和普通函數(shù)一樣勇凭,箭頭函數(shù)也可以使用剩余參數(shù)默認(rèn)參數(shù)疚膊。

<pre>
var func1 = (x = 1, y = 2) => x + y;
func1(); // 得到 3

var func2 = (x, ...args) => { console.log(args) };
func2(1,2,3); // 輸出 [2, 3] </pre>


使用注意點
  • 函數(shù)體內(nèi)的this對象,就是定義時所在的對象虾标,而不是使用時所在的對象。

  • 不可以當(dāng)作構(gòu)造函數(shù)傀蚌,也就是說善炫,不可以使用new命令,否則會拋出一個錯誤库继。

  • 不可以使用arguments對象艺谆,該對象在函數(shù)體內(nèi)不存在静汤。如果要用,可以用Rest參數(shù)代替狰右。

  • 不可以使用yield命令棋蚌,因此箭頭函數(shù)不能用作Generator函數(shù)蒿往。

this指向的固定化瓤漏,并不是因為箭頭函數(shù)內(nèi)部有綁定this的機(jī)制,實際原因是箭頭函數(shù)根本沒有自己的this饥漫,導(dǎo)致內(nèi)部的this就是外層代碼塊的this庸队。正是因為它沒有this,所以也就不能用作構(gòu)造函數(shù)宾尚。
箭頭函數(shù)內(nèi)部沒有constructor方法,也沒有prototype,所以不支持new操作缎谷。但是它對this的處理與一般的普通函數(shù)不一樣。箭頭函數(shù)的 this 始終指向函數(shù)定義時的 this希痴,而非執(zhí)行時虏缸。我們通過一個例子來理解:

var o = {
x : 1,
func : function() { console.log(this.x) },
test : function() {
setTimeout(function() {
this.func();
}, 100);
}
};
o.test(); // TypeError : this.func is not a function

上面的代碼會出現(xiàn)錯誤,因為this的指向從o變?yōu)榱巳?/strong>(函數(shù)調(diào)用中的this都是指向全局的)。如果大家對JavaScript中的this不是很熟悉的話慨灭,可以看看我寫過的一篇文章,深入理解javascript之this。好了惶翻,回歸正題旭愧,我們需要修改上面的代碼如下:

var o = {
x : 1,
func : function() { console.log(this.x) },
test : function() {

    var _this = this;
    setTimeout(function() {
        _this.func(); 
    }, 100);
}

};
o.test();

通過使用外部事先保存的this就行了。這里就可以利用到箭頭函數(shù)了先口,我們剛才說過,箭頭函數(shù)的 this 始終指向函數(shù)定義時的 this螟深,而非執(zhí)行時谐宙。所以我們將上面的代碼修改如下:

var o = {
x : 1,
func : function() { console.log(this.x) },
test : function() {
setTimeout(() => { this.func() }, 100);
}
};
o.test();

我們還需要注意一點的就是這個this是不會改變指向?qū)ο蟮?/strong>,我們知道call和apply可以改變this的指向搭综,但是在箭頭函數(shù)中是無效的。

var x = 1,
o = {
x : 10,
test : () => this.x
};

o.test(); // 1
o.test.call(o); // 依然是1

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末闪朱,一起剝皮案震驚了整個濱河市称诗,隨后出現(xiàn)的幾起案子计维,更是在濱河造成了極大的恐慌,老刑警劉巖鲫惶,帶你破解...
    沈念sama閱讀 218,525評論 6 507
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蜈首,死亡現(xiàn)場離奇詭異,居然都是意外死亡赏淌,警方通過查閱死者的電腦和手機(jī)踩寇,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,203評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來六水,“玉大人俺孙,你說我怎么就攤上這事∷趵蓿” “怎么了鼠冕?”我有些...
    開封第一講書人閱讀 164,862評論 0 354
  • 文/不壞的土叔 我叫張陵添寺,是天一觀的道長胯盯。 經(jīng)常有香客問我,道長计露,這世上最難降的妖魔是什么博脑? 我笑而不...
    開封第一講書人閱讀 58,728評論 1 294
  • 正文 為了忘掉前任憎乙,我火速辦了婚禮,結(jié)果婚禮上叉趣,老公的妹妹穿的比我還像新娘泞边。我一直安慰自己,他們只是感情好疗杉,可當(dāng)我...
    茶點故事閱讀 67,743評論 6 392
  • 文/花漫 我一把揭開白布阵谚。 她就那樣靜靜地躺著,像睡著了一般烟具。 火紅的嫁衣襯著肌膚如雪梢什。 梳的紋絲不亂的頭發(fā)上,一...
    開封第一講書人閱讀 51,590評論 1 305
  • 那天朝聋,我揣著相機(jī)與錄音嗡午,去河邊找鬼。 笑死冀痕,一個胖子當(dāng)著我的面吹牛荔睹,可吹牛的內(nèi)容都是我干的。 我是一名探鬼主播言蛇,決...
    沈念sama閱讀 40,330評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼僻他,長吁一口氣:“原來是場噩夢啊……” “哼!你這毒婦竟也來了猜极?” 一聲冷哼從身側(cè)響起中姜,我...
    開封第一講書人閱讀 39,244評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎跟伏,沒想到半個月后丢胚,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,693評論 1 314
  • 正文 獨居荒郊野嶺守林人離奇死亡受扳,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,885評論 3 336
  • 正文 我和宋清朗相戀三年携龟,在試婚紗的時候發(fā)現(xiàn)自己被綠了。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片勘高。...
    茶點故事閱讀 40,001評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡峡蟋,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出华望,到底是詐尸還是另有隱情蕊蝗,我是刑警寧澤,帶...
    沈念sama閱讀 35,723評論 5 346
  • 正文 年R本政府宣布赖舟,位于F島的核電站蓬戚,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏宾抓。R本人自食惡果不足惜子漩,卻給世界環(huán)境...
    茶點故事閱讀 41,343評論 3 330
  • 文/蒙蒙 一豫喧、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧幢泼,春花似錦紧显、人聲如沸。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,919評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽。三九已至招驴,卻和暖如春重父,著一層夾襖步出監(jiān)牢的瞬間,已是汗流浹背忽匈。 一陣腳步聲響...
    開封第一講書人閱讀 33,042評論 1 270
  • 我被黑心中介騙來泰國打工房午, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留,地道東北人丹允。 一個月前我還...
    沈念sama閱讀 48,191評論 3 370
  • 正文 我出身青樓郭厌,卻偏偏與公主長得像,于是被迫代替她去往敵國和親雕蔽。 傳聞我的和親對象是個殘疾皇子折柠,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,955評論 2 355

推薦閱讀更多精彩內(nèi)容