W3Cschool
恭喜您成為首批注冊用戶
獲得88經(jīng)驗值獎勵
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
的“根”對象。它有兩個角色:
例如,我們可以將它用作全局對象:
function sayHi() {
alert("Hello");
}
// 全局函數(shù)是全局對象的方法:
window.sayHi();
并且我們可以將它用作瀏覽器窗口,以查看窗口高度:
alert(window.innerHeight); // 內(nèi)部窗口高度
還有更多窗口特定的方法和屬性,我們稍后會介紹。
文檔對象模型(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ī)則),但這也是可行的。
瀏覽器對象模型(Browser Object Model),簡稱 BOM,表示由瀏覽器(主機環(huán)境)提供的用于處理文檔(document)之外的所有內(nèi)容的其他對象。
例如:
navigator.userAgent
? —— 關(guān)于當前瀏覽器,?navigator.platform
? —— 關(guān)于平臺(有助于區(qū)分 Windows/Linux/Mac 等)。這是我們可以如何使用 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 中。
說到標準,我們有:
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 中扮演著核心角色。
Copyright©2021 w3cschool編程獅|閩ICP備15016281號-3|閩公網(wǎng)安備35020302033924號
違法和不良信息舉報電話:173-0602-2364|舉報郵箱:jubao@eeedong.com
掃描二維碼
下載編程獅App
編程獅公眾號
聯(lián)系方式:
更多建議: