JavaScript的變量强重,作用域

變量類型

JavaScript的變量分為兩種:基本類型和引用類型。
基本類型有五種:Undefined贸人、Null间景、Boolean、Number艺智、String倘要。除開基礎(chǔ)類型的就是引用類型,如數(shù)組,函數(shù)封拧,日期志鹃,正則表達(dá)式
基礎(chǔ)類型的變量每當(dāng)聲明一個(gè)時(shí),都會開辟一個(gè)內(nèi)存空間存貯值泽西。就算是賦值也會建立一個(gè)獨(dú)立的空間曹铃,兩個(gè)之間完全不會影響。
但是引用類型內(nèi)存里面存儲的是一個(gè)地址捧杉,就是說當(dāng)賦值一個(gè)引用類型變量的時(shí)候陕见,改變一個(gè)變量,另外一個(gè)變量也將會收到影響
基本類型實(shí)例

var num1 = 5;
var num2 = num1;
num1=6
alert(num2) // 5

var arry1 = [1,2,3]
var arry2 = arry1;
arry1.push(4);
alert(arry2); // [1,2,3.4]

引用類型在函數(shù)傳參的時(shí)候的變換

            var arry1 = [1,2,3];
            var arry1 = [1,2,3];
            function push1(arry){
                arry.push(4);
                return arry;
            }
            var arry2 = push1(arry1);
            alert(arry1) // [1,2,3,4]

這種單純的復(fù)制只能做到淺拷貝味抖,有關(guān)js 變量的深拷貝將用另外一篇文章就是描述评甜。

如何獲取變量的類型

var s = "Nicholas";
var b = true;
var i = 22;
var u;
var n = null;
var t = [1,2,3];
var y= function(){
    return "qwe";
}
var o = new Object();
alert(typeof s); //string
alert(typeof i); //number
alert(typeof b); //boolean
alert(typeof u); //undefined
alert(typeof n); //object
alert(typeof o); //object
alert(typeof t); //object
alert(typeof y); //function

當(dāng)要確定引用類型變量的類型時(shí)候使用instanceof

alert(person instanceof Object); // 變量 person 是 Object 嗎?
alert(colors instanceof Array); // 變量 colors 是 Array 嗎仔涩?
alert(pattern instanceof RegExp); // 變量 pattern 是 RegExp 嗎忍坷?

作用域

每個(gè)執(zhí)行環(huán)境都有一個(gè)與之關(guān)聯(lián)的變量對象(variable object) ,每一個(gè)頁面都有一個(gè)全局執(zhí)行環(huán)境就是windon红柱。全局執(zhí)行環(huán)境直到應(yīng)用程序退出——例如關(guān)閉網(wǎng)頁或?yàn)g覽器——時(shí)才會被銷毀承匣。在js 中一個(gè)函數(shù)就是一個(gè)執(zhí)行環(huán)境,對應(yīng)一個(gè)變量對象锤悄。
代碼在一個(gè)環(huán)境中執(zhí)行的時(shí)候會創(chuàng)建一個(gè)變量對象的作用域鏈韧骗。從外到內(nèi),從大到小零聚。搜索變量的時(shí)候也會通過這個(gè)作用域鏈去尋找變量袍暴。

延長作用域鏈

通過with 和try-catch中的catch 塊

function buildUrl() {
var qs = "?debug=true";
with(location){
var url = href + qs;
}
return url;
}

在上面代碼中執(zhí)行buildUrl()。會返回url 變量隶症,就是因?yàn)閎uildUrl這個(gè)執(zhí)行環(huán)境中將location和with 塊里面的變量對象添加到buildUrl這個(gè)執(zhí)行環(huán)境中的變量對象政模。所以才可以成功返回url 這個(gè)對象。

js 沒有塊級作用域

for (var i=0; i < 10; i++){
doSomething(i);
}
alert(i);//10

這個(gè)i是存在于全局環(huán)境中的蚂会。

垃圾回收機(jī)制

局部變量只在函數(shù)執(zhí)行的過程中存在淋样。而在這個(gè)過程中,會為局部變量在棧(或堆)內(nèi)存上分配相應(yīng)的空間胁住,以便存儲它們的值趁猴。然后在函數(shù)中使用這些變量,直至函數(shù)執(zhí)行結(jié)束彪见。結(jié)束后儡司,這些變量就將被銷毀。

