您的位置:首页 > 移动开发

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])
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: