1. 程式人生 > 實用技巧 >【interview】箭頭函式和普通函式的區別

【interview】箭頭函式和普通函式的區別

一、 箭頭函式是匿名函式的簡寫,不能作為建構函式,不能使用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關鍵字