Javascript 瀏覽器環(huán)境,規(guī)格

2023-02-17 10:53 更新

JavaScript 語言最初是為 Web 瀏覽器創(chuàng)建的。此后,它已經(jīng)演變成了一種具有多種用途和平臺的語言。

平臺可以是一個瀏覽器,一個 Web 服務(wù)器,或其他 主機(host),甚至可以是一個“智能”咖啡機,如果它能運行 JavaScript 的話。它們每個都提供了特定于平臺的功能。JavaScript 規(guī)范將其稱為 主機環(huán)境

主機環(huán)境提供了自己的對象和語言核心以外的函數(shù)。Web 瀏覽器提供了一種控制網(wǎng)頁的方法。Node.JS 提供了服務(wù)器端功能,等等。

下面是 JavaScript 在瀏覽器中運行時的鳥瞰示意圖:


有一個叫做 window 的“根”對象。它有兩個角色:

  1. 首先,它是 JavaScript 代碼的全局對象,如 全局對象 一章所述。
  2. 其次,它代表“瀏覽器窗口”,并提供了控制它的方法。

例如,我們可以將它用作全局對象:

function sayHi() {
  alert("Hello");
}

// 全局函數(shù)是全局對象的方法:
window.sayHi();

并且我們可以將它用作瀏覽器窗口,以查看窗口高度:

alert(window.innerHeight); // 內(nèi)部窗口高度

還有更多窗口特定的方法和屬性,我們稍后會介紹。

文檔對象模型(DOM)

文檔對象模型(Document Object Model),簡稱 DOM,將所有頁面內(nèi)容表示為可以修改的對象。

document 對象是頁面的主要“入口點”。我們可以使用它來更改或創(chuàng)建頁面上的任何內(nèi)容。

例如:

// 將背景顏色修改為紅色
document.body.style.background = "red";

// 在 1 秒后將其修改回來
setTimeout(() => document.body.style.background = "", 1000);

在這里,我們使用了 document.body.style,但還有很多很多其他的東西。規(guī)范中有屬性和方法的詳細描述:DOM Living Standard。

DOM 不僅僅用于瀏覽器

DOM 規(guī)范解釋了文檔的結(jié)構(gòu),并提供了操作文檔的對象。有的非瀏覽器設(shè)備也使用 DOM。

例如,下載 HTML 文件并對其進行處理的服務(wù)器端腳本也可以使用 DOM。但它們可能僅支持部分規(guī)范中的內(nèi)容。

用于樣式的 CSSOM

另外也有一份針對 CSS 規(guī)則和樣式表的、單獨的規(guī)范 CSS Object Model (CSSOM),這份規(guī)范解釋了如何將 CSS 表示為對象,以及如何讀寫這些對象。

當我們修改文檔的樣式規(guī)則時,CSSOM 與 DOM 是一起使用的。但實際上,很少需要 CSSOM,因為我們很少需要從 JavaScript 中修改 CSS 規(guī)則(我們通常只是添加/移除一些 CSS 類,而不是直接修改其中的 CSS 規(guī)則),但這也是可行的。

瀏覽器對象模型(BOM)

瀏覽器對象模型(Browser Object Model),簡稱 BOM,表示由瀏覽器(主機環(huán)境)提供的用于處理文檔(document)之外的所有內(nèi)容的其他對象。

例如:

  • navigator 對象提供了有關(guān)瀏覽器和操作系統(tǒng)的背景信息。navigator 有許多屬性,但是最廣為人知的兩個屬性是:?navigator.userAgent? —— 關(guān)于當前瀏覽器,?navigator.platform? —— 關(guān)于平臺(有助于區(qū)分 Windows/Linux/Mac 等)。
  • location 對象允許我們讀取當前 URL,并且可以將瀏覽器重定向到新的 URL。

這是我們可以如何使用 location 對象的方法:

alert(location.href); // 顯示當前 URL
if (confirm("Go to Wikipedia?")) {
  location.; // 將瀏覽器重定向到另一個 URL
}

函數(shù) alert/confirm/prompt 也是 BOM 的一部分:它們與文檔(document)沒有直接關(guān)系,但它代表了與用戶通信的純?yōu)g覽器方法。

規(guī)范

BOM 是通用 HTML 規(guī)范 的一部分。

是的,你沒聽錯。在 https://html.spec.whatwg.org 中的 HTML 規(guī)范不僅是關(guān)于“HTML 語言”(標簽,特性)的,還涵蓋了一堆對象、方法和瀏覽器特定的 DOM 擴展。這就是“廣義的 HTML”。此外,某些部分也有其他的規(guī)范,它們被列在 https://spec.whatwg.org 中。

總結(jié)

說到標準,我們有:

DOM 規(guī)范

描述文檔的結(jié)構(gòu)、操作和事件,詳見 https://dom.spec.whatwg.org

CSSOM 規(guī)范

描述樣式表和樣式規(guī)則,對它們進行的操作,以及它們與文檔的綁定,詳見 https://www.w3.org/TR/cssom-1/。

HTML 規(guī)范

描述 HTML 語言(例如標簽)以及 BOM(瀏覽器對象模型)— 各種瀏覽器函數(shù):?setTimeout?,?alert?,?location? 等,詳見 https://html.spec.whatwg.org。它采用了 DOM 規(guī)范,并使用了許多其他屬性和方法對其進行了擴展。

此外,某些類被分別描述在 https://spec.whatwg.org/

請注意這些鏈接,因為要學的東西太多了,所以不可能涵蓋并記住所有內(nèi)容。

當你想要了解某個屬性或方法時,Mozilla 手冊 https://developer.mozilla.org/en-US/ 是一個很好的資源,但對應(yīng)的規(guī)范可能會更好:它更復(fù)雜,且閱讀起來需要更長的時間,但是會使你的基本知識更加全面,更加完整。

要查找某些內(nèi)容時,你通常可以使用互聯(lián)網(wǎng)搜索 “WHATWG [term]” 或 “MDN [term]”,例如 https://google.com?q=whatwg+localstorage,https://google.com?q=mdn+localstorage

現(xiàn)在,我們開始學習 DOM,因為文檔在 UI 中扮演著核心角色。


以上內(nèi)容是否對您有幫助:
在線筆記
App下載
App下載

掃描二維碼

下載編程獅App

公眾號
微信公眾號

編程獅公眾號