微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

详解JS函数重载

JS的函数定义可以指定形式参数名称,多多少少我们会以为js至少可以支持参数个数不同的方法重载,然而遗憾的是这仅仅是一个假象,js所有的参数都是以arguments传递过去的,这个参数类似于数组,在函数调用的时候,所有的实参都是保存在了这个数据结构里面,我们定义函数的时候所指定的形式参数其实是为这个数据结构里面的数据定义一个快捷的访问方式。也就是说js所有的函数都是支持无限个参数的,加上数据类型是弱类型,那么JS的函数除了名称就真的没有方法区别了?

  办法总是有的,我们可以利用JavaScript中的特殊对象arguments来模拟函数重载。用它来判断传入参数的个数或类型以区分重载。

1.根据参数个数重载

js判断传入参数数量可以用arguments.length这个属性来判断;

代码如下:
函数调用 add(10); add(10,20);

2.根据参数类型重载

判断变量类型的3种方法: 1.用 typeof 语句判断变量类型,typeof语句返回类型对应的字符串。 2.用 instanceof 语句判断变量类型,instanceof语句返回true/false。 3.用 constructor 属性判断变量类型,这个属性返回用来构造该变量的构造函数引用。 对照表:可以看出用 typeof 不能准确的判断出具体的类型,所以我们用 constructor 来进行判断。

typeofstringnumberobjectfunctionbooleanobjectobject constructorStringNumberObjectFunctionBooleanArrayUser Define

代码如下:
函数调用 alert(add(10)); alert(add(10,20));

小伙伴们是否理解了javascript函数重载的方法了呢,有疑问就留言吧

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。

相关推荐