Javascript call apply
2013-05-07 16:25
344 查看
call
方法 call([thisObj[,arg1[,
arg2[,…[,.argN]]]]])
调用一个对象的一个方法,以另一个对象替换当前对象。
call
方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj
指定的新对象。如果没有提供 thisObj
参数,那么 Global
对象被用作 thisObj。说明白一点其实就是更改对象的内部指针,即改变对象的this指向的内容。这在面向对象的js编程过程中有时是很有用的。
call函数和apply方法的第一个参数都是要传入给当前对象的对象,及函数内部的this。后面的参数都是传递给当前对象的参数。
运行如下代码:
<script>
var func=new function(){this.a="func"}
var myfunc=function(x){
vara="myfunc";
alert(this.a);
alert(x);
}
myfunc.call(func,"var");
</script>
可见分别弹出了func和var。//先调用func函数,用this.a=”func”替换myfunc中的this.a ;
然后将”var”传递给方法myfunc的参数x
对于apply和call两者在作用上是相同的,但两者在参数上有区别的。
如 func.call(func1,var1,var2,var3)==func.apply(func1,[var1,var2,var3])
方法 call([thisObj[,arg1[,
arg2[,…[,.argN]]]]])
调用一个对象的一个方法,以另一个对象替换当前对象。
call
方法可将一个函数的对象上下文从初始的上下文改变为由 thisObj
指定的新对象。如果没有提供 thisObj
参数,那么 Global
对象被用作 thisObj。说明白一点其实就是更改对象的内部指针,即改变对象的this指向的内容。这在面向对象的js编程过程中有时是很有用的。
call函数和apply方法的第一个参数都是要传入给当前对象的对象,及函数内部的this。后面的参数都是传递给当前对象的参数。
运行如下代码:
<script>
var func=new function(){this.a="func"}
var myfunc=function(x){
vara="myfunc";
alert(this.a);
alert(x);
}
myfunc.call(func,"var");
</script>
可见分别弹出了func和var。//先调用func函数,用this.a=”func”替换myfunc中的this.a ;
然后将”var”传递给方法myfunc的参数x
对于apply和call两者在作用上是相同的,但两者在参数上有区别的。
如 func.call(func1,var1,var2,var3)==func.apply(func1,[var1,var2,var3])
相关文章推荐
- [js]Javascript call() & apply() vs bind()
- 【JavaScript】apply&call
- javascript中的apply&call方法
- javascript apply & call
- 深入浅出 妙用Javascript中apply、call、bind
- javascript 之 call & apply
- JavaScript:prototype&apply&call
- JavaScript:prototype&apply&call
- javascript中apply、call和bind的区别
- JavaScript中的函数:函数的apply、call方法和length属性
- 前端见微知著JavaScript基础篇:你所不知道的apply, call 和 bind
- javascript 中apply和call的用法记录
- JavaScript中的self、this、call、apply、prototype、initialize
- [转]深入浅出妙用 Javascript 中 apply、call、bind
- Javascript点滴:this, Function.apply 及Function.call
- 全面理解javascript的caller,callee,call,apply概念(修改版)
- Javascript 中的 call 和 apply
- JavaScript中call和apply
- 关于javascript中apply()和call()方法的区别
- 关于javascript中apply()和call()方法的区别