JavaScript中函数(Function)的apply与call理解


Posted in Javascript onJuly 08, 2015

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。
Javascript 相关文章推荐
javascript学习网址备忘
May 29 Javascript
一个cssQuery对象 javascript脚本实现代码
Jul 21 Javascript
jQuery判断checkbox是否选中的3种方法
Aug 12 Javascript
jQuery实现下滑菜单导航效果代码
Aug 25 Javascript
JavaScript数据操作_浅谈原始值和引用值的操作本质
Aug 23 Javascript
JS实现的简单标签点击切换功能示例
Sep 21 Javascript
js 数组详细操作方法及解析合集
Jun 01 Javascript
Vue中 v-if/v-show/插值表达式导致闪现的原因及解决办法
Oct 12 Javascript
Javascript实现时间倒计时功能
Nov 17 Javascript
JavaScript实现简单计算器功能
Dec 19 Javascript
Vue快速实现通用表单验证的示例代码
Jan 09 Javascript
vuex管理状态仓库使用详解
Jul 29 Javascript
JavaScript forEach()遍历函数使用及介绍
Jul 08 #Javascript
JavaScript中调用函数的4种方式代码实例
Jul 08 #Javascript
JavaScript对象属性检查、增加、删除、访问操作实例
Jul 08 #Javascript
jquery获取多个checkbox的值异步提交给php
Jul 07 #Javascript
浅谈jQuery中setInterval()方法
Jul 07 #Javascript
javascript数组排序汇总
Jul 07 #Javascript
javascript编写贪吃蛇游戏
Jul 07 #Javascript
You might like
兼容PHP和Java的des加密解密代码分享
2014/06/26 PHP
ThinkPHP模板判断输出Defined标签用法详解
2014/06/30 PHP
PHP正则表达式替换站点关键字链接后空白的解决方法
2014/09/16 PHP
PHP 实现人民币小写转换成大写的方法及大小写转换函数
2017/11/17 PHP
thinkphp框架无限级栏目的排序功能实现方法示例
2020/03/29 PHP
基于jquery的loading效果实现代码
2010/11/05 Javascript
jQuery实现简单二级下拉菜单
2015/04/12 Javascript
js中this用法实例详解
2015/05/05 Javascript
浅析JavaScript中的事件机制
2015/06/04 Javascript
jQuery+CSS实现简单切换菜单示例
2016/07/27 Javascript
深入理解vue中的$set
2017/06/01 Javascript
浅谈Angular4中常用管道
2017/09/27 Javascript
vue观察模式浅析
2018/09/25 Javascript
用图片替换checkbox原始样式并实现同样的功能
2018/11/15 Javascript
js实现数字滚动特效
2019/12/16 Javascript
[48:48]2014 DOTA2国际邀请赛中国区预选赛 SPD-GAMING VS Dream TIME
2014/05/21 DOTA
举例讲解Python设计模式编程中的访问者与观察者模式
2016/01/26 Python
PyQt5每天必学之事件与信号
2018/04/20 Python
Python日期时间模块datetime详解与Python 日期时间的比较,计算实例代码
2018/09/14 Python
Django中使用极验Geetest滑动验证码过程解析
2019/07/31 Python
pytorch中的weight-initilzation用法
2020/06/24 Python
英国最大的邮寄种子和植物公司:Thompson & Morgan
2017/09/21 全球购物
编写用C语言实现的求n阶阶乘问题的递归算法
2014/10/21 面试题
室内设计自我鉴定
2013/10/15 职场文书
中文专业毕业生自荐信
2013/10/28 职场文书
快餐公司创业计划书
2014/04/29 职场文书
安全伴我行演讲稿
2014/09/04 职场文书
保证金退回承诺函格式
2015/01/21 职场文书
白鹤梁导游词
2015/02/06 职场文书
幼儿园2015年度工作总结
2015/04/01 职场文书
劳动争议仲裁代理词
2015/05/25 职场文书
教师工作证明范本
2015/06/12 职场文书
2015年教学副校长工作总结
2015/07/22 职场文书
高一语文教学反思
2016/02/16 职场文书
python 爬取华为应用市场评论
2021/05/29 Python
Elasticsearch Recovery 详细介绍
2022/04/19 Java/Android