由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禁止小键盘输入数字功能代码
Aug 01 Javascript
jQuery源码分析-03构造jQuery对象-工具函数
Nov 14 Javascript
jquery 触发a链接点击事件解决方案
May 02 Javascript
jQuery实现鼠标可拖动调整表格列宽度
May 26 Javascript
jQuery入门介绍之基础知识
Jan 13 Javascript
jQuery元素的隐藏与显示实例
Jan 20 Javascript
javascript中sort排序实例详解
Jul 24 Javascript
js读取json文件片段中的数据实例
Mar 09 Javascript
Vue关于数据绑定出错解决办法
May 15 Javascript
JS+Canvas绘制动态时钟效果
Nov 10 Javascript
原生JS实现烟花效果
Mar 10 Javascript
javascript设计模式 ? 享元模式原理与用法实例分析
Apr 15 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函数file_get_contents超时处理的方法详解
2013/06/03 PHP
PHP动态规划解决0-1背包问题实例分析
2015/03/23 PHP
jquery $.ajax入门应用一
2008/11/19 Javascript
JavaScript iframe的相互操作浅析
2009/10/14 Javascript
ExtJS下grid的一些属性说明
2009/12/13 Javascript
js操作table示例(个人心得)
2013/11/29 Javascript
JS图像无缝滚动脚本非常好用
2014/02/10 Javascript
Node.js中的事件驱动编程详解
2014/08/16 Javascript
node.js中的querystring.parse方法使用说明
2014/12/10 Javascript
jquery序列化方法实例分析
2015/06/10 Javascript
简述JavaScript对传统文档对象模型的支持
2015/06/16 Javascript
HTML5 Shiv完美解决IE(IE6/IE7/IE8)不兼容HTML5标签的方法
2015/11/25 Javascript
js闭包引起的事件注册问题介绍
2016/03/29 Javascript
快速解决jquery.touchSwipe左右滑动和垂直滚动条冲突
2016/04/15 Javascript
AngularJS模仿Form表单提交的实现代码
2016/12/08 Javascript
Nodejs高扩展性的模板引擎 functmpl简介
2017/02/13 NodeJs
Angular1.x复杂指令实例详解
2017/03/01 Javascript
JS完成画圆圈的小球
2017/03/07 Javascript
angularjs中的$eval方法详解
2017/04/24 Javascript
bootstrap表单示例代码分享
2017/05/18 Javascript
利用node实现一个批量重命名文件的函数
2017/12/21 Javascript
vue跳转同一个组件,参数不同,页面接收值只接收一次的解决方法
2019/11/05 Javascript
[51:07]VGJ.S vs Pain 2018国际邀请赛小组赛BO2 第一场 8.17
2018/08/20 DOTA
python 文件操作api(文件操作函数)
2016/08/28 Python
python中aioysql(异步操作MySQL)的方法
2019/04/11 Python
Django组件cookie与session的具体使用
2019/06/05 Python
使用Django xadmin 实现修改时间选择器为不可输入状态
2020/03/30 Python
Python求解排列中的逆序数个数实例
2020/05/03 Python
python re.match()用法相关示例
2021/01/27 Python
日语专业个人求职信范文
2014/02/02 职场文书
小学生秋游活动方案
2014/02/23 职场文书
《分一分》教学反思
2014/04/13 职场文书
工厂车间标语
2014/06/19 职场文书
就业协议书
2014/09/12 职场文书
MySQL创建高性能索引的全步骤
2021/05/02 MySQL
CSS子盒子水平和垂直居中的五种方法
2022/07/23 HTML / CSS