javascript函数教程之函数参数介绍
程序员文章站
2022-09-24 13:03:15
javascript中的函数定义并未指定函数形参的类型,函数调用甚至不检查传入形参的个数
同名形参
function add(x,x,x){
return x;
}
console...
javascript中的函数定义并未指定函数形参的类型,函数调用甚至不检查传入形参的个数
同名形参
function add(x,x,x){ return x; } console.log(add(1,2,3));//3
严格模式下,同名形参抛出语法错误。
参数个数:实参比形参个数少时,剩下的形参为undefined
function add(x,y){ console.log(x,y);//1 undefined } add(1);
实参比形参个数要多时,剩下的实参没有办法直接获得,需要使用即将提到的arguments对象
function add(x){ console.log(arguments[0],arguments[1],arguments[2])//1 2 3 console.log(arguments[0]+arguments[1]+arguments[2]);//6 return x+1;//2 } add(1,2,3);
内部属性【callee】:arguments对象有一个名为callee的属性,该属性是一个指针,指向拥有这个arguments对象的函数
function factorial(num){ if(num <=1){ return 1; }else{ return num * arguments.callee(num-1); } } console.log(factorial(5));//120
函数重载:js不能重载
//后面的声明覆盖了前面的声明 function addsomenumber(num){ return num + 100; } function addsomenumber(num){ return num + 200; } var result = addsomenumber(100);//300
参数传递:函数的传递参数过程中可以定义多个参数,接受参数时会按照代码的顺序进行接收
fn7('javascript'); fn7('学习js课程'); function fn7( a ){ alert( a.charat(4) ); //返回的值为 先返回"s" ,再返回"课" }