由JavaScript中call()方法引发的对面向对象继承机制call的思考


Posted in Javascript onSeptember 12, 2011

起因:

今天在阅读snandy大神的读jQuery之五(取DOM元素)时,看到有讲到toArray()方法,具体jQuery代码如下:

toArray: function() { 
return slice.call( this, 0 ); 
}, 
get: function( num ) { 
return num == null ? 
// Return a 'clean' array 
this.toArray() : 
// Return just the object 
( num < 0 ? this[ this.length + num ] : this[ num ] ); 
},

看到这里的call()方法,以前也看过手册,说是对象冒充的,用于继承的。在jQuery源码里有点乱,所以就把这部分提取出来,放在一个单独文件中,来看看具体执行。

但还是没太明白,今天决定研究下call。于是查了下MDN上的说明,心血来潮,拿出我的“葵花宝典”-牛津大辞典,准备练习下自己的英文水平,提高提高,而且也提供给有需要的朋友一些帮助(翻译中如果有些出路,请各位前辈见谅!)
call

摘要:

 通过给定的this和arguments来调用一个function

 注意:该方法与apply方法语法相似,但不同的是:call()接受参数列,而apply()接受传递给函数的参数数组

 Function类的一个方法:版本JavaScript 1.3版以后

语法:

 fun.call(thisArg[, arg1[, arg2[, ...]]])

参数说明:

 thisArg:

为fun()的调用指定对象。注意:你看到的this值可能不是实际的值:如果这个方法是在 non-strict mode下,null和undefined会被全局对象替换掉,原始的值会被封装。

 arg1,arg2,....

this对象的参数

描述:

当调用一个已存在的函数,你可以分配不同的对象。这时,this指定的对象是当前正在调用对象。

通过call,你可以只写一次方法,而被另一个对象来继承。而不用自己再新建对象时,重写该方法。(即对象冒充,下面会有例子说明!)

在MDN官网上面有例子可以看看。另外,无意中在stackoverflow上看到了篇相关的问题,看到里面的一个回答,一下子就明白了对象冒充,怎么冒充了。
下面把那部分摘取出来(点击这里看原文):

In javascript, methods of an object can be bound to another object at runtime. In short, javascript allows an object to "borrow" the method of another object:

object1 = { 
name:'frank', 
greet:function(){ 
alert('hello '+this.name) 
} 
}; 
object2 = { 
name:'andy' 
}; 
// Note that object2 has no greet method. 
// But we may "borrow" from object1: 
object1.greet.call(object2);

The call and apply methods of function objects (in javascript functions are objects as well) allows you to do this. So in your code you could say that the Nodelist is borrowing an array's slice method. What does the conversion is the fact that slice returns another array as it's result.

这里的第一句话说的很形象,大致意思就是:在JavaScript中,对象的方法可绑定到另外一个对象上。简单点说,就是,JavaScript中允许对象‘借用'本不属于它本身的方法。“冒充”也就不言而喻了,就上上面的例子来说,object2冒充object1,来调用object1的方法。

PS:菜鸟第一次写博客,有点乱,我相信以后会慢慢改善,向各位师兄师姐学习怎么写博客,写好博客。另外欢迎大家给我批评与指导!

参考资料:
1.w3cschool ECMAScript 继承机制实现

2.MDN上call的说明

3.stackoverflow

Javascript 相关文章推荐
JSChart轻量级图形报表工具(内置函数中文参考)
Oct 11 Javascript
JS小功能(onmouseover实现选择月份)实例代码
Nov 28 Javascript
删除节点的jquery代码
Jan 13 Javascript
Angularjs 基础入门
Dec 26 Javascript
Angular.Js中过滤器filter与自定义过滤器filter实例详解
May 08 Javascript
javascript 封装Date日期类实例详解
May 28 Javascript
详解nuxt sass全局变量(公共scss解决方案)
Jun 27 Javascript
详解Angularjs 自定义指令中的数据绑定
Jul 19 Javascript
vue的for循环使用方法
Feb 12 Javascript
微信小程序生成二维码的示例代码
Mar 29 Javascript
微信小程序与公众号卡券/会员打通的问题
Jul 25 Javascript
JavaScript 替换所有匹配内容及正则替换方法
Feb 12 Javascript
腾讯UED 漂亮的提示信息效果代码
Sep 12 #Javascript
jQuery的.live()和.die() 使用介绍
Sep 10 #Javascript
jquery tab插件精简版分享
Sep 10 #Javascript
javascript语言结构小记(一)
Sep 10 #Javascript
JavaScript高级程序设计 客户端存储学习笔记
Sep 10 #Javascript
JavaScript高级程序设计 错误处理与调试学习笔记
Sep 10 #Javascript
JavaScript高级程序设计 事件学习笔记
Sep 10 #Javascript
You might like
一次失败的jQuery优化尝试小结
2011/02/06 Javascript
jQuery AjaxQueue改进步骤
2011/10/06 Javascript
jQuery 阴影插件代码分享
2012/01/09 Javascript
js获取location.href的参数实例代码
2013/08/02 Javascript
seaJs的模块定义和模块加载浅析
2014/06/06 Javascript
JavaScript的各种常见函数定义方法
2014/09/16 Javascript
javascript+html5实现仿flash滚动播放图片的方法
2015/04/27 Javascript
JS建造者模式基本用法实例分析
2015/06/30 Javascript
Bootstrap项目实战之首页内容介绍(全)
2016/04/25 Javascript
利用css+原生js制作简单的钟表
2020/04/07 Javascript
很棒的js Tab选项卡切换效果
2016/08/30 Javascript
微信小程序 wx:key详细介绍
2016/10/28 Javascript
Angular.Js的自动化测试详解
2016/12/09 Javascript
如何在Angular2中使用jQuery及其插件的方法
2017/02/09 Javascript
详解vue项目首页加载速度优化
2017/10/18 Javascript
javascript性能优化之分时函数的介绍
2018/03/28 Javascript
React Native悬浮按钮组件的示例代码
2018/04/05 Javascript
最简单的JS实现json转csv的方法
2019/01/10 Javascript
小程序hover-class点击态效果实现
2019/02/26 Javascript
小程序实现按下录音松开识别语音
2019/11/22 Javascript
JavaScript回调函数callback用法解析
2020/01/14 Javascript
[46:02]DOTA2上海特级锦标赛D组资格赛#2 Liquid VS VP第二局
2016/02/28 DOTA
Python获取指定字符前面的所有字符方法
2018/05/02 Python
Python数据库封装实现代码示例解析
2020/09/05 Python
全方位了解CSS3的Regions扩展
2015/08/07 HTML / CSS
广州迈达威.net面试题目
2012/03/10 面试题
Does C# support multiple inheritance? (C#支持多重继承吗)
2012/01/04 面试题
建议书的格式
2014/05/12 职场文书
班级团队活动方案
2014/08/14 职场文书
学校端午节活动方案
2014/08/23 职场文书
判缓刑人员个人思想汇报
2014/10/10 职场文书
雷峰塔导游词
2015/02/09 职场文书
2015年学生会个人工作总结
2015/04/09 职场文书
2015初中政教处工作总结
2015/07/21 职场文书
党员反邪教心得体会
2016/01/15 职场文书
python数字转对应中文的方法总结
2021/08/02 Python