四虎精品视频-四虎精品成人免费网站-四虎黄色网-四虎国产视频-国产免费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,轉載需保留來源!

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

主站蜘蛛池模板: 2024年中央遴选笔试真题| 美国伦理片禁忌| 禁忌的爱在线| 邓稼先教学设计一等奖优秀教案| 男生女生向前冲2014| 电影《上一当》| 将夜电视剧免费观看完整版高清| 赌侠演员表大全| 电影壮志凌云女版满天星法版在线看 | 山东教育电视台直播| 我是特种兵剧情介绍| 社会好全部歌词| 李泽锋个人资料| 色女孩视频| 包青天之真假包公| 祝妈妈生日快乐英文| 德国老太性视频播放| 霹雳俏娇娃| 太原教育电视台| cope消除| 街头霸王 1994 尚格·云顿| 新人类电影| 汪汪队100集全免费| 褚阳| 卡通图片头像| 刘浩存个人简介资料| 美丽的坏女人中文字幕| 溜溜的她| 久草在现| 含羞草传媒2024| 麻豆视频网站| 电影潘金莲| 乱世佳人电视剧免费观看完整版| 姐妹电影| 拼音表大全图| 左佳| 狐狸电影| 素人片| 算死草粤语| 山本裕典| 西游记tvb|