Javascript基础 函数“重载” 详细介绍


Posted in Javascript onOctober 25, 2013

Javascript不像其他编程语言一样具有函数签名(什么是函数签名,简单的说就是说函数的接受参数类型和参数个数,也有人认为返回类型也应该包括。具体概念大家可以到网上查询)。

所以Javascript是不能像其他语言一样实现方法名相同,参数个数不同…的这类重载的,不信你可以试试:

         function show(){
             alert("1");
         }
         function show(num1){
             alert(num1);
         }         window.onload=function(){
             show();
             show(2);
         }

断点调试下,不带参数的show方法是不会被执行的,它会被show(num1)方法给覆盖掉。

那么Javascript中就不可以实现“重载”了么?答案是可以的,只是是另一种方式而已。对,就是利用arguments。

那么什么是arguments呢?在JS中它是一个特殊的属性,它可以像数组一样通过下标索引获取参数的值(但它不是数组),通过length获取参数个数:

         function showParamsCount(){
             alert("参数个数:"+arguments.length);//输出:参数个数:4
             alert("下标索引为3的参数:"+arguments[3]);//输出: 下标索引为3的参数:你好
         }         window.onload=function(){
             showParamsCount("Hello",4,5,"你好");
         }

还要知道的一点是JS中函数的命名参数不是必须的,所以要想知道调用时传递了多少个参数还是得通过arguments获取参数。

下面就实现一个简单的方法重载:

         function showMessage(){
             if(arguments.length==1){
                 alert(arguments[0]);
             }else if( arguments.length==2){
                 alert(arguments[0]+"说:"+arguments[1]);
             }else{
                 return false;
             }
         }         window.onload=function(){
             showMessage("Hi!");
             showMessage("张三","Hi 你妹");
         }

这样JS的重载算是实现了。

在看js高级程序设计这本书的时候发现arguments的值与对应命名参数的值永远同步,以前没注意过这个问题

         function showMessage(name,msg){
             arguments[1]="我可以改变msg的值";
             alert(name+"说:"+msg);//输出:张三说:我可以改变msg的值
         }         window.onload=function(){
             showMessage("张三","Hi 你妹");
         }

好吧关于js“重载”的基础知识就这么些

Javascript 相关文章推荐
QQ邮箱的一个文本编辑器代码
Mar 14 Javascript
JS option location 页面跳转实现代码
Dec 27 Javascript
js 强制弹出窗口代码研究-又一款代码
Mar 20 Javascript
event.X和event.clientX的区别分析
Oct 06 Javascript
详解jquery uploadify 上传文件
Nov 09 Javascript
js中用window.open()打开多个窗口的name问题
Mar 13 Javascript
详解JavaScript中的表单验证
Jun 16 Javascript
AngularJS中$injector、$rootScope和$scope的概念和关联关系深入分析
Jan 19 Javascript
jQuery Ajax实现跨域请求
Jan 21 Javascript
详解Vue 动态添加模板的几种方法
Apr 25 Javascript
js构建二叉树进行数值数组的去重与优化详解
Mar 26 Javascript
select2 ajax 设置默认值,初始值的方法
Aug 09 Javascript
JS关闭窗口或JS关闭页面的几种代码分享
Oct 25 #Javascript
jquery及原生js获取select下拉框选中的值示例
Oct 25 #Javascript
Jquery 模拟用户点击超链接或者按钮的方法
Oct 25 #Javascript
各种常用的JS函数整理
Oct 25 #Javascript
jquery索引在使用中的一些困惑
Oct 24 #Javascript
各种页面定时跳转(倒计时跳转)代码总结
Oct 24 #Javascript
js 浏览本地文件夹系统示例代码
Oct 24 #Javascript
You might like
解析百度搜索结果link?url=参数分析 (全)
2012/10/09 PHP
thinkPHP中配置的读取与C方法详解
2016/12/05 PHP
可兼容IE的获取及设置cookie的jquery.cookie函数方法
2013/09/02 Javascript
javaScript如何生成xmlhttp
2013/12/16 Javascript
JavaScript制作简易的微信打飞机
2015/03/31 Javascript
JavaScript如何调试有哪些建议和技巧附五款有用的调试工具
2015/10/28 Javascript
JavaScript中Textarea滚动条不能拖动的解决方法
2015/12/15 Javascript
JS获取当前脚本文件的绝对路径
2016/03/02 Javascript
jquery遍历table的tr获取td的值实现方法
2016/05/19 Javascript
详解Javascript函数声明与递归调用
2016/10/22 Javascript
angularjs 表单密码验证自定义指令实现代码
2016/10/27 Javascript
基于javascript实现的快速排序
2016/12/02 Javascript
AngularJS 在同一个界面启动多个ng-app应用模块详解
2016/12/20 Javascript
vue双向绑定的简单实现
2016/12/22 Javascript
JS数组去重常用方法实例小结【4种方法】
2018/05/28 Javascript
angular学习之动态创建表单的方法
2018/12/07 Javascript
js嵌套的数组扁平化:将多维数组变成一维数组以及push()与concat()区别的讲解
2019/01/19 Javascript
atom-design(Vue.js移动端组件库)手势组件使用教程
2019/05/16 Javascript
通过mod_python配置运行在Apache上的Django框架
2015/07/22 Python
python模块简介之有序字典(OrderedDict)
2016/12/01 Python
python基础教程项目四之新闻聚合
2018/04/02 Python
python获取酷狗音乐top500的下载地址 MP3格式
2018/04/17 Python
Python使用sort和class实现的多级排序功能示例
2018/08/15 Python
Python+Kepler.gl轻松制作酷炫路径动画的实现示例
2020/06/02 Python
美国家居装饰和豪华家具购物网站:One Kings Lane
2018/12/24 全球购物
STAUD官方网站:洛杉矶独有的闲适风格
2019/04/11 全球购物
科颜氏法国官网:Kiehl’s法国
2019/08/20 全球购物
骨干教师培训方案
2014/05/06 职场文书
2014年国庆节庆祝建国65周年比赛演讲稿
2014/09/21 职场文书
个人反四风对照检查材料思想汇报
2014/09/23 职场文书
服务员态度差检讨书
2014/10/28 职场文书
2014年房地产个人工作总结
2014/12/20 职场文书
谢师宴学生致辞
2015/07/27 职场文书
用Python实现一个打字速度测试工具来测试你的手速
2021/05/28 Python
Windows Server 2019 安装DHCP服务及相关配置
2022/04/28 Servers
win11开机发生死循环重启怎么办?win11开机发生死循环重启解决方法
2022/08/05 数码科技