您好,登錄后才能下訂單哦!
這篇文章主要講解了“javaScript中的call()方法與apply方法的使用”,文中的講解內(nèi)容簡單清晰,易于學(xué)習(xí)與理解,下面請(qǐng)大家跟著小編的思路慢慢深入,一起來研究和學(xué)習(xí)“javaScript中的call()方法與apply方法的使用”吧!
javaScript 中的 call() 是一個(gè)奇妙的方法,但也是一個(gè)讓人迷惑的方法,先看一下官方的解釋:
call 方法
請(qǐng)參閱
應(yīng)用于:Function 對(duì)象
要求
版本 5.5
調(diào)用一個(gè)對(duì)象的一個(gè)方法,以另一個(gè)對(duì)象替換當(dāng)前對(duì)象。
call([thisObj[,arg1[, arg2[, [,.argN]]]]])
參數(shù)
thisObj
可選項(xiàng)。將被用作當(dāng)前對(duì)象的對(duì)象。
arg1, arg2, , argN
可選項(xiàng)。將被傳遞方法參數(shù)序列。
說明
call 方法可以用來代替另一個(gè)對(duì)象調(diào)用一個(gè)方法。call 方法可將一個(gè)函數(shù)的對(duì)象上下文從初始的上下文改變?yōu)橛?thisObj 指定的新對(duì)象。
如果沒有提供 thisObj 參數(shù),那么 Global 對(duì)象被用作 thisObj。
-------------------------------------------------------------------------------------------
乍一看,很容易把人看迷胡,先做一些簡單的說明
obj1.method1.call(obj2,argument1,argument2)
如上,call的作用就是把obj1的方法放到obj2上使用
,后面的argument1..這些做為參數(shù)傳入.
舉一個(gè)具體的例子
f
unction add(a,b)
{
alert(a+b);
}
function sub(a,b)
{
alert(a-b);
}
add.call(sub,3,1);
這個(gè)例子中的意思就是用 add 來替換 sub,add.call(sub,3,1) == add(3,1) ,所以運(yùn)行結(jié)果為:alert(4); // 注意:js 中的函數(shù)其實(shí)是對(duì)象,函數(shù)名是對(duì) Function 對(duì)象的引用。
看一個(gè)稍微復(fù)雜一點(diǎn)的例子
function Class1()
{
this.name = "class1";
this.showNam = function()
{
alert(this.name);
}
}
function Class2()
{
this.name = "class2";
}
var c1 = new Class1();
var c2 = new Class2();
c1.showNam.call(c2);
注意,call 的意思是把 c1 的方法放到c2上執(zhí)行,原來c2是沒有showNam() 方法,現(xiàn)在是把c1 的showNam()方法放到 c2 上來執(zhí)行,所以this.name 應(yīng)該是 class2,執(zhí)行的結(jié)果就是 :alert("class2");
怎么樣,覺得有意思了吧,可以讓a對(duì)象來執(zhí)行b對(duì)象的方法,這是java程序員所不敢想的。還有更有趣的,可以用 call 來實(shí)現(xiàn)繼承
function Class1()
{
this.showTxt = function(txt)
{
alert(txt);
}
}
function Class2()
{
Class1.call(this);
}
var c2 = new Class2();
c2.showTxt("cc");
這樣 Class2 就繼承Class1了,Class1.call(this) 的 意思就是使用 Class1 對(duì)象代替this對(duì)象,那么 Class2 中不就有Class1 的所有屬性和方法了嗎,c2 對(duì)象就能夠直接調(diào)用Class1 的方法以及屬性了,執(zhí)行結(jié)果就是:alert(“cc”);
對(duì)的,就是這樣,這就是 javaScript 如何來模擬面向?qū)ο笾械睦^承的,還可以實(shí)現(xiàn)多重繼承。
function Class10()
{
this.showSub = function(a,b)
{
alert(a-b);
}
}
function Class11()
{
this.showAdd = function(a,b)
{
alert(a+b);
}
}
function Class2()
{
Class10.call(this);
Class11.call(this);
}
很簡單,使用兩個(gè) call 就實(shí)現(xiàn)多重繼承了
當(dāng)然,js的繼承還有其他方法,例如使用原型鏈,這個(gè)不屬于本文的范疇,只是在此說明call 的用法
說了call ,當(dāng)然還有 apply,這兩個(gè)方法基本上是一個(gè)意思
區(qū)別在于 call 的第二個(gè)參數(shù)可以是任意類型,而apply的第二個(gè)參數(shù)必須是數(shù)組,也可以是arguments
還有 callee,caller,這個(gè)和call的 用法就不同了,放到下次講吧 ,呵呵。
/*又一篇文章*/
<
input
type
="text"
id
="myText"
value
="input text"
>
<
script
>
function
Obj(){
this
.value
=
"
對(duì)
象!
"
;}
var
value
=
"
global 變
量
"
;
function
Fun1(){alert(
this
.value);}
window.Fun1();
//
global 變量
Fun1.call(window);
//
global 變量
Fun1.call(document.getElementById('myText'));
//
input text
Fun1.call(
new
Obj());
//
對(duì)象!
</
script
>call函數(shù)和apply方法的第一個(gè)參數(shù)都是要傳入給當(dāng)前對(duì)象的對(duì)象,及函數(shù)內(nèi)部的this。后面的參數(shù)都是傳遞給當(dāng)前對(duì)象的參數(shù)。
運(yùn)行如下代碼:<
script
>
var
func
=
new
function
(){
this
.a
=
"
func
"
}
var
myfunc
=
function
(x){
var
a
=
"
myfunc
"
;
alert(
this
.a);
alert(x);
}
myfunc.call(func,
"
var
"
);
</
script
>
可見分別彈出了func和var。到這里就對(duì)call的每個(gè)參數(shù)的意義有所了解了。
對(duì)于apply和call兩者在作用上是相同的,但兩者在參數(shù)上有區(qū)別的。
對(duì)于第一個(gè)參數(shù)意義都一樣,但對(duì)第二個(gè)參數(shù):
apply傳入的是一個(gè)參數(shù)數(shù)組,也就是將多個(gè)參數(shù)組合成為一個(gè)數(shù)組傳入,而call則作為call的參數(shù)傳入(從第二個(gè)參數(shù)開始)。
如
func.call(func1,var1,var2,var3)對(duì)應(yīng)的apply寫法為:func.apply(func1,
[var1,var2,var3])
同時(shí)使用apply的好處是可以直接將當(dāng)前函數(shù)的arguments對(duì)象作為apply的第二個(gè)參數(shù)傳入.
感謝各位的閱讀,以上就是“javaScript中的call()方法與apply方法的使用”的內(nèi)容了,經(jīng)過本文的學(xué)習(xí)后,相信大家對(duì)javaScript中的call()方法與apply方法的使用這一問題有了更深刻的體會(huì),具體使用情況還需要大家實(shí)踐驗(yàn)證。這里是億速云,小編將為大家推送更多相關(guān)知識(shí)點(diǎn)的文章,歡迎關(guān)注!
免責(zé)聲明:本站發(fā)布的內(nèi)容(圖片、視頻和文字)以原創(chuàng)、轉(zhuǎn)載和分享為主,文章觀點(diǎn)不代表本網(wǎng)站立場,如果涉及侵權(quán)請(qǐng)聯(lián)系站長郵箱:is@yisu.com進(jìn)行舉報(bào),并提供相關(guān)證據(jù),一經(jīng)查實(shí),將立刻刪除涉嫌侵權(quán)內(nèi)容。