//匿名函数也叫拉姆达函数
//使用基本形式创建的函数叫做函数声明,其他形式的叫函数表达式
myfun();//函数声明提升, 只适用与基本形式创建的函数
function myfun(){
console.log("基本函数")
}
/*
* return关键字:
* return用于返回函数的结果,可选,根据需要来添加
* 注意事项:
* 1.return只能出现在函数体内,出现在函数体外或者其他地方会造成语法错误
* 2.函数在执行过程中,只要执行过return语句就会停止继续执行函数体内的其他代码(return后面的代码都不会执行)
* 3.函数体内可以存多个return语句,但是只会执行一个
* 4.return后面可以不接变量或者表达式,直接return停止函数执行
* 5.return的返回值可以是任意的数据类型
* 6.return只能有一个返回值
* 7.如果函数没有返回值,那么这个函数的值就会自带被赋值为undefined
*/
/*
* arguments对象:
* 每一个函数在创建的时候,都会隐式的去创建一个arguments对象个一个this对象,
* 它包含有实参的信心,只在函数体内起作用,并且永远指向当前函数的调用者传入的所以参数
*
* arguments对象是在用来访问函数参数的,通过arguments对象,我们无需明确指出参数的名称就能够直接访问参数
*/
function sayName(){
console.log(arguments.length);//获取实参的个数(长度)
console.log(arguments[0],arguments[1]);
if(arguments[0] == "Tom")//arguments[下标]可以取到任意一项
return arguments[0]+",懒猫!";
}
console.log(sayName("Tom","Jack"));
//根据arguments对象的长度的不同,执行不同的代码块
function len_fun(){
if(arguments.length == 0)
return;
else if(arguments.length==1)
return arguments[0];
else if(arguments.length==2)
return arguments[0]+arguments[1]
}
console.log(len_fun(1,3));
//在传参过程中,如果实参对形参有遗漏,那么遗漏的参数回以undefined的形式穿给形参
/*
* arguments.callee() -- 递归
* 在函数中调用函数本身叫递归
* 递归算法:将问题转化为规模缩小的同类问题的子问题,每一个子问题都用同样的算法
* 去解决,一般来说,一个递归算法就是函数用自身去解决他的子问题
*
* 递归算法的特点
* 1.在函数中调用自身
* 2.在递归过程中,必须有一个明确的条件判断递归结束,这个条件就是递归出口
* 3.递归的算法简洁,但效率低,通常不作推荐算法
*
* 缺点:
* 如果递归的终止条件不明确,或者缺少终止条件,会导致函数长时间运行,使用户界面处于假死状态
*
* arguments.callee()函数调用函数自身,总比写函数名要好、
*/
// n!=n*(n-1) 5*4*3*2*1
var sum = function(n){
if(n<=1){//作为递归结束条件
return 1;
}
return n*arguments.callee(n-1);
}
// var num=1;
// for(var i=5;i>=1;i--){
// num = num*i;
// }
函数的注意&递归
最新推荐文章于 2024-08-15 22:40:53 发布