成人国产在线小视频_日韩寡妇人妻调教在线播放_色成人www永久在线观看_2018国产精品久久_亚洲欧美高清在线30p_亚洲少妇综合一区_黄色在线播放国产_亚洲另类技巧小说校园_国产主播xx日韩_a级毛片在线免费

資訊專欄INFORMATION COLUMN

【轉(zhuǎn)】什么是JavaScript

rockswang / 2596人閱讀

摘要:運(yùn)行代碼以響應(yīng)在網(wǎng)頁中發(fā)生的特定事件。以及更多然而更令人興奮的是建立在語言的核心之上的功能。這就是為什么谷歌地圖可以找到你的位置,而且標(biāo)示在地圖上。谷歌地圖允許你去嵌入定制的地圖到你的網(wǎng)站,和其他的功能。

轉(zhuǎn)自mdn學(xué)習(xí)網(wǎng)站-什么是JavaScript

什么是JavaScript?

歡迎來到 MDN JavaScript 初學(xué)者的課程! 在第一篇文章中,我們將會站在一定的高度來俯看 JavaScript,回答一些像“它是什么?”和“它能做什么?”的問題 。并確保你熟悉 JavaScript 的用途。

一個高水平的定義

JavaScript 是允許你在網(wǎng)頁中實(shí)現(xiàn)復(fù)雜事情的一門編程語言 —— 每次當(dāng)你瀏覽網(wǎng)頁時不只是顯示靜態(tài)信息—— 顯示即時更新的內(nèi)容, 或者交互式的地圖,或 2D/3D 圖形動畫,又或者自動播放視頻等,你可以確信,JavaScript 參與其中。這是 Web技術(shù)的三層蛋糕標(biāo)準(zhǔn):

  • HTML是一種標(biāo)記語言,用來結(jié)構(gòu)化我們的網(wǎng)頁內(nèi)容和賦予內(nèi)容含義,例如定義段落、標(biāo)題、和數(shù)據(jù)表,或在頁面中嵌入圖片和視頻。
  • CSS 是一種樣式規(guī)則語言,我們將樣式應(yīng)用于我們的 HTML 內(nèi)容, 例如設(shè)置背景顏色和字體,在多個列種布局我們的內(nèi)容。
  • JavaScript 是一種編程語言,允許你創(chuàng)建動態(tài)更新的內(nèi)容,控制多媒體,圖像動畫,和一些其他的東西。好吧,雖然不是一切,但是它的神奇之處是你能夠用幾行JavaScript代碼就能實(shí)現(xiàn)。

這三個層次規(guī)矩地建立在彼此之上。讓我們用一個簡單的文本標(biāo)簽作為例子。我們可以用 HTML 來標(biāo)記它,以賦予它結(jié)構(gòu)和目的:

Player 1: Chris

然后我們可以加上一點(diǎn) CSS 來使它看起來更好:

p {
  font-family: "helvetica neue", helvetica, sans-serif;
  letter-spacing: 1px;
  text-transform: uppercase;
  text-align: center;
  border: 2px solid rgba(0,0,200,0.6);
  background: rgba(0,0,200,0.3);
  color: rgba(0,0,200,0.6);
  box-shadow: 1px 1px 2px rgba(0,0,200,0.4);
  border-radius: 10px;
  padding: 3px 10px;
  display: inline-block;
  cursor:pointer;
}

而最后,我們可以加上一些 JavaScript 來實(shí)現(xiàn)動態(tài)行為:

var para = document.querySelector("p");

para.addEventListener("click", updateName);

function updateName() {
  var name = prompt("Enter a new name");
  para.textContent = "Player 1: " + name;
}

嘗試點(diǎn)擊文本標(biāo)簽,觀察會發(fā)生什么(同時注意,你可以在 GitHub 上找到這個演示—— 源代碼,或者 實(shí)時運(yùn)行)!

JavaScript 可以做比這更多的東西——讓我們詳細(xì)探索它可以做些什么。

所以它_實(shí)際上_可以做什么?

