标签:arr 调用 console 函数 打印 JS fn log
函数自调用:
指函数在页面加载时就自行调用,不依靠其他的语句,例如fn();函数只调用了一次。
格式:
(function fn( 形参 ) { 内部表达式 } )( 实参 );
实参有两种:直接量(就是直接给值),变量;
arguments.length 实参数量 arguments.callee 运行的函数对象 例:function fn(a, b) { console.log( arguments.length); console.log(arguments.callee); } fn(10, 20)
打印结果:
2
ƒ fn(a, b) {
console.log( arguments.length);
console.log(arguments.callee);
}
1、在函数内部自调用:
function fn () { console.log('fn'); fn(); } fn();
这样的打印会一直调用fn函数,无限打印’fn‘,是一种死循环。
*但可以在fn内部加入条件判断语句避免这种情况;
2、我们可以利用函数自调用,解决一些数学问题,特别是一些迭代计算:
function fn (n) { if(n<=1){ return 1 } else{ return n*fn(n-1) } } var re=fn(10) console.log(re)
打印:3628800
理解:
调用fn后把参数10传入,在条件语句中返回一个10*fn(9),再调用fn把9传入返回9*fn(8),依次推出就是10*9*8*7*6*5*4*3*2*1
计算10+9+...+1——
function fn (n) { if(n<=1){ return 1 } else{ return n+fn(n-1) } } var re=fn(10) console.log(re)
打印结果:
55
3、若要打印一个不知道嵌套了几层的数组的每个元素,可以使用自调用函数:
打印出数组中所有的数字——
var arr = [ [1, 2, 3, 4, [2, 3, 4, 5], [2, 3, 4, 5], [4, 54, 2, 6] ], [2, 3, 4, 4, 5, 6] ] //遍历数组 function fn(arr) { for (var i = 0; i < arr.length; i++) { if (typeof (arr[i]) == "number") { console.log(arr[i]) } else { fn(arr[i]); //函数自调用 } } } fn(arr);
打印结果:(暂不换行,以“,”分隔,在控制台打印是会换行的)
1, 2, 3, 4, 2, 3, 4, 5, 2, 3, 4, 5,4, 54, 2, 6, 2, 3, 4, 4, 5, 6
标签:arr,调用,console,函数,打印,JS,fn,log 来源: https://www.cnblogs.com/LIXI-/p/16405118.html
本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享; 2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关; 3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关; 4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除; 5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。