【interview】箭頭函式和普通函式的區別
阿新 • • 發佈:2020-07-16
一、 箭頭函式是匿名函式的簡寫,不能作為建構函式,不能使用new
二、箭頭函式不能繫結arguments物件,arguments物件包含了函式執行時的所有引數,arguments只是像陣列,真正意義上並不是陣列,不可以使用陣列的方法
取而代之用rest引數...解決,rest引數搭配的變數是一個數組,可以使用陣列的方法,rest函式後不能再有其他引數(即rest只能是最後一個引數),否則會報錯
function A(a){ console.log(arguments); } A(1,2,3,4,5,8); // [1, 2, 3, 4, 5, 8, callee: ƒ, Symbol(Symbol.iterator): ƒ]let C = (...c) => { console.log(c); } C(3,82,32,11323); // [3, 82, 32, 11323]
三、箭頭函式沒有原型屬性prototype =undefined
var a = ()=>{ return 1; } function b(){ return 2; } console.log(a.prototype); // undefined console.log(b.prototype); // {constructor: ƒ}
四、箭頭函式沒有自己的this,箭頭函式的this永遠指向其上下文的this,沒有辦改變其指向,
普通函式的this指向呼叫它的物件
箭頭函式不繫結this,會捕獲其所在的上下文的this值,作為自己的this值
var obj = { a: 10, b: () => { console.log(this.a); // undefined console.log(this); // Window {postMessage: ƒ, blur: ƒ, focus: ƒ, close: ƒ, frames: Window, …} }, c: function() { console.log(this.a); // 10 console.log(this); // {a: 10, b: ƒ, c: ƒ} } } obj.b(); obj.c();
五、箭頭函式不能當做Generator函式,不能使用yield關鍵字