js中apply与call简单用法详解
你可以直接看例子,也可以先读一下介绍:
call和apply是为了动态改变this而出现的,当一个object没有某个方法,但是其他的有,我们可以借助call或apply用其它对象的方法来操作。
call, apply都属于function.prototype的一个方法,它是javascript引擎内在实现的,因为属于function.prototype,所以每个function对象实例,也就是每个方法都有call, apply属性.既然作为方法的属性,那它们的使用就当然是针对方法的了.这两个方法是容易混淆的,因为它们的作用一样,只是使用方式不同.
从上面可以得出 call, apply 是给方法使用的,为了改变调用该方法的 this指针
简单例子:
call
function a() { this.getname = function (xx) { return xx; } } function b() { } var a = new a(); console.log( a.getname('i am a') ); //i am a var b = new b() ; console.log( a.getname.call(b,'i am b') ); // i am b
b 函数中没有 任何方法 , a 函数有个 getname() 方法 ,a.getname() 自然成立 ,但 b 也要使用 getname() 的方法怎么办呢 ? 那就用 call(this,'参数') !!
可以 再理解一下这句话 -- 我们可以借助call或apply调用其它对象的方法来操作,call和apply是为了动态改变this而出现的 ,本来 a.getname() 的 this 指向 a, call 动态的 把 this 指向了 b ,变成了 b.getname()
apply
apply 与 call 只是参数的使用不同而已
function a() { this.sun = function (a ,b) { return a+b; } } function b() { } var a = new a(); console.log( a.sun(1,2) ); //3 var b = new b() ; console.log( a.sun.call(b,2,2) ); // 4 console.log( a.sun.apply(b,[3, 3]) ); //6
call和apply一般使用情况
用的比较多的,通过document.getelementsbytagname选择的dom 节点是一种类似array的array。它不能应用array下的push,pop等方法。我们可以通过:
var domnodes = array.prototype.slice.call(document.getelementsbytagname("*"));
这样domnodes就可以应用array下的所有方法了。
以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持。
上一篇: PHP定时任务延缓执行的实现
推荐阅读
-
js中apply()和call()的区别与用法实例分析
-
js中apply与call简单用法详解
-
node.js中express中间件body-parser的介绍与用法详解
-
javascript中call apply 与 bind方法详解
-
js中的call bind apply简单分析
-
js中apply()和call()的区别与用法实例分析
-
JavaScript中apply与call的用法意义及区别说明_javascript技巧
-
JS中apply,call,bind区别与用法
-
js中apply与call使用详解(附代码)
-
JavaScript中apply与call的用法意义及区别说明_javascript技巧