由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 相关文章推荐
javascript的onchange事件与jQuery的change()方法比较
Sep 28 Javascript
灵活应用js调试技巧解决样式问题的步骤分享
Mar 15 Javascript
jQuery阻止事件冒泡具体实现
Oct 11 Javascript
jquery通过a标签删除table中的一行的代码
Dec 02 Javascript
在百度知道团队中快速审批新成员的js脚本
Feb 02 Javascript
JS+CSS实现另类带提示效果的竖向导航菜单
Oct 15 Javascript
JS+Canvas实现的俄罗斯方块游戏完整实例
Dec 12 Javascript
详解jquery插件jquery.viewport.js学习使用方法
Sep 08 jQuery
Angularjs按需查询实例代码
Oct 30 Javascript
vue.js实现的经典计算器/科学计算器功能示例
Jul 11 Javascript
Angular8基础应用之表单及其验证
Aug 11 Javascript
Js图片点击切换轮播实现代码
Jul 27 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
PHP数组排序函数合集 以及它们之间的联系分析
2013/06/27 PHP
ThinkPHP Mobile使用方法简明教程
2014/06/18 PHP
CI框架中类的自动加载问题分析
2016/11/21 PHP
PHP 应用容器化以及部署方法
2018/02/12 PHP
Laravel实现短信注册的示例代码
2018/05/29 PHP
python进程与线程小结实例分析
2018/11/11 PHP
php设计模式之适配器模式原理、用法及注意事项详解
2019/09/24 PHP
HR vs CL BO3 第二场 2.13
2021/03/10 DOTA
jQuery页面图片伴随滚动条逐渐显示的小例子
2013/03/21 Javascript
js 实现 input type=&quot;file&quot; 文件上传示例代码
2013/08/07 Javascript
让网页跳转到指定位置的jquery代码非书签
2013/09/06 Javascript
JavaScript模拟可展开、拖动与关闭的聊天窗口实例
2015/05/12 Javascript
js实现下拉列表选中某个值的方法(3种方法)
2015/12/17 Javascript
jQuery组件easyui基本布局实现代码
2016/08/25 Javascript
JavaScript随机生成颜色的方法
2016/10/15 Javascript
基于JavaScript实现下拉列表左右移动代码
2017/02/07 Javascript
AngularJS使用拦截器实现的loading功能完整实例
2017/05/17 Javascript
js阻止默认右键的下拉菜单方法
2018/01/02 Javascript
微信小程序wx.navigateTo中events属性实现页面间通信传值,数据同步
2019/07/13 Javascript
小程序实现图片预览裁剪插件
2019/11/22 Javascript
[01:23]2014DOTA2国际邀请赛 球迷无处不在Ti现场世界杯受关注
2014/07/10 DOTA
利用Python将时间或时间间隔转为ISO 8601格式方法示例
2017/09/05 Python
Python绘制3D图形
2018/05/03 Python
python代码如何实现余弦相似性计算
2020/02/09 Python
jenkins+python自动化测试持续集成教程
2020/05/12 Python
Farfetch香港官网:汇集全球时尚奢侈品购物平台
2017/11/26 全球购物
Joseph官网:英国小众奢侈品牌
2019/05/17 全球购物
预备党员入党自我评价范文
2014/03/10 职场文书
理财学专业自荐书
2014/06/28 职场文书
村委会贫困证明范本
2014/09/17 职场文书
校园之声广播稿
2015/08/18 职场文书
2019年“红色之旅”心得体会1000字(3篇)
2019/09/27 职场文书
python实现的web监控系统
2021/04/27 Python
pytorch中Schedule与warmup_steps的用法说明
2021/05/24 Python
springboot @ConfigurationProperties和@PropertySource的区别
2021/06/11 Java/Android
redis cluster支持pipeline的实现思路
2021/06/23 Redis