Js里重载问题

Posted breezezqf

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了Js里重载问题相关的知识,希望对你有一定的参考价值。

JS里是否存在重载?

  我们知道JS和Java很像,Java是有重载的,那么JS里有吗?

  答案是没有的

  重载就是函数(方法)名一样,参数列表不同,同命不同参称之为重载

  在js里如果有同命不同参的函数,则后写的函数覆盖前面的函数(html从上到下解析顺序),也就是多个同名函数,只有一个最后一个起作用。

模拟重载 

  js里虽然没有重载,但是我们可以模拟重载

说明  

  模拟重载需要用到arguments

  argument是类数组对象

属性

  length  获取arguments对象的长度

  callee  引用当前正在执行的函数

特性

  arguments和function是分不开的,因为arguments不能显示创建

  arguments对象只有函数开始时才能使用

 

arguments写在方法内部,可以获取传给当前方法的N个参数,可以把它想象成一个数组,我们也可以取某个下标的元素单独操作

案例1:累加

  

<script>
		function add(){
			var sum=0;
			for (var i = 0; i < arguments.length; i++) {
				sum+=arguments[i];
			}
			return sum;
		}
		document.write(add(1,2,3,4,5));  //累加结果
</script>

案例2:递归

  <script>
    function add(x){
      if(x==1){
      return 1;
    }else{
      return x+arguments.callee(x-1);
       //return x+add(x-1);   
       //两行代码都行,上一行都调用了它的属性callee(调用当前执行方法)
      }
    }
    document.write(add(10));
  </script>

  

以上是关于Js里重载问题的主要内容,如果未能解决你的问题,请参考以下文章

angularJS使用ocLazyLoad实现js延迟加载

导航架构片段重载问题

为啥vscode中.js文件没有片段提示,但是.html文件有提示?

谷歌浏览器调试jsp 引入代码片段,如何调试代码片段中的js

类外功能重载未见

VSCode自定义代码片段——JS中的面向对象编程