JavaScript函数(二)回调函数

目录

一、回调函数

二、递归调用

1.什么是递归?

2.用递归解决问题的条件

3. 递归的过程


一、回调函数

将函数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)

 

  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值