javaScript函数的闭包的一个运用 一段魔法代码来说明
2011-07-16 17:10
567 查看
函数可以被视为普通的动态对象来处理。
函数本身也是一种数据。
一段奇特的代码:
<html>
<head>
<title>Example-6.1(2)奇特的函数</title>
</head>
<body>
<script>
<!--
function dwn(s)
{
document.write(s + "<br/>");
}
//"无穷"的菲波纳契数据结构
function Fib(n, x, y)
{
//这里借参数x,y来保留前面的计算结果,即菲波数当前数列到n的最后两个数值
//在实际调用中通常并不用到x、y这两个参数
var a = x || 1; //13
var b = y || 1; //21
if(n == 0){
b = a;
}
var t;
//计算菲波数的算法
for(var i = 2; i <= n + 1; i++)
{
t = b;
b = a + b;
a = t;
}
// Fib(6) 经过循环后a=13 b=21 n=6(没变);
// 闭包返回主函数后n=2
alert("1、n="+n);
var ret = function(n, x, y){
//构造一个闭包,这个闭包本身包含一个以新起点计算Fib值的函数
//Fib(6)(2) 运行后n=2就是(2)第二个参数
alert("2、n="+n);
x = x || a; //x=13 n=2
y = y || b; //y=21
var fv=Fib(n, x, y);
return fv;
}
//重写valueOf和toString,这样在表达式中可以直接对返回的菲波函数自动求值
//在第五部分我们还会详细讨论到这种用法
ret.valueOf = ret.toString = function()
{
return a;
}
return ret;
}
var f6 = Fib(6); //奥妙在这里,f6是一个新起点的菲波数列函数
dwn(f6);
dwn(f6(2));
dwn(Fib(6)(2));
-->
</script>
</body>
</html>
这段代码是王者归来上面的代码,我不断反复测试,慢慢的理解了,加了很多注释,有以下三点体会:
1、闭包的执行是母体函数的调用的实例然后再调用,即Fib(6)(2)这两个括号的意思是,第一个括号是执行Fib这个母体函数,而第二个括号是执行子函数就是闭包,就是调用了两次函数。
2、为什么会调用这个闭包?因为母体函数的最后有一个返回“ return ret ” 这个返回的ret就是闭包的名称。所以调用闭包无需写闭包的名称。
3、为什么要重写toString和volveOF方法?因为ret是一个对象,document.write(s + "<br/>");这个方法输出对象会默认调用这两个方法,所以为了输出符合要求的数据,必须从重写这两个方法。
函数本身也是一种数据。
一段奇特的代码:
<html>
<head>
<title>Example-6.1(2)奇特的函数</title>
</head>
<body>
<script>
<!--
function dwn(s)
{
document.write(s + "<br/>");
}
//"无穷"的菲波纳契数据结构
function Fib(n, x, y)
{
//这里借参数x,y来保留前面的计算结果,即菲波数当前数列到n的最后两个数值
//在实际调用中通常并不用到x、y这两个参数
var a = x || 1; //13
var b = y || 1; //21
if(n == 0){
b = a;
}
var t;
//计算菲波数的算法
for(var i = 2; i <= n + 1; i++)
{
t = b;
b = a + b;
a = t;
}
// Fib(6) 经过循环后a=13 b=21 n=6(没变);
// 闭包返回主函数后n=2
alert("1、n="+n);
var ret = function(n, x, y){
//构造一个闭包,这个闭包本身包含一个以新起点计算Fib值的函数
//Fib(6)(2) 运行后n=2就是(2)第二个参数
alert("2、n="+n);
x = x || a; //x=13 n=2
y = y || b; //y=21
var fv=Fib(n, x, y);
return fv;
}
//重写valueOf和toString,这样在表达式中可以直接对返回的菲波函数自动求值
//在第五部分我们还会详细讨论到这种用法
ret.valueOf = ret.toString = function()
{
return a;
}
return ret;
}
var f6 = Fib(6); //奥妙在这里,f6是一个新起点的菲波数列函数
dwn(f6);
dwn(f6(2));
dwn(Fib(6)(2));
-->
</script>
</body>
</html>
这段代码是王者归来上面的代码,我不断反复测试,慢慢的理解了,加了很多注释,有以下三点体会:
1、闭包的执行是母体函数的调用的实例然后再调用,即Fib(6)(2)这两个括号的意思是,第一个括号是执行Fib这个母体函数,而第二个括号是执行子函数就是闭包,就是调用了两次函数。
2、为什么会调用这个闭包?因为母体函数的最后有一个返回“ return ret ” 这个返回的ret就是闭包的名称。所以调用闭包无需写闭包的名称。
3、为什么要重写toString和volveOF方法?因为ret是一个对象,document.write(s + "<br/>");这个方法输出对象会默认调用这两个方法,所以为了输出符合要求的数据,必须从重写这两个方法。
相关文章推荐
- 一段代码既说明printf的入栈顺序是从右想做的,又说明inet_ntoa返回值是放在一个静态区域的,连续执行会覆盖
- Canvas运用样式与颜色fillStyle【每日一段代码15】
- C语言宏定义的学习------一个宏代表一段代码
- 编写一段程序,从标准输入读取string对象的序列直到连续出现两个相同的单词或者所有单词都读完为止。使用while循环一次读取一个单词,当一个单词连续出现两次是使用break语句终止循环。输出连续重复出现的单词,或者输出一个消息说明没有人任何单词是重复出现的。
- 如何用一段简单的代码讲述一个悲伤的故事?
- [有人帮我说明了原因,明天找人测试一下]紧急求助!!(请您帮看看我的一个在线考试系统的部分代码是否有问题啊?)
- 一段代码展现一个流程,流程在代码中内聚
- 《一个Android工程的从零开始》-3、base(二) BaseActivity布局相关代码——空布局控件的运用
- javascript 写一段代码,判断一个字符串中出现次数最多的字符串,并统计出现的次数
- OC中用字典创建一个具有省市区的应用(简单的字典运用代码)
- 写一段PHP代码,确保多个进程同时写入同一个文件成功(腾讯)
- 一段代码说明javascript闭包执行机制
- 通过一段代码说明C#中rel与out的使用区别
- Android 一个代码教你学会运用服务相关知识
- 一段带有边框说明的代码
- 贴一段代码吧,纯PHP的,只是一个项目中的一部分
- 一段代码清晰说明js中的this
- 一段旧代码,引起的关于OO中一个问题的思考
- 在vs2008的一段代码中将256*256*256*256赋值个一个long型变量,居然编译不通过