由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 相关文章推荐
select组合框option的捕捉实例代码
Sep 30 Javascript
用js统计用户下载网页所需时间的脚本
Oct 15 Javascript
用Jquery实现多级下拉框无刷新的联动
Dec 22 Javascript
javascript学习笔记(六) Date 日期类型
Jun 19 Javascript
jquery控制显示服务器生成的图片流
Aug 04 Javascript
jQuery中常用的遍历函数用法实例总结
Sep 01 Javascript
基于jQuery实现仿QQ空间送礼物功能代码
May 24 Javascript
详解Angular2中Input和Output用法及示例
May 21 Javascript
JS沙箱模式实例分析
Sep 04 Javascript
react以create-react-app为基础创建项目
Mar 14 Javascript
微信小程序scroll-x失效的完美解决方法
Jul 18 Javascript
使用ng-packagr打包Angular的方法示例
Sep 21 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
Memcache 在PHP中的使用技巧
2010/02/08 PHP
php ZipArchive压缩函数详解实例
2013/11/06 PHP
thinkPHP5.0框架命名空间详解
2017/03/18 PHP
php微信公众号开发之简答题
2018/10/20 PHP
golang实现php里的serialize()和unserialize()序列和反序列方法详解
2018/10/30 PHP
php数组指针函数功能及用法示例
2020/02/11 PHP
用JAVASCRIPT如何给&amp;lt;textarea&amp;gt;&amp;lt;/textarea&amp;gt;赋值
2007/04/20 Javascript
javascript之可拖动的iframe效果代码
2008/08/01 Javascript
javascript中字符串替换函数replace()方法与c# 、vb 替换有一点不同
2010/06/25 Javascript
jQuery学习笔记(4)--Jquery中获取table中某列值的具体思路
2013/04/10 Javascript
JQuery 控制内容长度超出规定长度显示省略号
2014/05/23 Javascript
js图片滚动效果时间可随意设定当鼠标移上去时停止
2014/06/26 Javascript
jquery实现未经美化的简洁TAB菜单效果
2015/08/28 Javascript
JS提示:Uncaught SyntaxError:Unexpected token ) 错误的解决方法
2016/08/19 Javascript
浅谈JS之iframe中的窗口
2016/09/13 Javascript
微信小程序 删除项目工程实现步骤
2016/11/10 Javascript
基于node.js express mvc轻量级框架实践
2017/09/14 Javascript
Vuejs 2.0 子组件访问/调用父组件的方法(示例代码)
2018/02/08 Javascript
vue下载excel的实现代码后台用post方法
2019/05/10 Javascript
浅谈Vue为什么不能检测数组变动
2019/10/14 Javascript
JavaScript/TypeScript 实现并发请求控制的示例代码
2021/01/18 Javascript
Python中操作MySQL入门实例
2015/02/08 Python
python和bash统计CPU利用率的方法
2015/07/10 Python
Django中URLconf和include()的协同工作方法
2015/07/20 Python
从DataFrame中提取出Series或DataFrame对象的方法
2018/11/10 Python
Python图片的横坐标汉字实例
2019/12/04 Python
python图形用户接口实例详解
2019/12/16 Python
python:目标检测模型预测准确度计算方式(基于IoU)
2020/01/18 Python
Python绘制动态水球图过程详解
2020/06/03 Python
社区工作感言
2014/02/21 职场文书
搞笑婚礼主持词
2014/03/13 职场文书
2014院党委领导班子对照检查材料思想汇报
2014/09/24 职场文书
工作业绩不及格检讨书
2014/10/28 职场文书
2016机关干部作风建设心得体会
2016/01/21 职场文书
详解如何修改nginx的默认端口
2021/03/31 Servers
单身狗福利?Python爬取某婚恋网征婚数据
2021/06/03 Python