javascript学习笔记(Function与闭包)

本部分主要是Function类与闭包的重难点。

Function

  • 生成表示
var obj= function();
var sum = Function ('a','b','return (a+b);');
  • 原理解析
function f() {}
f.foo = 'FOO';
f.doit = function() {
    print('doit called');}
}

各个部分的关系如图所示
tu

闭包

它的最大用处有两个,一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。

表现格式

function f() {
 var cnt =0;
return g;
 function g() {return ++cnt;}
}
//也可以是
function f() {
 var cnt =0;
 return function() {return ++cnt;}
}
fn = f();
print(fn());
print(fn());
print(fn());
// 1
// 2
// 3

嵌套函数原理

  1. 闭包的前提条件是在函数声明的内部声明另一个函数,(即嵌套的函数声明)。
  2. js中,调用函数时会隐式地生成Call对象,函数完成后会销毁Call对象。
  3. 作用域链:对于嵌套声明的函数,内部的函数将会首先查找被调用时所生成的Call对象属性,然后查找外层函数的Call对象的属性。
function f() {
    var n=123;
    function g() {
        print(n);
    }
    return g;
}
fn();
var fn =f();
//123
//[Function: g]

各个部分之间的关系如图所示:
tu

通过闭包实现信息隐藏

  1. 格式
//( {function() {函数体}} )();

var sum = (function f() {
    var n=123;
    function g() {
        print(n);
    }
    return g;
})();
sum();
//123
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值