JavaScript 語言的核心包含一些普遍的編程特點(diǎn),以讓你可以做到如下的事情:

  • 在變量中儲存有用的值。以上面的演示做例子,我們請求輸入一個新的名字,然后把那個名字儲存到一個叫 name 的變量.
  • 對一段文本(在編程中被稱為“字符串”)進(jìn)行操作。在上面的例子中,我們?nèi)〕鲎址?"Player 1: ",然后把它和 name 變量連結(jié)起來,創(chuàng)造出完整的文本標(biāo)簽,例:"Player 1: Chris"。
  • 運(yùn)行代碼以響應(yīng)在網(wǎng)頁中發(fā)生的特定事件。在上述的例子中,我們用了一個 click 事件來檢測按鈕什么時候被點(diǎn)擊,然后運(yùn)行更新文本標(biāo)簽的代碼。
  • 以及更多!

然而更令人興奮的是建立在 JavaScript 語言的核心之上的功能。在你的 JavaScript 代碼里,被稱為應(yīng)用程序編程接口 [Application Programming Interfaces (APIs) ] 的功能會提供額外的超能力給你使用。

APIs 是已經(jīng)建立好的一套代碼組件,目的是讓開發(fā)者可以實(shí)現(xiàn)除此之外很難甚至不可能實(shí)現(xiàn)的程序。它們的作用就像是已經(jīng)制作好的家具套件對家居建設(shè)的作用一樣——從一堆已經(jīng)切好的木板開始組裝一個書柜,顯然比自己設(shè)計(jì),尋找合適的木材,裁切至合適的大小和形狀,找到合適大小的螺絲釘,然后組裝成一個書柜要簡單得多。

它們 (APIs) 通常分成兩個分類。

瀏覽器 APIs (Browser APIs) 已經(jīng)安裝在你的網(wǎng)頁瀏覽器中,而且能夠從周圍的計(jì)算機(jī)環(huán)境中揭露數(shù)據(jù),或者做有用的復(fù)雜事情。舉個例子:

  • 文檔對象模型 API [DOM (Document Object Model) API] 允許你操作 HTML 和 CSS,創(chuàng)建,移除和修改 HTML,動態(tài)地應(yīng)用新的樣式到你的頁面,等等。比如說每次你在一個頁面里看到一個彈出窗口,或者顯示一些新的內(nèi)容(像我們在上面的簡單演示中看到那樣),這就是 DOM 在運(yùn)作。

  • 地理定位 API [Geolocation API] 獲取地理信息。這就是為什么谷歌地圖 [Google Maps] 可以找到你的位置,而且標(biāo)示在地圖上。

  • 畫布 [Canvas] 和 WebGL APIs 允許你創(chuàng)建生動的 2D 和 3D 圖像。人們正運(yùn)用這些網(wǎng)頁技術(shù)進(jìn)行一些令人驚嘆的事情——比如說 Chrome Experiments 和 webglsamples。

  • 音像和影像 APIs [Audio and Video APIs],像 HTMLMediaElement 和 WebRTC 允許你運(yùn)用多媒體去做一些非常有趣的事情,比如在網(wǎng)頁中播放音像和影像,或者從你的網(wǎng)頁攝像頭中獲取獲取錄像,然后在其他人的電腦上展示(嘗試我們的簡單快照演示 [Snapshot demo] 以理解這個概念)。

Note: 上述的很多演示都不能在舊的瀏覽器中運(yùn)行——當(dāng)進(jìn)行實(shí)驗(yàn)時,在現(xiàn)代瀏覽器,像 Firefox, Chrome, Edge 或者 Opera,中運(yùn)行會是一個好的想法。當(dāng)你接近交付產(chǎn)品代碼時,你會需要更深入地去考慮跨平臺測試 [cross browser testing](例:現(xiàn)實(shí)客戶會使用的實(shí)際代碼)。

