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 相关文章推荐
setAttribute 与 class冲突解决
Feb 17 Javascript
关于document.cookie的使用javascript
Apr 11 Javascript
JQuery 应用 JQuery.groupTable.js
Dec 15 Javascript
基于jquery & json的省市区联动代码
Jun 26 Javascript
JS连连看源码完美注释版(推荐)
Dec 09 Javascript
jQuery过滤选择器用法示例
Sep 12 Javascript
webpack入门必知必会
Jan 16 Javascript
Angular.js自定义指令学习笔记实例
Feb 24 Javascript
详解webpack + vue + node 打造单页面(入门篇)
Sep 23 Javascript
AngularJS中scope的绑定策略实例分析
Oct 30 Javascript
详解Vue2.0组件的继承与扩展
Nov 23 Javascript
vue如何实现关闭对话框后刷新列表
Apr 08 Vue.js
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
getimagesize获取图片尺寸实例
2014/11/15 PHP
PHP使用pear自带的mail类库发邮件的方法
2015/07/08 PHP
php阳历转农历优化版
2016/08/08 PHP
yii框架使用分页的方法分析
2019/07/25 PHP
学习YUI.Ext第五日--做拖放Darg&Drop
2007/03/10 Javascript
struts2+jquery+json实现异步加载数据(自写)
2013/06/24 Javascript
浅析JavaScript中的常用算法与函数
2013/11/21 Javascript
JS二维数组的定义说明
2014/03/03 Javascript
JS实现iframe编辑器光标位置插入内容的方法(兼容IE和Firefox)
2016/06/24 Javascript
JavaScript 链式结构序列化详解
2016/09/30 Javascript
解析NodeJs的调试方法
2016/12/11 NodeJs
js如何判断是否在iframe中及防止网页被别站用iframe嵌套
2017/01/11 Javascript
原生js实现电商侧边导航效果
2017/01/19 Javascript
使用vue构建移动应用实战代码
2017/08/02 Javascript
浅谈Vuex的状态管理(全家桶)
2017/11/04 Javascript
AngularJs返回前一页面时刷新一次前面页面的方法
2018/10/09 Javascript
js回文数的4种判断方法示例
2019/06/04 Javascript
Egg Vue SSR 服务端渲染数据请求与asyncData
2019/11/24 Javascript
vue实现购物车的小练习
2020/12/21 Vue.js
[08:07]DOTA2每周TOP10 精彩击杀集锦vol.8
2014/06/25 DOTA
python缩进区别分析
2014/02/15 Python
python实现多线程的方式及多条命令并发执行
2016/06/07 Python
scrapy爬虫实例分享
2017/12/28 Python
Python常见数据类型转换操作示例
2019/05/08 Python
Python企业编码生成系统之主程序模块设计详解
2019/07/26 Python
实现Python与STM32通信方式
2019/12/18 Python
Python字典深浅拷贝与循环方式方法详解
2020/02/09 Python
超酷炫 CSS3垂直手风琴菜单
2016/06/28 HTML / CSS
Toppik顶丰增发纤维官网:解决头发稀疏
2017/12/30 全球购物
Pandora西班牙官方商店:PandoraShop.es
2020/10/05 全球购物
暑期实习鉴定
2013/12/16 职场文书
银行实习生的自我评价
2014/01/13 职场文书
会计辞职信范文
2014/01/15 职场文书
实习会计求职自荐信范文
2014/03/10 职场文书
需求分析说明书
2014/05/09 职场文书
消防隐患整改通知书
2015/04/22 职场文书