js的call 与 apply 方法
来源:互联网 发布:网络教育学籍参军 编辑:程序博客网 时间:2024/06/07 01:21
调用一个对象的一个方法,并以另一个对象来替换该对象。
call(thisObject,arg1,arg2,…,argn);
apply(thisObject,[arg1,arg2,…,argn]);
call和apply都是为了改变某个函数运行时的context即上下文而存在的,换言之,即为了改变函数体内部的this的指向的。二者作用一样,只不过是接受参数的形式不一样。
obj.call(thisObj,arg1,arg2,…);
obj.apply(thisObj,[arg1,arg2,…]);
两者的作用一致,都是将obj(即this)绑定到thisObj,这时候thisObj具备了obj的属性和方法。
function Animal(){ this.name = "Animal"; this.showName = function(){ alert(this.name); } } function Cat(){ this.name = "Cat"; } var animal = new Animal(); var cat = new Cat(); //通过call或apply方法,将原本属于Animal对象的showName()方法交给对象cat来使用了。 //输入结果为"Cat" animal.showName.call(cat,","); //animal.showName.apply(cat,[]);
call 的意思是把 animal 的方法放到cat上执行,原来cat是没有showName() 方法,现在是把animal 的showName()方法放到 cat上来执行,所以this.name 应该是 Cat。
function cat(){};cat.prototype={ food:"fish", say: function(){ alert("I love "+this.food); } } var blackCat = new cat; blackCat.say();
如果一个对象为dog={food:’bone’},我们不想对它重新定义say方法,此时可以通过apply或call 用blackCat的say方法,即:blackCat.say.call(dog)
此时弹框弹出:i love bone。
call和apply是为了动态改变this的,当一个object没有某个方法,但其他有时,就可借助这两个方法。
用的比较多的,通过document.getElementsByTagName选择的dom 节点是一种类似array的array。它不能应用Array下的push,pop等方法。我们可以通过:var domNodes = Array.prototype.slice.call(document.getElementsByTagName(“*”));这样domNodes就可以应用Array下的所有方法了。
- js的call 与 apply 方法
- js中的call()方法与apply()方法
- js中call与apply方法
- js apply()与call()方法详解
- js中call()与apply()方法
- js的call方法和apply方法
- Js apply call方法
- JS-call/apply 方法
- JS Call()与Apply()
- JS call与apply
- JS Call()与Apply()
- js apply 与 call
- js call与apply
- js call()与apply()
- js: call与apply
- js的call()和apply()方法
- js call和apply方法的了解
- js里的call和apply方法
- c++录屏、FFmpeg录屏、录屏格式转换
- 接口和抽象类的区别
- ATL--创建简单的ATL之dll工程,给接口添加属性(实际上就是一个函数对)
- XAMARIN模拟器的配置与连接
- View中的onDraw()方法的canvas的来由
- js的call 与 apply 方法
- Hibernate——一级缓存__二级缓存__查询缓存
- PHP身份证、手机常用规则验证
- js滑动到底部加载更多
- MySQL 5.6 (Win7 64位)下载、安装与配置图文教程
- spring aop学习--拦截controller
- cloud_note项目的搭建
- 联想台式机Windows 7系统设置双显示器输出
- 二进制中1的个数