js中call、apply和bind的區別

來源:互聯網
上載者:User

標籤:面試   script   作用   題目   str   區別   上下文   遇到   getname   

前言

關於js中call、apply和bind這三者的區別,這應該是一個老生常談的問題,也是前端面試時經常會遇到的一道題目,因此也抽空把它理一遍。

作用

call、apply和bind都是一個javascript中的方法,他們的共同作用就是改變函數執行時的上下文,即改變函數執行時this的指向。我們來看下面的例子:

 1 function Animal(name) { 2     this.name = name; 3 } 4 Animal.prototype.getName = function() { 5     console.log(this.name); 6 } 7 var dog = new Animal(‘dog‘); 8 var cat = { 9     name: ‘cat‘10 };11 dog.getName();    // dog12 dog.getName.call(cat);    // cat13 dog.getName.apply(cat);    // cat14 dog.getName.bind(cat)();    // cat

上面的例子中,一開始 getName 方法中this的指向是dog對象,所以第一次執行時輸出的是‘dog‘,但在使用call、apply和bind分別改變getName執行時的上下文,this的指向就變成了cat對象,因此此時輸出的name是cat對象的name即 ‘cat‘。

區別

儘管call、apply和bind三個方法的作用都是改變函數執行時this的指向,但它們在使用上還是有一定的區別。

(1)call、apply與bind的區別

  call和apply都是改變函數的上下文this的指向後立即執行該函數,而bind則是返回改變上下文this後的一個函數。

(2)call和apply兩者的區別

  call和apply的第一個參數都是要改變的內容物件,call從第二個參數開始以及後面的參數都是以參數列表的形式展現,而apply則是把除了要改變的內容物件外的其他參數放在一個數組作為它的第二個參數。

1 fn.call(obj, arg1, arg2, arg3...);
2 fn.apply(obj, [arg1, arg2, arg3...]);

 

js中call、apply和bind的區別

相關文章

聯繫我們

該頁面正文內容均來源於網絡整理,並不代表阿里雲官方的觀點,該頁面所提到的產品和服務也與阿里云無關,如果該頁面內容對您造成了困擾,歡迎寫郵件給我們,收到郵件我們將在5個工作日內處理。

如果您發現本社區中有涉嫌抄襲的內容,歡迎發送郵件至: info-contact@alibabacloud.com 進行舉報並提供相關證據,工作人員會在 5 個工作天內聯絡您,一經查實,本站將立刻刪除涉嫌侵權內容。

A Free Trial That Lets You Build Big!

Start building with 50+ products and up to 12 months usage for Elastic Compute Service

  • Sales Support

    1 on 1 presale consultation

  • After-Sales Support

    24/7 Technical Support 6 Free Tickets per Quarter Faster Response

  • Alibaba Cloud offers highly flexible support services tailored to meet your exact needs.