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 相关文章推荐
WEB高性能开发之疯狂的HTML压缩
Jun 19 Javascript
20款超赞的jQuery插件 Web开发人员必备
Feb 26 Javascript
Js 冒泡事件阻止实现代码
Jan 27 Javascript
DOM节点深度克隆函数cloneNode()用法实例
Jan 12 Javascript
JS+CSS实现仿支付宝菜单选中效果代码
Sep 25 Javascript
基于jquery实现下拉框美化特效
Feb 02 Javascript
javascript随机抽取0-100之间不重复的10个数
Feb 25 Javascript
Bootstrap打造一个左侧折叠菜单的系统模板(一)
May 17 Javascript
微信小程序 实例应用(记账)详解
Sep 28 Javascript
Vue 2.x教程之基础API
Mar 06 Javascript
详解基于Angular4+ server render(服务端渲染)开发教程
Aug 28 Javascript
微信小程序实现传参数的几种方法示例
Jan 10 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
用PHP调用Oracle存储过程
2006/10/09 PHP
destoon实现调用热门关键字的方法
2014/07/15 PHP
PHP中读取文件的几个方法总结(推荐)
2016/06/03 PHP
javascript的函数
2007/01/31 Javascript
Javascript 学习笔记 错误处理
2009/07/30 Javascript
分享一个我自己写的ToolTip提示插件(附源码)
2013/01/20 Javascript
jquery网页元素拖拽插件效果及实现
2013/08/05 Javascript
12306验证码破解思路分享
2015/03/25 Javascript
Backbone.js框架中Model与Collection的使用实例
2016/05/07 Javascript
EasyUI中在表单提交之前进行验证
2016/07/19 Javascript
requirejs + vue 项目搭建详解
2017/06/16 Javascript
vue实现页面加载动画效果
2017/09/19 Javascript
vue-cli之router基本使用方法详解
2017/10/17 Javascript
vue中的scope使用详解
2017/10/29 Javascript
js实现微信/QQ直接跳转到支付宝APP打开口令领红包功能
2018/01/09 Javascript
Vue实现动态创建和删除数据的方法
2018/03/17 Javascript
react MPA 多页配置详解
2019/10/18 Javascript
layui实现数据表格隐藏列的示例
2019/10/25 Javascript
原生js实现随机点餐效果
2019/12/10 Javascript
详解Node.JS模块 process
2020/08/31 Javascript
vuecli项目构建SSR服务端渲染的实现
2020/10/30 Javascript
[03:40]DOTA2亚洲邀请赛小组赛第二日 赛事回顾
2015/01/31 DOTA
Numpy数组的保存与读取方法
2018/04/04 Python
使用Python实现微信提醒备忘录功能
2018/12/04 Python
python 获取毫秒数,计算调用时长的方法
2019/02/20 Python
日本最大美瞳直送网:Morecontact(中文)
2019/04/03 全球购物
软件配置管理有什么好处
2015/04/15 面试题
商场拾金不昧表扬信
2014/01/13 职场文书
班级活动策划书
2014/02/06 职场文书
政府个人对照检查材料
2014/08/28 职场文书
2014年安全员工作总结
2014/11/13 职场文书
优秀团队申报材料
2014/12/26 职场文书
开国大典观后感
2015/06/04 职场文书
幼儿园音乐教学反思
2016/02/18 职场文书
nginx代理实现静态资源访问的示例代码
2022/07/07 Servers
Win11自动黑屏怎么办 Win11自动黑屏设置教程
2022/07/15 数码科技