个性化阅读
专注于IT技术分析

快速理解JS中的递归函数和闭包

定义的函数有两种,一种是函数声明,第二种是函数表达式。关于函数声明,最重要的一个特征就是函数声明的提升,就是可以在函数声明之前调用,也不会出错。函数表达式就是把一个匿名函数复制给一个变量,这个变量就变成了函数的名字,这个函数表达式就不能提前在函数表达式之前调用,否则会出错。

JavaScript函数和闭包

一、递归函数

递归函数是在一个函数通过名字调用自身的情况下构成的。我们在Function的引用类型中提过,由于函数名是指指针,于函数表达式其实没太多关系,如果在函数表达式内也使用函数名,那改变函数名的时候,也造成了许多麻烦,不科学,所以我们可以使用arguments.callee指向参数的原函数,也就是正在执行的原函数的指针。

可是在严格模式下,不能通过脚本访问arguments.callee,所以,我们可以通过命名函数表达式,这种方式无论是在严格模式还是非严格模式都可以。

例如:

"use strict"
function factorial(num){ 
if (num <= 1){ 
return 1; 
} else { 
return num * arguments.callee(num-1); 
} 
}

// 改进
var ff = function f(num){ // 把命名函数复制给变量,从而可以把arguments.callee直接写成命名函数的名字
if (num <= 1){ 
return 1; 
} else { 
return num * f(num-1); 
} 
}
console.log(factorial(10)) // 3628800 严格模式下出错
console.log(ff(10)) // 3628800 

二、闭包

我们知道JS中没有块作用域,只有全局作用域和函数作用域,所以函数和变量之间的结合体就是闭包,这里的变量可以是全局变量中的,也可以是函数作用域中的。所以如果一个函数本身内部定义了变量,或者引用了全局作用域中的变量,那它自己就是一个闭包。

赞(0) 打赏
未经允许不得转载:srcmini » 快速理解JS中的递归函数和闭包
分享到: 更多 (0)

评论 抢沙发

评论前必须登录!

 

觉得文章有用就打赏一下文章作者

微信扫一扫打赏