javascript apply 与call用法

一:语法

语法:call (this,arg1,arg2,…argn)

定义:调用一个对象的一个方法,以另一个对象替换当前对象。

说明:call方法可以用来替换另一个对象调用一个方法。call方法可将一个函数的对象上下文从初始的上下文改变为由this指定的新对象。

如果没有提供this参数,那么Global对象被用作this。


语法:apply(this,[arg1,agr2,…argn])

定义:应用某一对象的一个方法。用另一个对象替换当前对象。

说明:如果[arg1,agr2,…argn]不是一个有效的数组或者不是arguments对象,那么将导致一个TypeError

如果没有提供[arg1,agr2,…argn]和this任何一个参数,那么Global对象将被用作this,并且无法被传递任何参数。


区别:call和apply方法主要区别就是参数。call的参数是一个个排列的,apply的参数是放在一个数组里。



< input  type ="text"  id ="myText"    value ="input text" >
< script >
    
function  Obj(){ this .value = " 对象! " ;}
    
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());    // 对象!
</ script >



//定义一个函数,函数里面的this在没有调用该函数时不知道this指向

function Pet(words){
	this.words = words;
	this.speak = function(){
		console.log(this.words);
	}
}


//定义一个Dog函数

function Dog(words){
	Pet.call(this,words);
}

//当new Dog('wang'); Dog里面的this指向的就是dog对象,Pet.call(this,words);就相当于Pet.call(dog,words),就是现在this指向的是dog。

var dog = new Dog('wang');
dog.speak();


评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值