首页 > 编程语言 > 详细

javascript学习笔记

时间:2018-05-04 11:17:23      阅读:175      评论:0      收藏:0      [点我收藏+]

本部分主要是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

嵌套函数原理

  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]

各个部分之间的关系如图所示:
技术分享图片

通过闭包实现信息隐藏

  1. 格式
//( {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;">





javascript学习笔记

原文:https://www.cnblogs.com/auyeungcarl/p/1efddb724761cbd2340bb98b6a121cf6.html

(0)
(0)
   
举报
评论 一句话评论(0
关于我们 - 联系我们 - 留言反馈 - 联系我们:wmxa8@hotmail.com
© 2014 bubuko.com 版权所有
打开技术之扣,分享程序人生!