由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 Ajax功能时需要注意的一个问题(内存溢出)
May 30 Javascript
用js格式化金额可设置保留的小数位数
May 09 Javascript
jquery隔行换色效果实现方法
Jan 15 Javascript
jQuery插件HighCharts绘制2D柱状图、折线图的组合双轴图效果示例【附demo源码下载】
Mar 09 Javascript
Angualrjs 表单验证的两种方式(失去焦点验证和点击提交验证)
May 09 Javascript
10行原生JS实现文字无缝滚动(超简单)
Jan 02 Javascript
原生JS实现多个小球碰撞反弹效果示例
Jan 31 Javascript
微信小程序使用wxParse解析html的方法教程
Jul 06 Javascript
基于js Canvas实现二次贝塞尔曲线
Dec 25 Javascript
three.js实现圆柱体
Dec 30 Javascript
详解webpack4.x之搭建前端开发环境
Mar 28 Javascript
vue中组件通信的八种方式(值得收藏!)
Aug 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
php打开远程文件的方法和风险及解决方法
2013/11/12 PHP
php计算当前程序执行时间示例
2014/04/24 PHP
destoon实现调用热门关键字的方法
2014/07/15 PHP
是 WordPress 让 PHP 更流行了 而不是框架
2016/02/03 PHP
php生成与读取excel文件
2016/10/14 PHP
php抛出异常与捕捉特定类型的异常详解
2016/10/26 PHP
popdiv
2006/07/14 Javascript
Javascript开发之三数组对象实例介绍
2012/11/12 Javascript
ajax中get和post的说明及使用与区别
2012/12/23 Javascript
ie6下png图片背景不透明的解决办法使用js实现
2013/01/11 Javascript
JavaScript移除数组元素减少长度的方法
2013/09/05 Javascript
Javascript基础教程之for循环
2015/01/18 Javascript
深入理解JavaScript中的对象
2015/06/04 Javascript
jQuery右下角悬浮广告实例
2016/10/17 Javascript
详解微信小程序 页面跳转 传递参数
2016/12/08 Javascript
JavaScript中数组Array方法详解
2017/02/27 Javascript
bootstrap弹出层的多种触发方式
2017/05/10 Javascript
jQuery、layer实现弹出层的打开、关闭功能
2017/06/28 jQuery
Vue学习之路之登录注册实例代码
2017/07/06 Javascript
使用pkg打包Node.js应用的方法步骤
2018/10/19 Javascript
vue实现条件叠加搜索的解决方法
2019/05/28 Javascript
微信小程序中悬浮窗功能的实现代码
2019/08/02 Javascript
在vue中高德地图引入和轨迹的绘制的实现
2019/10/11 Javascript
d3.js实现图形拖拽
2019/12/19 Javascript
Vue如何实现验证码输入交互
2020/12/07 Vue.js
Python实现的下载8000首儿歌的代码分享
2014/11/21 Python
Python实现图片转字符画的示例代码
2017/08/21 Python
Python常见数据结构之栈与队列用法示例
2019/01/14 Python
Python搭建代理IP池实现接口设置与整体调度
2019/10/27 Python
python数据分析工具之 matplotlib详解
2020/04/09 Python
pytorch简介
2020/11/11 Python
Python基于opencv的简单图像轮廓形状识别(全网最简单最少代码)
2021/01/28 Python
WebSphere面试题:在WebSphere里面如何部署一个应用
2015/08/02 面试题
《争吵》教学反思
2014/02/15 职场文书
连带责任保证书
2014/04/29 职场文书
民事撤诉申请书范本
2015/05/18 职场文书