由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 相关文章推荐
FileUpload 控件 禁止手动输入或粘贴的实现代码
Apr 07 Javascript
js前台判断开始时间是否小于结束时间
Feb 23 Javascript
jQuery的live()方法对hover事件的处理示例
Feb 27 Javascript
JS实现自适应高度表单文本框的方法
Feb 25 Javascript
javascript显式类型转换实例分析
Apr 25 Javascript
JQuery导航菜单选择特效
Apr 11 Javascript
jQuery 全选 全部选 反选 实现代码
Aug 17 Javascript
基于AngularJS实现iOS8自带的计算器
Sep 12 Javascript
javascript函数的四种调用模式
Jan 08 Javascript
JS实现的排列组合算法示例
Jul 16 Javascript
ES6学习笔记之字符串、数组、对象、函数新增知识点实例分析
Jan 22 Javascript
将Vue组件库更换为按需加载的方法步骤
May 06 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生成月历代码
2007/06/14 PHP
如何用ajax来创建一个XMLHttpRequest对象
2012/12/10 Javascript
JS 加入收藏夹的代码(主流浏览器通用)
2013/05/13 Javascript
利用js正则表达式验证手机号,email地址,邮政编码
2014/01/23 Javascript
Jquery 返回json数据在IE浏览器中提示下载的问题
2014/05/18 Javascript
JS使用oumousemove和oumouseout动态改变图片显示的方法
2015/03/31 Javascript
JavaScript中的splice()方法使用详解
2015/06/09 Javascript
JS中frameset框架弹出层实例代码
2016/04/01 Javascript
Jquery插件仿百度搜索关键字自动匹配功能
2016/05/11 Javascript
使用Ajax与服务器(JSON)通信实例
2016/11/04 Javascript
vue引入axios同源跨域问题
2018/09/27 Javascript
详解Vue webapp项目通过HBulider打包原生APP(vue+webpack+HBulider)
2019/02/02 Javascript
JS重学系列之聊聊new操作符
2019/03/04 Javascript
layer父页获取弹出层输入框里面的值方法
2019/09/02 Javascript
VueQuillEditor富文本上传图片(非base64)
2020/06/03 Javascript
vue中el-input绑定键盘按键(按键修饰符)
2020/07/22 Javascript
Vue中 axios delete请求参数操作
2020/08/25 Javascript
[52:06]FNATIC vs NIP 2019国际邀请赛小组赛 BO2 第二场 8.16
2019/08/19 DOTA
Python中断言Assertion的一些改进方案
2016/10/27 Python
浅谈pyhton学习中出现的各种问题(新手必看)
2017/05/17 Python
python数据抓取分析的示例代码(python + mongodb)
2017/12/25 Python
pandas.loc 选取指定列进行操作的实例
2018/05/18 Python
python多进程提取处理大量文本的关键词方法
2018/06/05 Python
Python中文件的写入读取以及附加文字方法
2019/01/23 Python
python爬虫租房信息在地图上显示的方法
2019/05/13 Python
python下对hsv颜色空间进行量化操作
2020/06/04 Python
python实现图片,视频人脸识别(dlib版)
2020/11/18 Python
Kangol帽子官网:坎戈尔袋鼠
2018/09/26 全球购物
当一个对象被当作参数传递到一个方法后,此方法可改变这个对象的属性,并可返回变化后的结果,那么这里到底是值传递还是引用传递?
2014/09/09 面试题
研究生求职推荐信范文
2013/11/30 职场文书
历史专业学生的自我评价
2014/02/28 职场文书
员工加薪申请报告
2015/05/15 职场文书
2016年幼儿园庆六一开幕词
2016/03/04 职场文书
彩虹社八名人气艺人全新周边限时推出,性转女装男装一次拥有!
2022/04/01 日漫
尝试使用Python爬取城市租房信息
2022/04/12 Python
分享几个实用的CSS代码块
2022/06/10 HTML / CSS