apply,call,bind區別

js中有三個改變this指針的方法,分別是 apply,call,bind。不少人只知道能改變的this,可是具體的適用場景不是太清楚。我也是遇到坑後不斷的實踐發現了區別。es6

call ,apply方法:數組

 1 function Product(name, price) {
 2   this.name = name;
 3   this.price = price;
 4 }
 5 
 6 function Food(name, price) {
 7   Product.call(this, name, price);
  
8 this.category = 'food'; 9 } 10 11 console.log(new Food('cheese', 5).name); 12 // expected output: "cheese"

在Food類中,由於使用了call改變類Product的類的this執向。因此這個時候在Product 中this定義的兩個私有屬性卻成了Food類new出來對象的。這種方式實現了相似繼承的概念,這種方式叫作call繼承。app

其中call第一個參數表示的是修改的類的this指向值,後面兩個name,price都是作爲參數傳遞到Product中。最後在執行這條語句的時候,會執行一下Product這個類(函數)。也就是call就會執行一下 ‘’.‘’ 符號以前的類或者函數。函數

apply相對call來講也是執行了一下函數或者類,只是參數傳遞進行了組裝。若是要進行apply修改,第7句話就能夠表達爲 Prpduct.apply(this,[name,price]); 能夠把要傳遞的參數進行數組化。this

bind:spa

bind是es6中新推出的修改this的方法。可是他和傳統的call,apply區別就是函數或者類的this修改後沒有執行,而是在程序代碼檢測時已經對代碼的this指向進行了修改。那麼有什麼用呢?指針

好比我這個時候須要用DOM2級別的事件綁定 :code

document.addEventListener('click',fn);
fn(){
this.name='yangkun'
}
//這裏咱們給document元素對象添加了一個點擊事件方法fn;
var obj={name:'zhansan'};
fn.call(obj);
咱們須要的是修改fn中的this,指向是obj中的name.是若是這樣作,會有一個問題就是,函數fn已經被執行了!實際上咱們綁定的click事件對應的是一個函數返回值(這裏沒有返回值,實際上點擊事件綁定了null),而不是咱們但願綁定的方法!

這個時候若是咱們使用fn.bind(obj)就沒問題了。方法沒有執行。對象

 

後記:JavaScript早期版本沒有類,可是你們發現經過new能夠實現相似後臺語言的語法方式。天然把進行new 的函數說成類。  js 函數有三態,普通函數,類,對象。這個是ES6以前函數的三態。blog

相關文章
相關標籤/搜索