Javascript 面向对象之重载


Posted in Javascript onMay 04, 2010

上几节讲了 JavaScript 面向对象之命名空间 、 javascript 面向对象的JavaScript类 与 JavaScript 面向对象的之私有成员和公开成员 ,大家可以先看上面的再继续往下看。

假如 我这样定义:

function getDate(){.....} 
function getDate(date){.....}

那么后一个方法将覆盖前一个,虽然不报错。

但是我们确实是可以实现重载的,如果你用过jQuery,你就会深有体会,比如$("#btn").val() 是获取id为"btn"的按钮的value值,而$("#btn").val("点我")则是给id为"btn"的按钮赋值。

那么JavaScript是怎么实现(准确地讲应该叫“模拟”)的呢?。
答案很简单:arguments
arguments是JavaScript里的一个内置对象,包含了调用者传递的实际参数,但不局限于函数声明所定义的参数列表,而调用时只它和数组一样有个length属性。 

我们暂且把它当“数组”来理解吧,我们根据该数组的长度以及其元素的类型来选择不同的实现,从而模拟了重载。 

具体请看下面的示例:

function getDate(){ 
if(arguments.length==0){ 
var date=new Date().toLocaleDateString(); 
return "您没有输入参数,现在时间:"+date ; 
} if(arguments.length==1){ 
if(arguments[0].constructor ==Date){ 
return "您输入的参数是Date类型,现在时间是:"+arguments[0].toDateString(); 
} 
if(arguments[0].constructor ==String){ 
return "您输入的参数是String类型,现在时间是:"+arguments[0]; 
} 
} 
}

于是我们可以这样调用:
getDate() 
getDate(new Date()) 
getDate("星期一")

这样就实现了JavaScript的重载,不过我们发现这样的“实现”实在是太勉强了,如果参数多了,就会显得力不从心,代码也会很乱,到处是if{...} 。所以我不建议在JavaScript中使用这样的重载。
Javascript 相关文章推荐
Javascript 对象的解释
Nov 24 Javascript
IE Firefox 使用自定义标签的区别
Oct 15 Javascript
javascript 事件查询综合 推荐收藏
Mar 10 Javascript
理解Javascript_10_对象模型
Oct 16 Javascript
利用Javascript判断操作系统的类型实现不同操作系统下的兼容性
Jan 29 Javascript
利用jQuery及AJAX技术定时更新GridView的某一列数据
Dec 04 Javascript
JCrop+ajaxUpload 图像切割上传的实例代码
Jul 20 Javascript
bootstrap表格内容过长时用省略号表示的解决方法
Nov 21 Javascript
微信小程序实现图片预览功能
Jan 31 Javascript
JS实现图片转换成base64的各种应用场景实例分析
Jun 22 Javascript
js实现按钮开关单机下拉菜单效果
Nov 22 Javascript
利用Angular7开发一个Radio组件的全过程
Jul 11 Javascript
JavaScript 面向对象的之私有成员和公开成员
May 04 #Javascript
javascript 面向对象的JavaScript类
May 04 #Javascript
JavaScript 面向对象之命名空间
May 04 #Javascript
10个实用的脚本代码工具
May 04 #Javascript
利用location.hash实现跨域iframe自适应
May 04 #Javascript
Array.prototype 的泛型应用分析
Apr 30 #Javascript
jQuery 锚点跳转滚动条平滑滚动一句话代码
Apr 30 #Javascript
You might like
PHP数据类型之整数类型、浮点数的介绍
2013/04/28 PHP
php文件上传的例子及参数详解
2013/12/12 PHP
Yii框架调试心得--在页面输出执行sql语句
2014/12/25 PHP
PHP安装memcached扩展笔记
2015/05/28 PHP
Yii模型操作之criteria查找数据库的方法
2016/07/15 PHP
javascript通过className来获取元素的简单示例代码
2014/01/10 Javascript
js中for in语句的用法讲解
2015/04/24 Javascript
javascript仿京东导航左侧分类导航下拉菜单效果
2020/11/25 Javascript
jQuery用FormData实现文件上传的方法
2016/11/21 Javascript
bootstrap模态框消失问题的解决方法
2016/12/02 Javascript
解析NodeJs的调试方法
2016/12/11 NodeJs
详解jQuery同步Ajax带来的UI线程阻塞问题及解决办法
2017/08/09 jQuery
AngularJS实现controller控制器间共享数据的方法示例
2017/10/30 Javascript
BootStrap自定义popover,点击区域隐藏功能的实现
2018/01/23 Javascript
JS获取本地地址及天气的方法实例小结
2019/05/10 Javascript
vue打包静态资源后显示空白及static文件路径报错的解决
2020/09/02 Javascript
如何在JavaScript中等分数组的实现
2020/12/13 Javascript
[44:39]2014 DOTA2国际邀请赛中国区预选赛 NE VS CNB
2014/05/21 DOTA
[03:37]2014DOTA2国际邀请赛 主赛事第一日胜者组TOPPLAY
2014/07/19 DOTA
Python实现ssh批量登录并执行命令
2016/10/25 Python
Python实现字符串格式化的方法小结
2017/02/20 Python
Python下使用Scrapy爬取网页内容的实例
2018/05/21 Python
python实现傅里叶级数展开的实现
2018/07/21 Python
Tensorflow进行多维矩阵的拆分与拼接实例
2020/02/07 Python
python使用matplotlib的savefig保存时图片保存不完整的问题
2021/01/08 Python
python 指定源路径来解决import问题的操作
2021/03/04 Python
泰国排名第一的家居用品中心:HomePro
2020/11/18 全球购物
集团公司人力资源部岗位职责
2014/01/03 职场文书
写求职信有什么意义
2014/02/17 职场文书
体育系毕业生求职自荐信
2014/04/16 职场文书
三分钟演讲稿范文
2014/04/24 职场文书
党支部反对四风思想汇报
2014/10/10 职场文书
企业反腐倡廉心得体会
2015/08/15 职场文书
2015年度个人工作总结报告
2015/10/24 职场文书
PyTorch梯度裁剪避免训练loss nan的操作
2021/05/24 Python
SQL Server数据库基本概念、组成、常用对象与约束
2022/03/20 SQL Server