摘要:了解面向?qū)ο缶幊讨?,首先要了解的?zhí)行順序。的解析過程分為兩個(gè)階段預(yù)處理階段與執(zhí)行期。在執(zhí)行階段的執(zhí)行上下文對象由賦值為指向?qū)?yīng)函數(shù)
了解js面向?qū)ο缶幊讨?,首先要了解js的執(zhí)行順序。js的解析過程分為兩個(gè)階段:預(yù)處理階段與執(zhí)行期。
預(yù)處理階段在預(yù)處理階段,js會首先創(chuàng)建一個(gè)執(zhí)行上下文對象(Execute Context,然后掃描聲明式函數(shù)和用var定義的變量,將其加入執(zhí)行上下文環(huán)境中,看下面栗子:
var a = 5; b = 1; function f(){} var g = function(){} //執(zhí)行上下文對象 /*Execute Context{ a: undefined f: 對函數(shù)的引用 }*/
從上面可以看出,js在預(yù)處理階段創(chuàng)建了一個(gè)預(yù)處理對象,將聲明式函數(shù)和var定義的變量放入其中,這里忽略了沒有用var聲明的b以及函數(shù)表達(dá)式 g。
alert(a); // undefined alert(b); // 報(bào)錯(cuò) b in not defined alert(c); // 函數(shù)體被打印出來 alert(d); // 報(bào)錯(cuò) var a = 1; b = 5; function c(){ console.log("c"); } var d = function(){ console.log("d"); }
從上面例子的輸出結(jié)果就可以看出js預(yù)處理階段做了哪些事情,對于沒有加進(jìn)函數(shù)變量預(yù)處理階段的變量或函數(shù),會直接報(bào)錯(cuò)。
對于沖突解決有兩種情況:
處理函數(shù)聲明有沖突時(shí),會覆蓋前面
處理函數(shù)變量聲明有沖突時(shí),會直接忽略
alert(f); // 彈出function f(){console.log("fff");} function f(){ console.log("ff"); } var f = 10; function f(){ console.log("fff"); }
總結(jié)一句話:函數(shù)是js里的第一等公民。
執(zhí)行階段在執(zhí)行階段中,js會先掃描函數(shù)聲明后掃描變量,然后給預(yù)處理階段中執(zhí)行上下文對象中的成員賦值,如果沒有用var聲明的變量,會成為外部執(zhí)行上下文的成員。
alert(a); alert(f); var a = 1; function f(){} //在執(zhí)行階段的執(zhí)行上下文對象 /*{ a: 1; // 由undefined賦值為1 f: 指向?qū)?yīng)函數(shù) }*/
文章版權(quán)歸作者所有,未經(jīng)允許請勿轉(zhuǎn)載,若此文章存在違規(guī)行為,您可以聯(lián)系管理員刪除。
轉(zhuǎn)載請注明本文地址:http://systransis.cn/yun/86452.html
摘要:的變量作用域是基于其特有的作用域鏈的。需要注意的是,用創(chuàng)建的函數(shù),其作用域指向全局作用域。所以,有另一種說法認(rèn)為閉包是由函數(shù)和與其相關(guān)的引用環(huán)境組合而成的實(shí)體。 作用域 定義 在編程語言中,作用域控制著變量與參數(shù)的可見性及生命周期,它能減少名稱沖突,而且提供了自動內(nèi)存管理 --javascript 語言精粹 我理解的是,一個(gè)變量、函數(shù)或者成員可以在代碼中訪問到的范圍。 js的變量作...
摘要:在構(gòu)造函數(shù)中的中定義的屬性和方法,會被創(chuàng)建的對象所繼承下來。從上面的輸出結(jié)果看出,指向了其構(gòu)造函數(shù)的,而本身也是一個(gè)對象,其內(nèi)部也有屬性,其指向的是直到最后指向,這條原型鏈才結(jié)束。和都指向,說明原型鏈到終止。 prototype原型對象 每個(gè)函數(shù)都有一個(gè)默認(rèn)的prototype屬性,其實(shí)際上還是一個(gè)對象,如果被用在繼承中,姑且叫做原型對象。 在構(gòu)造函數(shù)中的prototype中定義的屬性...
摘要:類的繼承建立繼承關(guān)系修改的指向調(diào)用父類方法調(diào)用父類的構(gòu)造器調(diào)用父類上的方法封裝命名空間是沒有命名空間的,因此可以用對象模擬。參考資料面向?qū)ο? 面向?qū)ο蟪绦蛟O(shè)計(jì)(Object-oriented programming,OOP)是一種程序設(shè)計(jì)范型,同時(shí)也是一種程序開發(fā)的方法。對象指的是類的實(shí)例。它將對象作為程序的基本單元,將程序和數(shù)據(jù)封裝其中,以提高軟件的重用性、靈活性和擴(kuò)展性?!S基百...
摘要:對構(gòu)造函數(shù)使用運(yùn)算符,就能生成實(shí)例,并且變量會綁定在實(shí)例對象上。這個(gè)對象的所有屬性和方法,都會被構(gòu)造函數(shù)的實(shí)例繼承。 對象 對象的含義 所謂對象,就是一種無序的數(shù)據(jù)集合,由若干個(gè)鍵值對(key-value)構(gòu)成。 對象的創(chuàng)建 使用new運(yùn)算符創(chuàng)建Object var p = new Object(); p.name = Tony; 使用對象字面量的形式 //對象字面量形...
摘要:構(gòu)造函數(shù)通常首字母大寫,用于區(qū)分普通函數(shù)。這種關(guān)系常被稱為原型鏈,它解釋了為何一個(gè)對象會擁有定義在其他對象中的屬性和方法。中所有的對象,都有一個(gè)屬性,指向?qū)嵗龑ο蟮臉?gòu)造函數(shù)原型由于是個(gè)非標(biāo)準(zhǔn)屬性,因此只有和兩個(gè)瀏覽器支持,標(biāo)準(zhǔn)方法是。 從這篇文章開始,復(fù)習(xí) MDN 中級教程 的內(nèi)容了,在初級教程中,我和大家分享了一些比較簡單基礎(chǔ)的知識點(diǎn),并放在我的 【Cute-JavaScript】系...
閱讀 4012·2021-11-18 13:22
閱讀 1830·2021-11-17 09:33
閱讀 2886·2021-09-26 09:46
閱讀 1220·2021-08-21 14:11
閱讀 2896·2019-08-30 15:53
閱讀 2717·2019-08-30 15:52
閱讀 1914·2019-08-30 10:52
閱讀 1528·2019-08-29 15:30