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 相关文章推荐
用JQuery实现表格隔行变色和突出显示当前行的代码
Feb 10 Javascript
JS仿百度搜索自动提示框匹配查询功能
Nov 21 Javascript
jquery 合并内容相同的单元格(示例代码)
Dec 13 Javascript
javascript中实现兼容JAVA的hashCode算法代码分享
Aug 11 Javascript
jquery实现的淡入淡出下拉菜单效果
Aug 25 Javascript
jQuery弹出下拉列表插件(实现kindeditor的@功能)
Aug 16 Javascript
js实现本地图片文件拖拽效果
Jul 18 Javascript
微信小程序实现点击按钮移动view标签的位置功能示例【附demo源码下载】
Dec 06 Javascript
JavaScript实现区块链
Mar 14 Javascript
vue2 设置router-view默认路径的实例
Sep 20 Javascript
vue项目使用$router.go(-1)返回时刷新原来的界面操作
Jul 26 Javascript
IDEA配置jQuery, $符号不再显示黄色波浪线的问题
Oct 09 jQuery
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
模仿OSO的论坛(四)
2006/10/09 PHP
php中使用cookie来保存用户登录信息的实现代码
2012/03/08 PHP
PHP中is_dir()函数使用指南
2015/05/08 PHP
JS版的date函数(和PHP的date函数一样)
2014/05/12 Javascript
jQuery判断当前点击的是第几个li的代码
2014/09/26 Javascript
Node.js实用代码段之正确拼接Buffer
2016/03/17 Javascript
妙用Bootstrap的 popover插件实现校验表单提示功能
2016/08/29 Javascript
JS实现的简单图片切换功能示例【测试可用】
2017/02/14 Javascript
微信小程序 如何引入外部字体库iconfont的图标
2018/01/31 Javascript
vue项目中,main.js,App.vue,index.html的调用方法
2018/09/20 Javascript
laydate时间日历插件使用方法详解
2018/11/14 Javascript
微信小程序 如何保持登录状态
2019/08/16 Javascript
微信小程序实现电子签名并导出图片
2020/05/27 Javascript
VSCode launch.json配置详细教程
2020/06/18 Javascript
[05:46]2018完美盛典-《同梦共竞》
2018/12/17 DOTA
Python模拟登录验证码(代码简单)
2016/02/06 Python
python的debug实用工具 pdb详解
2019/07/12 Python
python小程序之4名牌手洗牌发牌问题解析
2020/05/15 Python
python 6行代码制作月历生成器
2020/09/18 Python
M1芯片安装python3.9.1的实现
2021/02/02 Python
CSS3 translate导致字体模糊的实例代码
2019/08/30 HTML / CSS
德国最大的拼图在线商店:Puzzle.de
2016/12/17 全球购物
美国创意礼品网站:UncommonGoods
2017/02/03 全球购物
美国折扣香水网站:The Perfume Spot
2020/12/12 全球购物
简单的JAVA编程面试题
2013/03/19 面试题
普师专业个人自荐信范文
2013/11/26 职场文书
实习生体会的自我评价范文
2013/11/28 职场文书
工程开工庆典邀请函
2014/02/01 职场文书
2014年大班元旦活动方案
2014/02/26 职场文书
产品质量承诺范本
2014/03/31 职场文书
职工擅自离岗检讨书
2014/09/23 职场文书
思想作风整顿个人剖析材料
2014/10/06 职场文书
计划生育诚信协议书
2014/11/02 职场文书
暑假安全保证书
2015/02/28 职场文书
教师正风肃纪心得体会
2016/01/15 职场文书
详解pytorch创建tensor函数
2022/03/22 Python