由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 相关文章推荐
js Flash插入函数免激活代码
Mar 31 Javascript
Javascript 设计模式(二) 闭包
May 26 Javascript
捕获浏览器关闭、刷新事件不同情况下的处理方法
Jun 02 Javascript
javascript实现根据3原色制作颜色选择器的方法
Jul 17 Javascript
使用jQuery制作基础的Web图片轮播效果
Apr 22 Javascript
iframe中使用jquery进行查找的方法【案例分析】
Jun 17 Javascript
在线引用最新jquery文件的实现方法
Aug 26 Javascript
收藏AngularJS中最重要的核心功能
Jul 09 Javascript
JavaScript的数据类型转换原则(干货)
Mar 15 Javascript
关于引入vue.js 文件的知识点总结
Jan 28 Javascript
Vue作用域插槽实现方法及作用详解
Jul 08 Javascript
Vue实现一种简单的无限循环滚动动画的示例
Jan 10 Vue.js
腾讯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
基于curl数据采集之正则处理函数get_matches的使用
2013/04/28 PHP
PHP简单获取视频预览图的方法
2015/03/12 PHP
php实现约瑟夫问题的方法小结
2015/03/23 PHP
PHP计算近1年的所有月份
2017/03/13 PHP
jQuery 使用手册(六)
2009/09/23 Javascript
JavaScript面向对象之Prototypes和继承
2012/07/12 Javascript
侧栏跟随滚动的简单实现代码
2013/03/18 Javascript
JQueryEasyUI Layout布局框架的使用
2013/04/08 Javascript
node.js下LDAP查询实例分享
2015/09/30 Javascript
JS实现自定义简单网页软键盘效果代码
2015/11/05 Javascript
超漂亮的jQuery图片轮播特效
2015/11/24 Javascript
Jquery轮播效果实现过程解析
2016/03/30 Javascript
谈一谈JS消息机制和事件机制的理解
2016/04/14 Javascript
bootstrap 表单验证使用方法
2017/01/11 Javascript
jQuery插件扩展操作入门示例
2017/01/16 Javascript
浅析Vue实例以及生命周期
2018/08/14 Javascript
jquery向后台提交数组的代码分析
2020/02/20 jQuery
Javascript实现简易天数计算器
2020/05/18 Javascript
JavaScript事件概念详解(区分静态注册和动态注册)
2021/02/05 Javascript
Python转换HTML到Text纯文本的方法
2015/01/15 Python
举例讲解Python中is和id的用法
2015/04/03 Python
使用简单工厂模式来进行Python的设计模式编程
2016/03/01 Python
Python3.4 splinter(模拟填写表单)使用方法
2018/10/13 Python
HTML5 visibilityState属性详细介绍和使用实例
2014/05/03 HTML / CSS
乌克兰第一的珠宝网上商店:Gold.ua
2019/11/29 全球购物
物业管理公司实习生自我鉴定
2013/09/19 职场文书
经理秘书找工作求职信
2013/12/19 职场文书
英语演讲稿范文
2014/01/03 职场文书
一夜的工作教学反思
2014/02/08 职场文书
清扬洗发水广告词
2014/03/14 职场文书
企业总经理助理岗位职责
2014/09/12 职场文书
社区党的群众路线教育实践活动总结材料
2014/10/31 职场文书
幼儿园开学报名通知
2015/07/16 职场文书
2016保送生自荐信范文
2016/01/29 职场文书
css3 利用transform-origin 实现圆点分布在大圆上布局及旋转特效
2021/04/29 HTML / CSS
撤回我也能看到!教你用Python制作微信防撤回脚本
2021/06/11 Python