第三方 APIs (Third party APIs) 默認(rèn)是沒有安裝到瀏覽器中的,而你通常需要從網(wǎng)絡(luò)上的某些地方取得它們的代碼和信息。舉個例子:

  • 推特 API [Twitter API] 允許你做一些像是在你的網(wǎng)站上展示你的最新推送之類的事情。

  • 谷歌地圖 API [Google Maps API] 允許你去嵌入定制的地圖到你的網(wǎng)站,和其他的功能。

Note: 這些 APIs 是高級的,而我們不會在課程中涉及任何的這些 APIs,但是如果你想了解更多,上述的鏈接提供延展的文檔供參考。

這里還有更多可用的東西!然而,不要這么快就感到太過興奮。你不可能只通過 24 小時的 JavaScript 學(xué)習(xí),就能夠構(gòu)建下一個 Facebook, Google Maps 或者 Instagram——這里有很多的基礎(chǔ)需要優(yōu)先覆蓋。而這就是為什么你在這里——讓我們繼續(xù)前進(jìn)!

JavaScript 在你的頁面上做什么?

在這我們會開始確實(shí)地查看一些代碼,而在這樣做的同時,探索當(dāng)你在你的頁面上運(yùn)行 JavaScript 的時候?qū)嶋H發(fā)生了什么。

讓我們簡單地回顧當(dāng)你在瀏覽器中讀取一個網(wǎng)頁時發(fā)生什么(在文章 How CSS works 中第一次談及到)。 當(dāng)你在瀏覽器中讀取一個網(wǎng)頁,你在一個實(shí)行環(huán)境(瀏覽器標(biāo)簽)中運(yùn)行你的代碼(HTML, CSS 和 JavaScript)。這就像是一個工廠,獲取原材料(代碼)然后出產(chǎn)一個產(chǎn)品(網(wǎng)頁)。

在 HTML 和 CSS 已經(jīng)被集合和組裝成一個網(wǎng)頁后,瀏覽器的 JavaScript 引擎執(zhí)行 JavaScript。這保證了當(dāng) JavaScript 開始運(yùn)行時,網(wǎng)頁的結(jié)構(gòu)和樣式已經(jīng)在該出現(xiàn)的地方了。

這是一個好事情,正如 JavaScript 的普遍用處是通過 DOM API(如之前提及的那樣)動態(tài)地修改 HTML 和 CSS 來更新用戶交界面。如果 JavaScript 在 HTML 和 CSS 加載完成之前加載運(yùn)行,那么會發(fā)生錯誤。

瀏覽器安全

每個瀏覽器標(biāo)簽本身就是一個用來運(yùn)行代碼的分離的容器(這些容器用專業(yè)術(shù)語稱為“運(yùn)行環(huán)境”)——這意味著在大多數(shù)情況中,每個標(biāo)簽中的代碼是完全分離地運(yùn)行,而且在一個標(biāo)簽中的代碼不能直接影響在另一個標(biāo)簽中的代碼——或者在另一個網(wǎng)站中的。這是一個好的安全措施——如果不是這樣的話,那么海盜們就可以開始寫從其他網(wǎng)站偷取信息的代碼,和其他像這樣的壞事。

Note: 這里有安全的方式去在不同網(wǎng)站/標(biāo)簽中傳送代碼和數(shù)據(jù),但這些方法是高級的技術(shù),而我們不會在這門課里覆蓋這些。

JavaScript 運(yùn)行順序

當(dāng)瀏覽器遇到一塊 JavaScript 代碼時,它通常會按順序運(yùn)行這代碼塊,從上往下。這意味著你需要注意你放置代碼的順序。舉個例子,讓我們回到我們在第一個例子中看到的 JavaScript 代碼塊:

var para = document.querySelector("p");

para.addEventListener("click", updateName);

function updateName() {
  var name = prompt("Enter a new name");
  para.textContent = "Player 1: " + name;
}

在這里我們正選定一個文本段落 (line 1),然后給它附上一個事件監(jiān)聽器 (line 3) 使得當(dāng)這個段落被點(diǎn)擊時,updateName() 代碼塊 (lines 5–8) 會被運(yùn)行。updateName() 代碼塊(這類可以重復(fù)使用的代碼塊被稱為“函數(shù)”)向用戶請求一個新的名字,然后把這個名字插入到段落中以更新顯示。

