JavaScript之call apply bind區別詳解

相同

  • 以傳入的第一個參數作為this的指向
  • 都可傳入其他參數

不同

  • apply是通過數組來傳遞
  • call是按參數列表傳遞
func.call(this, arg1, arg2);
func.apply(this, [arg1, arg2])
  • bind()方法會創建一個新函數,稱為綁定函數
var obj = {
    x: 1,
};
var foo = {
    getX: function() {
        return this.x;
    }
}
console.log(foo.getX.bind(obj)());  //1
console.log(foo.getX.call(obj));    //1
console.log(foo.getX.apply(obj));   //1

總結

  • bind() 方法會在調用時執行,而 apply/call則會立即執行函數
  • 當參數固定時用call,不固定時用apply,并且可以用arguments來遍歷所有的參數

參考文章推薦:
深入淺出妙用 Javascript 中 apply、call、bind

最后編輯于
?著作權歸作者所有,轉載或內容合作請聯系作者
平臺聲明:文章內容(如有圖片或視頻亦包括在內)由作者上傳并發布,文章內容僅代表作者本人觀點,簡書系信息發布平臺,僅提供信息存儲服務。

推薦閱讀更多精彩內容