JavaScript高级程序设计(九):基本概念----函数

一、参数的理解

  1、ECMAScript中的参数在内部是用一个数组来表示的。函数接收到的始终是这个数组,而不关心数组中包含多少个参数,即使没有参数也可以。

  2、实质上,函数可以通过arguments对象来访问参数数组,从而获取传递给函数的每一个参数【即第一个参数是arguments[0],第二个参数是arguments[1],以此类推】。使用length属性来确定传递进来多少个参数。eg:

//函数
function sayHi(name,msg){
console.log('hello! '+name+','+msg);
} //同样的使用arguments也可以实现
function sayHi(){
console.log('hello! '+arguments[]+','+arguments[]);
} //调用时候,可以返回同样的结果
sayHi('tom','how old are you today?'); //hello!tom,how old are you today?

  3、ECMAScript没有函数签名【接收参数的类型和个数没影响】,所以函数重载没办法实现。

  4、利用arguments可以实现函数的重载效果,eg:

//根据传递参数的个数来执行不同的逻辑
function doAdd(){
if(arguments.length==){
console.log(arguments[]+);
}else if(arguments.length==){
console.log(arguments[]+arguments[]);
}
} //调用
doAdd(); //20(执行if) doAdd(,); //40(执行elseif)

  

  5、ECMAScript中没有函数重载,so如果存在两个同名的函数,则该名字只属于后定义的函数【即后定义的函数才有效】。

 

上一篇:定时器setTimeout()和Node.js的Event Loop


下一篇:ABP开发框架前后端开发系列---(16)ABP框架升级最新版本的经验总结