如果你互換了代碼里最初兩行的順序,它將不會工作——取而代之的是,你會在瀏覽器的開發(fā)者控制臺中得到一個錯誤——TypeError: para is undefined [類型錯誤:para沒有被定義]。這意味著 para 對象還不存在,所以我們不能為它增添一個事件監(jiān)聽器。

Note: 這是一個很常見的錯誤——你需要注意在嘗試對你的代碼中引用的對象進(jìn)行操作前,它已經(jīng)存在。

解釋代碼 vs 編譯代碼

在編程環(huán)境中,你或許聽說過這兩個術(shù)語 解釋 [interpreted]編譯 [compiled]。JavaScript 是一個解釋語言——代碼從上到下運(yùn)行,而運(yùn)行的結(jié)果會馬上被返回。在瀏覽器運(yùn)行代碼前,你不必先把它轉(zhuǎn)化為其他形式。

另一方面來說,編譯語言則需要在運(yùn)行前轉(zhuǎn)化為另一種形式。比如說 C/C++ 則要先被編譯成匯編語言,然后再由電腦運(yùn)行。

兩種方式都有不同的優(yōu)勢,然而就目前而言,我們不會談?wù)撨@些。

服務(wù)器端代碼 vs 客戶端代碼

你或許也聽說過 服務(wù)器端 [server-side]客戶端 [client-side] 代碼這兩個術(shù)語,尤其是在網(wǎng)頁開發(fā)的語境中??蛻舳舜a是在用戶的電腦上運(yùn)行的代碼——當(dāng)瀏覽一個網(wǎng)頁時,這個網(wǎng)頁的客戶端代碼就會被下載,然后由瀏覽器來運(yùn)行和展示。在這個 JavaScript 模塊,我們將會明確地探討 客戶端 JavaScript [client-side JavaScript]。

在另一方面,服務(wù)器端代碼則在服務(wù)器上運(yùn)行,然后它的結(jié)果會由瀏覽器進(jìn)行下載和展示。流行的服務(wù)器端網(wǎng)頁語言包含以下幾個例子:PHP, Python, Ruby, ASP.NET 和 JavaScript!JavaScript 同時也能用作服務(wù)器端語言,比如說在流行的 Node.js 環(huán)境中——你可以在我們的 動態(tài)網(wǎng)頁 - 服務(wù)器端編程 [Dynamic Websites – Server-side programming] 主題中找到更多關(guān)于服務(wù)器端 JavaScript 的知識。

動態(tài) [dynamic] 這個詞被用來描述客戶端 JavaScript 和服務(wù)器端語言——它指的是能更新網(wǎng)頁/應(yīng)用的內(nèi)容以在不同環(huán)境下顯示不同事物,當(dāng)有需要時產(chǎn)生新內(nèi)容的能力。服務(wù)器端代碼會動態(tài)地在服務(wù)器上產(chǎn)生新的內(nèi)容,比如說從數(shù)據(jù)庫中提取信息。反之,客戶端 JavaScript則在用戶的瀏覽器中動態(tài)地生成新的內(nèi)容,比如說創(chuàng)建一個新的 HTML 表格,從中插入從服務(wù)器請求到的數(shù)據(jù),然后在已經(jīng)向用戶展示了的網(wǎng)頁中顯示這個表格。在這兩個語境中,動態(tài)的意義有細(xì)微的不同,但是有聯(lián)系,而且兩種方法(服務(wù)器端和客戶端)通常是在一起工作的。

一個沒有動態(tài)更新內(nèi)容的網(wǎng)頁被指作 靜態(tài) [static] ——它只會一直顯示一樣的內(nèi)容。

怎樣向你的頁面添加 JavaScript?

JavaScript 以一種近似于 CSS 的方式應(yīng)用到你的 HTML 頁面中。盡管 CSS 使用 元素去應(yīng)用外部的樣式表 [stylesheet] 和