實(shí)例講解JavaScript中call、apply、bind方法的異同
以實(shí)例切入,講解JavaScript中call,apply,bind方法,供大家參考,具體內(nèi)容如下
<!DOCTYPE html>
<html>
<head>
<meta charset="UTF-8">
<title></title>
<script type="text/javascript">
function MAN(name, sex, age) {
this.name = name;
this.sex = sex;
this.age = age;
this.say = function(school,zhuanye) {
console.log(this.name + " , " + this.sex + " ,今年" + this.age+"歲!在"+school+"學(xué)習(xí)"+zhuanye);
}
}
function WOMAN(name, sex, age) {
this.name = name;
this.sex = sex;
this.age = age;
}
var man=new MAN("張三","男",26);
var woman=new WOMAN("小紅","女",18);
man.say('清華大學(xué)','挖掘機(jī)');
man.say.call(woman,"藍(lán)翔技校","電氣焊");
man.say.apply(woman,["新東方","火星語(yǔ)"]);
man.say.bind(woman)("德云社","流行音樂(lè)");
</script>
</head>
<body>
</body>
</html>

why?call,apply,bind干什么的?為什么要學(xué)這個(gè)?
一般用來(lái)指定this的環(huán)境,在沒(méi)有學(xué)之前,通常會(huì)有這些問(wèn)題。
var a = {
user:"追夢(mèng)子",
fn:function(){
console.log(this.user);
}
}
var b = a.fn;
b(); //undefined
我們是想打印對(duì)象a里面的user卻打印出來(lái)undefined是怎么回事呢?如果我們直接執(zhí)行a.fn()是可以的。
var a = {
user:"追夢(mèng)子",
fn:function(){
console.log(this.user);
}
}
a.fn(); //追夢(mèng)子
這里能夠打印是因?yàn)椋@里的this指向的是函數(shù)a,那為什么上面的不指向a?我們?nèi)绻枰私鈚his的指向問(wèn)題,請(qǐng)看徹底理解js中this的指向,不必硬背這篇文章。
雖然這種方法可以達(dá)到我們的目的,但是有時(shí)候我們不得不將這個(gè)對(duì)象保存到另外的一個(gè)變量中,那么就可以通過(guò)以下方法。
1、call()
var a = {
user:"追夢(mèng)子",
fn:function(){
console.log(this.user); //追夢(mèng)子
}
}
var b = a.fn;
b.call(a);
通過(guò)在call方法,給第一個(gè)參數(shù)添加要把b添加到哪個(gè)環(huán)境中,簡(jiǎn)單來(lái)說(shuō),this就會(huì)指向那個(gè)對(duì)象。
call方法除了第一個(gè)參數(shù)以外還可以添加多個(gè)參數(shù),如下:
var a = {
user:"追夢(mèng)子",
fn:function(e,ee){
console.log(this.user); //追夢(mèng)子
console.log(e+ee); //3
}
}
var b = a.fn;
b.call(a,1,2);
2、apply()
apply方法和call方法有些相似,它也可以改變this的指向
var a = {
user:"追夢(mèng)子",
fn:function(){
console.log(this.user); //追夢(mèng)子
}
}
var b = a.fn;
b.apply(a);
同樣apply也可以有多個(gè)參數(shù),但是不同的是,第二個(gè)參數(shù)必須是一個(gè)數(shù)組,如下:
var a = {
user:"追夢(mèng)子",
fn:function(e,ee){
console.log(this.user); //追夢(mèng)子
console.log(e+ee); //11
}
}
var b = a.fn;
b.apply(a,[10,1]);
或者
var a = {
user:"追夢(mèng)子",
fn:function(e,ee){
console.log(this.user); //追夢(mèng)子
console.log(e+ee); //520
}
}
var b = a.fn;
var arr = [500,20];
b.apply(a,arr);
//注意如果call和apply的第一個(gè)參數(shù)寫(xiě)的是null,那么this指向的是window對(duì)象
var a = {
user:"追夢(mèng)子",
fn:function(){
console.log(this); //Window {external: Object, chrome: Object, document: document, a: Object, speechSynthesis: SpeechSynthesis…}
}
}
var b = a.fn;
b.apply(null);
3、bind()
bind方法和call、apply方法有些不同,但是不管怎么說(shuō)它們都可以用來(lái)改變this的指向。
先來(lái)說(shuō)說(shuō)它們的不同吧。
var a = {
user:"追夢(mèng)子",
fn:function(){
console.log(this.user);
}
}
var b = a.fn;
b.bind(a);
我們發(fā)現(xiàn)代碼沒(méi)有被打印,對(duì),這就是bind和call、apply方法的不同,實(shí)際上bind方法返回的是一個(gè)修改過(guò)后的函數(shù)。
var a = {
user:"追夢(mèng)子",
fn:function(){
console.log(this.user);
}
}
var b = a.fn;
var c = b.bind(a);
console.log(c); //function() { [native code] }
那么我們現(xiàn)在執(zhí)行一下函數(shù)c看看,能不能打印出對(duì)象a里面的user
var a = {
user:"追夢(mèng)子",
fn:function(){
console.log(this.user); //追夢(mèng)子
}
}
var b = a.fn;
var c = b.bind(a);
c();
ok,同樣bind也可以有多個(gè)參數(shù),并且參數(shù)可以執(zhí)行的時(shí)候再次添加,但是要注意的是,參數(shù)是按照形參的順序進(jìn)行的。
var a = {
user:"追夢(mèng)子",
fn:function(e,d,f){
console.log(this.user); //追夢(mèng)子
console.log(e,d,f); //10 1 2
}
}
var b = a.fn;
var c = b.bind(a,10);
c(1,2);
總結(jié):call和apply都是改變上下文中的this并立即執(zhí)行這個(gè)函數(shù),bind方法可以讓對(duì)應(yīng)的函數(shù)想什么時(shí)候調(diào)就什么時(shí)候調(diào)用,并且可以將參數(shù)在執(zhí)行的時(shí)候添加,這是它們的區(qū)別,根據(jù)自己的實(shí)際情況來(lái)選擇使用。
以上就是本文的全部?jī)?nèi)容,希望對(duì)大家的學(xué)習(xí)有所幫助,也希望大家多多支持腳本之家。
- 再談JavaScript中bind、call、apply三個(gè)方法的區(qū)別與使用方式
- 使用JS簡(jiǎn)單實(shí)現(xiàn)apply、call和bind方法的實(shí)例代碼
- JS 函數(shù)的 call、apply 及 bind 超詳細(xì)方法
- JavaScript函數(shù)之call、apply以及bind方法案例詳解
- Javascript中call,apply,bind方法的詳解與總結(jié)
- 深入理解JavaScript中的call、apply、bind方法的區(qū)別
- JS中改變this指向的方法(call和apply、bind)
- javascript中call apply 與 bind方法詳解
- js apply/call/caller/callee/bind使用方法與區(qū)別分析
- JavaScript手寫(xiě)call,apply,bind方法
相關(guān)文章
js select下拉聯(lián)動(dòng) 更具級(jí)聯(lián)性!
這篇文章主要為大家詳細(xì)介紹了js select下拉聯(lián)動(dòng)的相關(guān)資料,更具級(jí)聯(lián)性!文中示例代碼介紹的非常詳細(xì),具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2017-01-01
vue+ts下對(duì)axios的封裝實(shí)現(xiàn)
這篇文章主要介紹了vue+ts下對(duì)axios的封裝實(shí)現(xiàn),文中通過(guò)示例代碼介紹的非常詳細(xì),對(duì)大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價(jià)值,需要的朋友們下面隨著小編來(lái)一起學(xué)習(xí)學(xué)習(xí)吧2020-02-02
基于javascript實(shí)現(xiàn)判斷移動(dòng)終端瀏覽器版本信息
這篇文章主要介紹了基于javascript實(shí)現(xiàn)判斷移動(dòng)終端瀏覽器版本信息,需要的朋友可以參考下2014-12-12
javascript 瀏覽器類型和版本號(hào)檢測(cè)代碼(兼容多瀏覽器)
基于JavaScript實(shí)現(xiàn)抽獎(jiǎng)系統(tǒng)
通過(guò)JS來(lái)判斷頁(yè)面控件是否獲取焦點(diǎn)
webpack幾種手動(dòng)實(shí)現(xiàn)HMR的方式

