JavaScript中函数(Function)的apply与call理解_javascript技巧
程序员文章站
2022-03-31 09:53:08
...
JavaScript函数调用分为4中模式:
1. 方法调用模式:即对象包含方法属性,Obj.methodName()或者Obj[methodName]()。
2. 函数调用模式:即methodName()。
3. 构造器调用模式:即new MethodName()。
4. apply和call调用模式:即ObjA.apply(ObjB,args[])或者ObjA.call(ObjB,arg1,arg2...)。
函数调用时,除了接收形式参数外,还会接收this和arguments。其中this为函数对象上下文,arguments为实际参数。
apply和call实现同样的功能,即切换函数对象的上下文(this指向的引用),区别在于形式参数不一样。apply为arguments或者数组,call为以逗号隔开多个单独形式参数。
function add(c) { alert(this.a+this.b+c); } var test={a:1,b:2} add.call(test,3);
在执行add.call(test,3); 之前add和test都属于window下,此时this指向window。add.call(test,3); 执行时,进入add方法体,此时this由window切换为test,此时this.a=test.a,this.b=test.b,c为形式参数传入的值,即alert()的结果为1+2+3=6。apply也是一样的功能。
通过apply和call实现扩展和继承:
function Animal(name){ this.name = name; this.showName = function(){ alert(this.name); } } function Cat(name){ Animal.call(this, name); } var cat = new Cat("Black Cat");//执行时,Cat函数体的this由window切换为Cat{}, // Animal函数体的this.name通过形式参数传入即为Black Cat,最终cat //得到的结果为cat=Cat{name:"Black Cat",showName: function(){ alert(this.name);}, cat.showName();//执行时this由window切换为 //Cat{name:"Black Cat",showName: function(){ alert(this.name);} 此时this.name //为this.name=Cat.name,因此为Black Cat。
上一篇: 用模板引擎Smarty来开发PHP程序
推荐阅读
-
深入理解JavaScript中的传值与传引用_javascript技巧
-
JavaScript中的apply()方法和call()方法使用介绍_javascript技巧
-
有关JavaScript中call()和apply() 的一些理解
-
深入理解JavaScript 中的匿名函数((function() {})();)与变量的作用域
-
理解 javascript 中的函数表达式与函数声明
-
有关JavaScript中call()和apply() 的一些理解
-
深入理解JavaScript 中的匿名函数((function() {})();)与变量的作用域
-
一图搞懂javascript中的this与call/apply/bind的6中关系
-
JavaScript中的apply和call函数详解_jquery
-
理解 javascript 中的函数表达式与函数声明