?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末余指,一起剝皮案震驚了整個(gè)濱河市捕犬,隨后出現(xiàn)的幾起案子,更是在濱河造成了極大的恐慌,老刑警劉巖碉碉,帶你破解...
    沈念sama閱讀 219,110評論 6 508
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件柴钻,死亡現(xiàn)場離奇詭異,居然都是意外死亡垢粮,警方通過查閱死者的電腦和手機(jī)顿颅,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 93,443評論 3 395
  • 文/潘曉璐 我一進(jìn)店門,熙熙樓的掌柜王于貴愁眉苦臉地迎上來足丢,“玉大人,你說我怎么就攤上這事庇配≌兜” “怎么了?”我有些...
    開封第一講書人閱讀 165,474評論 0 356
  • 文/不壞的土叔 我叫張陵捞慌,是天一觀的道長耀鸦。 經(jīng)常有香客問我,道長啸澡,這世上最難降的妖魔是什么袖订? 我笑而不...
    開封第一講書人閱讀 58,881評論 1 295
  • 正文 為了忘掉前任,我火速辦了婚禮嗅虏,結(jié)果婚禮上洛姑,老公的妹妹穿的比我還像新娘。我一直安慰自己皮服,他們只是感情好楞艾,可當(dāng)我...
    茶點(diǎn)故事閱讀 67,902評論 6 392
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著龄广,像睡著了一般硫眯。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上择同,一...
    開封第一講書人閱讀 51,698評論 1 305
  • 那天两入,我揣著相機(jī)與錄音,去河邊找鬼敲才。 笑死裹纳,一個(gè)胖子當(dāng)著我的面吹牛,可吹牛的內(nèi)容都是我干的归斤。 我是一名探鬼主播痊夭,決...
    沈念sama閱讀 40,418評論 3 419
  • 文/蒼蘭香墨 我猛地睜開眼,長吁一口氣:“原來是場噩夢啊……” “哼脏里!你這毒婦竟也來了她我?” 一聲冷哼從身側(cè)響起,我...
    開封第一講書人閱讀 39,332評論 0 276
  • 序言:老撾萬榮一對情侶失蹤,失蹤者是張志新(化名)和其女友劉穎番舆,沒想到半個(gè)月后酝碳,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體,經(jīng)...
    沈念sama閱讀 45,796評論 1 316
  • 正文 獨(dú)居荒郊野嶺守林人離奇死亡恨狈,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點(diǎn)故事閱讀 37,968評論 3 337
  • 正文 我和宋清朗相戀三年疏哗,在試婚紗的時(shí)候發(fā)現(xiàn)自己被綠了。 大學(xué)時(shí)的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片禾怠。...
    茶點(diǎn)故事閱讀 40,110評論 1 351
  • 序言:一個(gè)原本活蹦亂跳的男人離奇死亡返奉,死狀恐怖,靈堂內(nèi)的尸體忽然破棺而出吗氏,到底是詐尸還是另有隱情芽偏,我是刑警寧澤,帶...
    沈念sama閱讀 35,792評論 5 346
  • 正文 年R本政府宣布弦讽,位于F島的核電站污尉,受9級特大地震影響,放射性物質(zhì)發(fā)生泄漏往产。R本人自食惡果不足惜被碗,卻給世界環(huán)境...
    茶點(diǎn)故事閱讀 41,455評論 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一處隱蔽的房頂上張望仿村。 院中可真熱鬧锐朴,春花似錦、人聲如沸奠宜。這莊子的主人今日做“春日...
    開封第一講書人閱讀 32,003評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽压真。三九已至娩嚼,卻和暖如春,著一層夾襖步出監(jiān)牢的瞬間滴肿,已是汗流浹背岳悟。 一陣腳步聲響...
    開封第一講書人閱讀 33,130評論 1 272
  • 我被黑心中介騙來泰國打工, 沒想到剛下飛機(jī)就差點(diǎn)兒被人妖公主榨干…… 1. 我叫王不留泼差,地道東北人贵少。 一個(gè)月前我還...
    沈念sama閱讀 48,348評論 3 373
  • 正文 我出身青樓,卻偏偏與公主長得像堆缘,于是被迫代替她去往敵國和親滔灶。 傳聞我的和親對象是個(gè)殘疾皇子,可洞房花燭夜當(dāng)晚...
    茶點(diǎn)故事閱讀 45,047評論 2 355

推薦閱讀更多精彩內(nèi)容