上一集中,重點介紹了誰動了你的代碼。這里先總結(jié)一下:咱們的代碼從敲下來到運行出結(jié)果,經(jīng)歷了兩個階段:分析期與運行期。在分析期,JavaScript分析器悄悄動了我們的代碼;在運行期,JavaScript又按照自己的一套機制進行變量尋找。我們的代碼是如何被動了手腳的,相信看官你已經(jīng)明白。但是前面所聊均是面向過程的,如果說只是簡單的面向過程言語,那JavaScript能夠有基本的數(shù)據(jù)類型,基本的執(zhí)行單元那也差不多了。但是故事并沒有在此結(jié)束。接下來劇情的發(fā)展,那才是造成今天鞋同們困惑的地方,那們還是從故事開始。大伙不要嫌樓主啰嗦(樓主確實是個啰嗦之人),講這故事是為了讓大伙了解當年布大師設計JavaScript的背景,融入布大師的設計思維,你就知道JavaScript為什么會有哪些奇怪的設計。好,故事開始了。

  前幾集的故事中,咱們提到了布大師只想設計一個簡單、滿足瀏覽器進行數(shù)據(jù)檢驗的腳本言語。當時的web應用毫無顏值,猶如白紙黑字,頂多再加點圖片。所以,你也別期待當時的布大師會想到如UI交互、動畫效果等等的設計需求。為此,從一開始布大師設計的JavaScript就是一個過程式的簡單的言語,但是布大師也不是個迂腐落后之人。c的升級版c++、讓編程界有點瘋狂的Java,布大師也不能視而不見,多少受點影響。于是乎,布大師想:我這JavaScript能否也玩點OOP思想呢?布大師這么一想,一堆問題就來了,本來就沒打算搞個正式的OOP腳本,也沒設計有class、extend,更沒有override啥的。但是今天拍腦袋一想要玩OOP,那總得在現(xiàn)有的設計基礎上去實現(xiàn)OOP三大思想(封裝、繼承、多態(tài))吧。那咱們就看看布大師是如何給JavaScript賦予OOP的。

封裝

  概念,樓主就不說了。但是你看看JavaScript定義的那些數(shù)據(jù)類型,壓根就沒class的概念。沒有類何來實例,沒有實例談何封裝?布大師翻來覆去研究已經(jīng)定義的數(shù)據(jù)類型,再對比了c++、java。他發(fā)現(xiàn)c++、java每次創(chuàng)建對象都離不開調(diào)用構(gòu)造函數(shù)。布大師靈感一來“對!繞過class直接調(diào)用構(gòu)造函數(shù)創(chuàng)建對象,剛好function可以作為構(gòu)造函數(shù)”。于是乎,你見到了今天JavaScript是這樣創(chuàng)建實現(xiàn)對象的:

網(wǎng)友評論

    <xmp id="hbtct">
      <span id="hbtct"></span>