四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费91-国产蜜臀97一区二区三区

javascript必知必會之closure

  摘要

  本系列博文主要談一些在 Javascript 使用中經常會混淆的高級應用,包括: prototype, closure, scope, this關鍵字. 對于一個需要提高自己Javascript水平的程序員,這些都是必須要掌握的.本節主要介紹closure.

  什么是closure?

  一種定義是:A "closure" is an expression (typically a function) that can have free variables together with an environment that binds those variables (that "closes" the expression).

  我的理解是: closure 是一個表達式(通常是一個函數), 這個表達式與一個 環境 共享著一些自由變量, 而這個 環境 則 綁定 著那些自由變量(或者說 結束 這個表達式, 這也是所謂closure 的名字由來). 所謂的 環境 就是一個更大的block, 所有的自由變量在這個 block 中 聲明(有意義). 而 綁定 也就是指這些自由變量的作用域就是這個環境.

  舉個簡單的例子:

var flag = false;   //調試開關
//
env 既是所謂的環境
//
而inner就是所謂的表達式, name即是所謂的自由變量
function env() //整個env可以看作是一個closure
{
var name = "zhutao";
function inner()
{
return name + " is a student.";
}
return inner; //返回的是一個內部函數
}//closure結束
flag = true;
if (flag)
{
// 此處是最神奇的地方, 代碼執行在此處, inner函數其實已經出了env的body,
//
而仍然能夠被引用, 這就是所謂形成了一個 closure
var inner_func_ref = env(); // 這時候inner_func_ref引用的就是inner()函數對象
alert(inner_func_ref()); // zhutao is a student.
}

it知識庫javascript必知必會之closure,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 《禁忌2》在线观看| 闵度允演的电影| av电影在线| 海灯法师电视剧| 死角| 打美女屁股免费| 广西柳州视频共11段| 在线播放的免费电影网站| 光遇安卓官服下载| 抖音音乐| 在屋顶上流浪| 日本xxx.| 南来北往分集剧情| 宅基地买卖合同协议书| jar of love完整版| ymxk| 曹东| 孤芳岚影| 后位子宫怎么样容易怀孕| 古铜| 古铜| 齐力电影| 太卷了正确答案| 隐形变异作风问题清单及整改措施| 棉袜vk| 王同辉| 奇门遁甲免费讲解全集| 珊特尔·范圣滕| 九九九九九九伊人| cctv17农业农村频道在线直播| 魔影| 孙子兵法三十六计完整解释电子书| 拾贝的小女孩阅读理解答案| 日韩在线操| 中国最贵的10大香烟| 芦名星| 美国伦理三颗熟樱桃| 塞下曲景然伶儿| 故乡,别来无恙演员表| 我的野蛮女老师2| 佐拉|