由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 相关文章推荐
jquery maxlength使用说明
Sep 09 Javascript
jquery ajax请求实例深入解析
Nov 26 Javascript
javascript简单实现滑动菜单效果的方法
Jul 27 Javascript
jQuery简单实现仿京东商城的左侧菜单效果代码
Sep 09 Javascript
分享15个大家都熟知的jquery小技巧
Dec 02 Javascript
JQuery日历插件My97DatePicker日期范围限制
Jan 20 Javascript
js style.display=block显示布局错乱问题的解决方法
Sep 21 Javascript
关于JavaScript中事件绑定的方法总结
Oct 26 Javascript
JavaScript 计算笛卡尔积实例详解
Dec 02 Javascript
vue实现todolist单页面应用
Apr 11 Javascript
vue在index.html中引入静态文件不生效问题及解决方法
Apr 29 Javascript
vue2 v-model/v-text 中使用过滤器的方法示例
May 09 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
各种战术和打法的原创者
2020/03/04 星际争霸
海贼王动画变成“真人”后,凯多神还原,雷利太帅了!
2020/04/09 日漫
PHP获取文件的MD5值并判断是否被修改的例子
2014/06/19 PHP
PHP中foreach()用法汇总
2015/07/02 PHP
PHP查看当前变量类型的方法
2015/07/31 PHP
kindeditor 加入七牛云上传的实例讲解
2017/11/12 PHP
关于laravel 子查询 &amp; join的使用
2019/10/16 PHP
基于jquery的无限级联下拉框js插件
2011/10/29 Javascript
JavaScript Scoping and Hoisting 翻译
2012/07/03 Javascript
JS中showModalDialog 的使用解析
2013/04/17 Javascript
jquery动态增加text元素以及删除文本内容实例代码
2013/07/01 Javascript
判断一个变量是数组Array类型的方法
2013/09/16 Javascript
jquery ajax修改全局变量示例代码
2013/11/08 Javascript
Ajax同步与异步传输的示例代码
2013/11/21 Javascript
原生js实现复制对象、扩展对象 类似jquery中的extend()方法
2014/08/30 Javascript
Seajs 简易文档 提供简单、极致的模块化开发体验
2016/04/13 Javascript
详解JavaScript中的自定义事件编写
2016/05/10 Javascript
JavaScript原生编写《飞机大战坦克》游戏完整实例
2017/01/04 Javascript
JS 组件系列之Bootstrap Table 冻结列功能IE浏览器兼容性问题解决方案
2017/06/30 Javascript
详解angularjs4部署文件过大解决过程
2018/12/05 Javascript
vuex(vue状态管理)的特殊应用案例分享
2020/03/03 Javascript
javascript利用canvas实现鼠标拖拽功能
2020/07/23 Javascript
H5+css3+js搭建带验证码的登录页面
2020/10/11 Javascript
Python 制作糗事百科爬虫实例
2016/09/22 Python
Python批处理删除和重命名文件夹的实例
2018/07/11 Python
python3 实现对图片进行局部切割的方法
2018/12/05 Python
利用Python批量识别电子账单数据的方法
2021/02/08 Python
世界上最大的字体市场:MyFonts
2020/01/10 全球购物
大学生最常用的自我评价
2013/12/07 职场文书
高二英语教学反思
2014/01/19 职场文书
《散步》教学反思
2014/03/02 职场文书
行政专员求职信范文
2014/05/03 职场文书
党的群众路线教育实践活动对照检查材料(个人)
2014/09/24 职场文书
先进班集体事迹材料
2014/12/25 职场文书
煤矿隐患排查制度
2015/08/05 职场文书
2015年幼儿园班主任个人工作总结
2015/10/22 职场文书