目录
一、回调函数
将函数A作为参数传递给函数B,在函数B中调用函数A,函数A称为回调函数。
//回调函数
function cal(a,b,fn) { //fn是一个回调函数
//相当于 var k =fn(a,b);
// return k;
return fn(a,b) //对fn进行回调
}
function f1(a1,b1){
return a1+b1;
}
var s = cal(10,20,f1); //函数名代表函数的入口地址
console.log('s=',s);
可以得到s的值是30
二、递归调用
1.什么是递归?
函数自己调用自己。
2.用递归解决问题的条件
A、问题可以分解,分解后得到的新问题的解法与原问题的解法相同。
B、分解的过程要有明确的结束条件。
3. 递归的过程
A、自上而下分解问题
B、自下而上回溯得到问题的解
举例:5!
5!-->5*4! 4! -->4*3! 3!-->3*2! 2!-->2*1!
1!-->2!-->3!-->4!-->5!
//用递归求n!
function fac(n){
if(n==1){ //递归结束条件
return 1;
}else{
return n*fac(n-1); //递归调用
}
}
console.log('6!=',fac(6));
(4) 作用域
变量的作用范围。
①全局作用域(全局变量):在函数外部定义的变量或在函数内部没有使用var声明的变量。在浏
览器页面没有关闭之前一直占用内存空间。比较耗费内存。在浏览器页面关闭时才释放内
②局部作用域(局部变量):在函数内部用var关键字定义的变量。只在函数内部起作用,函数调
用结束后,局部变量所占的内存就会被释放。
③块级作用域:ES6(ECMAScript 2016)使用let声明的变量,作用范围在语句块中
for(let i=0;i<100;i++){
}
④作用域链:当在一个函数内部声明另一个函数时,内层函数只能在外层函数作用域内执行,在
内层函数执行的过程中,若需要引入某个变量,首先会在当前作用域中寻找,若未
找到,则继续向上一层级的作用域中寻找,直到全局作用域,称这种链式的查询关
系为作用域链。
var s = 0;
function fun(t) {
console.log('t=',t);
function f2(){ //函数的声明(定义)
console.log('s=',s); //作用域链,逐层向上找,找到 s
}
f2() //函数的调用
}
fun(110)