js中call,apply和bind方法的區別和使用場景
原文地址:https://blog.csdn.net/yaojxing/article/details/71942496
一、call,apply和bind方法的來歷
在js中所有的函式都是Function的例項,而且對於Function來說,它的原型即Function.prototype中含有很多東西,其中call,apply和bind方法就是Function原型中的方法,所以根據原型的規則,所有的函式都可以使用原型中屬性和方法,所以來說,對於所有的函式都可以使用call,apply和bind方法。
簡單一句話:call,apply和bind都是Function原型中的方法,而所有的函式都是Function的例項。
二、丟擲一個概念,就是call,apply和bind方法到底有什麼作用?
我認為它們的作用可以用一句話來描述:就是改變this的指向。或者說 強行用其他物件來呼叫一個函式。
除此之外還能在構造方法有中屬性和函式的繼承體現
三.結合程式碼理解改變this的指向的含義
function show(sex){
console.log("姓名為"+this.yourname+",性別為"+sex);
}
var person={
yourname:"張三",
age:14
};
show.call(person,"男");//姓名為張三,性別為男
show("男");//姓名為undefined,性別為男
person.show("男");//報錯
在上面的程式碼塊中,我們可以看到person物件並沒有show方法,直接地用person.show()會報錯。但是我們可以通過call方法來實現person物件來呼叫show方法。所以這種情況我認為就是改變了this的指向。
四.call,apply和bind的區別
它們在功能上是沒有區別的,都是改變this的指向,它們的區別主要是在於方法的實現形式和引數傳遞上的不同
①:函式.call(物件,arg1,arg2....)
②:函式.apply(物件,[arg1,arg2,...])
③:函式.bind(物件,arg1,arg2,....)() 注:bind返回的是一個函式體,並不會直接執行函式
例項程式碼:
function show(sex){
console.log("姓名為"+this.yourname+",性別為"+sex);
}
var person={
yourname:"張三",
age:14
};
show.call(person,"男");//姓名為張三,性別為男
show.apply(person,['女']);//姓名為張三,性別為女
show.bind(person,"未知")();//姓名為張三,性別為未知
通過觀察上面的程式碼,很明顯的就可以得出它們三者的區別,僅僅是函式傳遞的不同以及bind方法可以更加的方便的使用。
相關文章
- apply 、call 以及 bind 的使用和區別APP
- call,apply和bind的區別APP
- js中call、apply、bind的區別JSAPP
- JS中改變this的指向 call、apply 和 bind 的區別JSAPP
- call apply bind的作用及區別? 應用場景?APP
- 理解JS中的call、apply、bind方法(********************************************************JSAPP
- call、apply、bind 區別APP
- call apply bind區別APP
- JS中的call、apply、bindJSAPP
- this, call, apply 和 bindAPP
- 最簡單的例子瞭解js中call()、apply()、bind()的區別和聯絡JSAPP
- 模擬js中的call、apply和bind的實現JSAPP
- 重寫JS中的apply,call,bind,new方法JSAPP
- 使用JS簡單實現一下apply、call和bind方法JSAPP
- JavaScript中apply、call、bind的區別與用法JavaScriptAPP
- js深入之實現call、apply和bindJSAPP
- 「乾貨」細說 call、apply 以及 bind 的區別和用法APP
- 淺談JavaScript中的apply、call和bindJavaScriptAPP
- 談談JavaScript中的call、apply和bindJavaScriptAPP
- JS每日一題: Call,Apply,Bind的使用與區別,如何實現一個bind?JS每日一題APP
- js之call,apply和bind的模擬實現JSAPP
- [譯] Javascript: call()、apply() 和 bind()JavaScriptAPP
- 第 38 題:apply、call 和 bind 是什麼?哪些區別?APP
- JS中的call()方法和apply()方法用法總結JSAPP
- bind、call、apply區別?如何實現?APP
- 從一行等式理解JS當中的call, apply和bindJSAPP
- js call、apply、bind的實現JSAPP
- bind、call、apply的區別與實現原理APP
- JavaScript中call,apply,bind方法的總結。JavaScriptAPP
- 關於call, apply, bind方法的區別與內部實現APP
- JavaScript 中的 apply、call、bindJavaScriptAPP
- 【譯】理解this及call,apply和bind的用法APP
- 說說bind、call、apply的區別?並手寫實現一個bind的方法APP
- JS中bind、call和apply的作用以及在TS裝飾器中的用法JSAPP
- this、apply、call、bindAPP
- 【JavaScript】深入理解call,以及與apply、bind的區別JavaScriptAPP
- 手寫JS函式的call、apply、bindJS函式APP
- 理解JS函式之call,apply,bindJS函式APP