前言
最近學(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