由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 相关文章推荐
在b/s开发中经常用到的javaScript技术
Aug 23 Javascript
Array的push与unshift方法性能比较分析
Mar 05 Javascript
extjs 04_grid 单击事件新发现
Nov 27 Javascript
JS控制输入框内字符串长度
May 21 Javascript
详细解读JavaScript编程中的Promise使用
Jul 27 Javascript
jQuery实现的网页左侧在线客服效果代码
Oct 23 Javascript
JS日期对象简单操作(获取当前年份、星期、时间)
Oct 26 Javascript
jQuery获取所有父级元素及同级元素及子元素的方法(推荐)
Jan 21 jQuery
AngularJS select加载数据选中默认值的方法
Feb 28 Javascript
详解Bootstrap 学习(一)入门
Apr 12 Javascript
vue视图不更新情况详解
May 16 Javascript
浅谈element中InfiniteScroll按需引入的一点注意事项
Jun 05 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
基于MySQL分区性能的详细介绍
2013/05/02 PHP
destoon二次开发入门示例
2014/06/20 PHP
PHP输出日历表代码实例
2015/03/27 PHP
php关联数组快速排序的方法
2015/04/17 PHP
PHP入门教程之面向对象的特性分析(继承,多态,接口,抽象类,抽象方法等)
2016/09/11 PHP
Javascript 强制类型转换函数
2009/05/17 Javascript
jquery中实现标签切换效果的代码
2011/03/01 Javascript
jQuery.extend 函数详解
2012/02/03 Javascript
jquery插件lazyload.js延迟加载图片的使用方法
2014/02/19 Javascript
JS实现一个列表中包含上移下移删除等功能
2014/09/24 Javascript
JavaScript里四舍五入函数round用法实例
2015/04/06 Javascript
JavaScript获取数组最小值和最大值的方法
2015/06/09 Javascript
freemarker判断对象是否为空的方法
2015/08/13 Javascript
JQuery中attr属性和jQuery.data()学习笔记【必看】
2016/05/18 Javascript
JS实现的打字机效果完整实例
2016/06/20 Javascript
获取select的value、text值的简单示例(jquery与javascript)
2016/12/07 Javascript
JavaScript数组操作详解
2017/02/04 Javascript
jQuery dateRangePicker插件使用方法详解
2017/07/28 jQuery
JavaScript中七种流行的开源机器学习框架
2018/10/11 Javascript
微信小程序跨页面传递data数据方法解析
2019/12/13 Javascript
JS数组方法concat()用法实例分析
2020/01/18 Javascript
python写日志封装类实例
2015/06/28 Python
python实现用户登陆邮件通知的方法
2015/07/09 Python
每天迁移MySQL历史数据到历史库Python脚本
2018/04/13 Python
Python使用到第三方库PyMuPDF图片与pdf相互转换
2019/05/03 Python
Python 画出来六维图
2019/07/26 Python
python实现的生成word文档功能示例
2019/08/23 Python
python目标检测给图画框,bbox画到图上并保存案例
2020/03/10 Python
软件测试常见笔试题
2012/02/04 面试题
打造完美自荐信
2014/01/24 职场文书
农林环境专业求职信
2014/03/13 职场文书
竞选学习委员演讲稿
2014/04/28 职场文书
医院财务人员岗位职责
2015/04/14 职场文书
环境保护宣传标语大全!
2019/06/28 职场文书
HTML5 新增内容和 API详解
2021/11/17 HTML / CSS
如何在Python中妥善使用进度条详解
2022/04/05 Python