javascript学习笔记
本部分主要是Function类与闭包的重难点。
Function
- 生成表示
var obj= function();
var sum = Function ('a','b','return (a+b);');
- 原理解析
function f() {}
f.foo = 'FOO';
f.doit = function() {
print('doit called');}
}
各个部分的关系如图所示
闭包
它的最大用处有两个,一个是前面提到的可以读取函数内部的变量,另一个就是让这些变量的值始终保持在内存中。
表现格式
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
嵌套函数原理
- 闭包的前提条件是在函数声明的内部声明另一个函数,(即嵌套的函数声明)。
- js中,调用函数时会隐式地生成Call对象,函数完成后会销毁Call对象。
- 作用域链:对于嵌套声明的函数,内部的函数将会首先查找被调用时所生成的Call对象属性,然后查找外层函数的Call对象的属性。
function f() {
var n=123;
function g() {
print(n);
}
return g;
}
fn();
var fn =f();
//123
//[Function: g]
各个部分之间的关系如图所示:
通过闭包实现信息隐藏
- 格式
//( {function() {函数体}} )();
var sum = (function f() {
var n=123;
function g() {
print(n);
}
return g;
})();
sum();
//123
<wiz_tmp_tag id="wiz-table-range-border" contenteditable="false" style="display: none;">
分享各种计算机技术、原理。
邮箱:ouyangcan2016@gmail.com