JavaScript 筆記七:DOM、BOM渣蜗、AST抽象語法樹

都是本人理解屠尊,筆記大致概念,不詳細也并非完全正確耕拷,所以僅供參考讼昆。


DOM與BOM

JavaScript 規(guī)范來說分為是三部分

  • ECMAScript:JS執(zhí)行標準
  • DOM:文檔對象模型
  • BOM:窗口對象模型

當瀏覽器加載文檔時,會以HTML節(jié)點生成DOM樹斑胜,而JS的DOM對象即DOM樹的調(diào)用API控淡,通過DOM對象可以對文檔節(jié)點進行增刪改等的作,所以 DOM 是為了操作文檔出現(xiàn)的接口止潘。

而 BOM 其實就是為了控制瀏覽器的行為而出現(xiàn)的接口掺炭,可以進行窗口的開啟、關(guān)閉凭戴,location 的前進后退涧狮,alert 彈窗等瀏覽器行為。

所以么夫,綜上所述:
DOM 是為了操作文檔出現(xiàn)的 API者冤,document 是其的一個對象。
BOM 是為了操作瀏覽器出現(xiàn)的 API档痪,window 是其的一個對象涉枫。


AST抽象語法樹

貼百度百科解釋:抽象語法樹(abstract syntax tree或者縮寫為AST),或者語法樹(syntax tree)腐螟,是源代碼的抽象語法結(jié)構(gòu)的樹狀表現(xiàn)形式愿汰,這里特指編程語言的源代碼。和抽象語法樹相對的是具體語法樹(concrete syntaxtree)乐纸,通常稱作分析樹(parse tree)衬廷。一般的,在源代碼的翻譯和編譯過程中汽绢,語法分析器創(chuàng)建出分析樹吗跋。一旦AST被創(chuàng)建出來,在后續(xù)的處理過程中,比如語義分析階段跌宛,會添加一些信息酗宋。

大致解釋下,就是說源碼是可以解析成一種語法樹秩冈,類似于DOM樹的結(jié)構(gòu)本缠,舉個例子隨便寫下:

function abc(a){
  var b = 2;
  var c = a + b;
  return c;
}

如果通過抽象語法樹的解析轉(zhuǎn)換,那么就類似如下的結(jié)構(gòu)(我是瞎寫的入问,只是便于理解丹锹,實際中的對象結(jié)構(gòu)和這里不一樣):

{
  type: 'function',
  name: 'abc',
  params: ['a'],
  body: {
    // 內(nèi)容
    content: `
      var b = 2;
      var c = a + b;
      return c;
    `,
    // 每一行
    line: [
      {
        content: 'var b = 2;',
        // 其他屬性 ...
      },
      {
        content: 'var c = a + b;',
        // 其他屬性 ...
      },
      // 其他行
    ]
  }
}

解析之后為類似結(jié)構(gòu),這就是AST抽象語法樹芬失。

都知道 DOM 對象可以修改 DOM 樹楣黍,修改節(jié)點的內(nèi)容與樣式等,所以AST抽象語法書也可以對源碼進行修改棱烂、拼接租漂,所以AST抽象語法書也可以說是操作源碼的API。

這里僅簡單說描述說明颊糜,詳細參考此文哩治。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末,一起剝皮案震驚了整個濱河市衬鱼,隨后出現(xiàn)的幾起案子业筏,更是在濱河造成了極大的恐慌,老刑警劉巖鸟赫,帶你破解...
    沈念sama閱讀 211,123評論 6 490
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件蒜胖,死亡現(xiàn)場離奇詭異,居然都是意外死亡抛蚤,警方通過查閱死者的電腦和手機嫉父,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 90,031評論 2 384
  • 文/潘曉璐 我一進店門单料,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人景馁,你說我怎么就攤上這事肯适⊙掳蹋” “怎么了湿刽?”我有些...
    開封第一講書人閱讀 156,723評論 0 345
  • 文/不壞的土叔 我叫張陵兽泣,是天一觀的道長。 經(jīng)常有香客問我诉位,道長,這世上最難降的妖魔是什么菜枷? 我笑而不...
    開封第一講書人閱讀 56,357評論 1 283
  • 正文 為了忘掉前任苍糠,我火速辦了婚禮,結(jié)果婚禮上啤誊,老公的妹妹穿的比我還像新娘岳瞭。我一直安慰自己拥娄,他們只是感情好,可當我...
    茶點故事閱讀 65,412評論 5 384
  • 文/花漫 我一把揭開白布瞳筏。 她就那樣靜靜地躺著稚瘾,像睡著了一般。 火紅的嫁衣襯著肌膚如雪姚炕。 梳的紋絲不亂的頭發(fā)上摊欠,一...
    開封第一講書人閱讀 49,760評論 1 289
  • 那天,我揣著相機與錄音柱宦,去河邊找鬼些椒。 笑死,一個胖子當著我的面吹牛掸刊,可吹牛的內(nèi)容都是我干的免糕。 我是一名探鬼主播,決...
    沈念sama閱讀 38,904評論 3 405
  • 文/蒼蘭香墨 我猛地睜開眼忧侧,長吁一口氣:“原來是場噩夢啊……” “哼石窑!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起蚓炬,我...
    開封第一講書人閱讀 37,672評論 0 266
  • 序言:老撾萬榮一對情侶失蹤松逊,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后试吁,有當?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體棺棵,經(jīng)...
    沈念sama閱讀 44,118評論 1 303
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 36,456評論 2 325
  • 正文 我和宋清朗相戀三年熄捍,在試婚紗的時候發(fā)現(xiàn)自己被綠了烛恤。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 38,599評論 1 340
  • 序言:一個原本活蹦亂跳的男人離奇死亡余耽,死狀恐怖缚柏,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情碟贾,我是刑警寧澤币喧,帶...
    沈念sama閱讀 34,264評論 4 328
  • 正文 年R本政府宣布,位于F島的核電站袱耽,受9級特大地震影響杀餐,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜朱巨,卻給世界環(huán)境...
    茶點故事閱讀 39,857評論 3 312
  • 文/蒙蒙 一史翘、第九天 我趴在偏房一處隱蔽的房頂上張望。 院中可真熱鬧,春花似錦琼讽、人聲如沸必峰。這莊子的主人今日做“春日...
    開封第一講書人閱讀 30,731評論 0 21
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽吼蚁。三九已至,卻和暖如春问欠,著一層夾襖步出監(jiān)牢的瞬間肝匆,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 31,956評論 1 264
  • 我被黑心中介騙來泰國打工溅潜, 沒想到剛下飛機就差點兒被人妖公主榨干…… 1. 我叫王不留术唬,地道東北人。 一個月前我還...
    沈念sama閱讀 46,286評論 2 360
  • 正文 我出身青樓滚澜,卻偏偏與公主長得像粗仓,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子设捐,可洞房花燭夜當晚...
    茶點故事閱讀 43,465評論 2 348