在對網站設計和開(kāi)發進行研究期間,我(wǒ)(wǒ)們可能遇到過用于描述網站類型的兩個術語:“靜态”和“動态”。
如果您正在構建自己的網站,選擇靜态網站還是動态網站是需要做出的首要決定之一(yī),因爲它将決定網頁如何存儲并在浏覽器中(zhōng)傳遞給訪問者。
靜态網站和動态網站的區别在于,靜态網站對于每個訪問它們的用戶來說都是一(yī)樣的,并且隻有在開(kāi)發人員(yuán)修改源文件時才會發生(shēng)變化,而動态網站可以向不同的訪問者呈現不同的信息。
無論網站看起來多麽複雜(zá),網頁的核心隻是顯示在網絡浏覽器中(zhōng)的 HTML 文件。當我(wǒ)(wǒ)們訪問一(yī)個網站時,浏覽器會向托管該網站的 Web 服務器發送一(yī)個請求,服務器會通過發回一(yī)個 HTML 文件(以及一(yī)些其他相關文件)來做出響應。
最終,靜态和動态網站都會生(shēng)成 HTML 文件,但網站“靜态”與“動态”的區别取決于服務器在将其發送給用戶之前如何創建此 HTML 文件。要了解其中(zhōng)的區别,讓我(wǒ)(wǒ)們首先了解靜态網站的工(gōng)作原理。
什麽是靜态網站?
靜态網站由存儲在 Web 服務器上的固定數量的預構建文件組成。這些文件是用 HTML、CSS 和 JavaScript 編寫的,它們被稱爲“客戶端”語言,因爲它們在用戶的 Web 浏覽器中(zhōng)執行。當用戶使用 URL 向服務器請求頁面時,服務器會返回由 URL 指定的 HTML 文件以及任何随附的CSS 和/或 JavaScript 文件。
在此交換期間,Web 服務器在将文件發送給用戶之前不會更改文件,因此網頁對于所有請求它的人來說都是完全相同的。内容是“靜态的”——改變網站外(wài)觀的唯一(yī)方法是手動更改文件的内容。
這并不意味着靜态網站不能具有交互性或吸引力。他們仍然可以擁有可點擊的鏈接和按鈕、圖像和視頻(pín)、CTA、表單、數字下(xià)載以及由 CSS或 JavaScript 提供支持的動畫。有了足夠的技巧,你甚至可以讓靜态網站看起來很漂亮。但是,靜态網站對每個人來說總是一(yī)樣的。
靜态網站的常見示例包括簡曆網站、作品集網站、宣傳冊網站、一(yī)次性登錄頁面以及其他信息或隻讀網站。這些網站很小(xiǎo)(三到四頁或更少),内容有限,不需要個性化内容或頻(pín)繁更新。
靜态網站優勢
靜态網站的大(dà)部分(fēn)好處源于它們的簡單性。靜态站點是最容易從頭開(kāi)始構建和維護的站點。如果您想快速廉價地啓動一(yī)個基本網站,靜态網站是一(yī)個不錯的選擇。有了 HTML 和 CSS 的知(zhī)識,你可以編寫一(yī)個像樣的代碼,而不需要太多的努力或成本。
在用戶端,靜态網站也往往比動态網站更快。這是因爲靜态網站上的頁面已經構建并且需要最少的後端處理。服務器隻需要檢索請求的文件并将它們交付給客戶端。由于内容缺乏變化,靜态網站也更容易緩存。網站速度,也稱爲網站性能,對于積極的用戶體(tǐ)驗至關重要,也會影響搜索引擎排名。
靜态網站的缺點
在許多情況下(xià),靜态網站并不是最佳選擇。最明顯的問題是可擴展性:任何時候我(wǒ)(wǒ)們想要進行站點範圍内的内容更新,例如更改頁面的标題,我(wǒ)(wǒ)們都必須更改每個單獨的 HTML 文件。此外(wài),每當我(wǒ)(wǒ)們想添加新頁面時,都必須手動創建一(yī)個新的 HTML 文件。對于大(dà)型網站,這根本不實用。
靜态網站的另一(yī)個缺點是缺乏個性化。無法爲訪問者定制内容,頁面可能會錯過爲訪問者創造更具吸引力的體(tǐ)驗的機會。當然,靜态站點可以顯示有關您的業務的信息,但是如果可以根據訪問者的位置(例如,他們的位置)向訪問者顯示不同的信息怎麽辦?爲此,需要一(yī)個動态站點。
最後,有許多類型的站點是無法靜态構建的。例如,電(diàn)子商(shāng)務網站通常允許用戶将産品添加到他們的購物(wù)車(chē)并結帳,這是靜态網站無法實現的功能,除非依賴第三方工(gōng)具。
什麽是動态網站?
與以相同格式向所有訪問者顯示相同内容的靜态網站不同,動态網站向不同訪問者顯示不同的信息。訪問者看到的内容可以由幾個因素決定,例如他們的位置、當地時間、設置和偏好,和/或他們在網站上采取的行動(例如,購物(wù)習慣),從而實現更具定制性和互動性經驗。
爲了在前端實現更大(dà)的靈活性,動态網站需要在後端增加更多的複雜(zá)性。這些網站不會将每個頁面存儲爲自己的HTML 文件。相反,Web 服務器“即時”構建頁面——當用戶請求頁面時,服務器從一(yī)個或多個數據庫中(zhōng)提取信息并構建爲客戶端定制的 HTML 文件。頁面構建完成後,HTML 文件将被發送回用戶的浏覽器。
爲了在後端構建頁面,除了客戶端語言(HTML、CSS 和 JavaScript)之外(wài),動态網站還使用服務器端腳本語言,如 PHP、Python、Ruby 或服務器端 JavaScript。根據爲構建頁面而提取的數據量,此過程可能會變得非常複雜(zá)。然而,用戶看不到任何這個過程——他們隻看到浏覽器中(zhōng)加載的網頁,與靜态站點相同。
如今,我(wǒ)(wǒ)們使用的大(dà)多數網站都至少采用了一(yī)些動态做法。在線商(shāng)店(diàn)、社交媒體(tǐ)網站、會員(yuán)網站、新聞網站、發布網站、博客和 Web 應用程序都在一(yī)定程度上依賴于動态内容。
例如,考慮一(yī)個電(diàn)子商(shāng)務網站,其主頁根據他們認爲您想要購買的産品推薦産品。這意味着每個訪問者都會看到略有不同的主頁。當然,爲每個人硬編碼一(yī)個頁面并将其存儲在服務器上是沒有意義的。相反,服務器端代碼用于确定您應該看到什麽内容,從各種數據庫中(zhōng)獲取該内容,并從中(zhōng)構建一(yī)個頁面。
動态内容的其他用例包括根據用戶的位置或設置更改頁面語言,在用戶登錄後顯示用戶之前從您的網站訂購的訂單,以及根據用戶的會員(yuán)狀态控制您網站上的某些内容。
動态網站優勢
我(wǒ)(wǒ)們已經談到了動态網站的主要優勢:它們使您能夠爲每個訪問者個性化您的網站内容,這意味着更具吸引力的用戶體(tǐ)驗會帶來更多的轉化和購買。
除了個性化之外(wài),服務器端腳本非常強大(dà),并爲功能提供了無數可能性。動态代碼使我(wǒ)(wǒ)們能夠構建靜态方法根本無法實現的 Web 應用程序、SaaS 軟件和豐富的體(tǐ)驗。
在動态網站上進行站點範圍的更新也容易得多。管理員(yuán)可以快速輕松地對其站點進行全面更改,而無需更新每個 HTML 文件的源代碼。在經常更新内容和外(wài)觀以跟上其行業的網站上,這是必要的。
最後,動态網站比靜态網站更具可擴展性,因爲服務器不存儲固定數量的頁面。相反,服務器在需要時構建一(yī)個頁面。回到我(wǒ)(wǒ)們的電(diàn)子商(shāng)務網站示例,假設您想向您的網站添加幾個新産品。無需在 HTML 中(zhōng)構建單獨的産品頁面,您隻需将産品信息存儲在數據庫中(zhōng)即可。服務器端腳本可以提取這些數據來自動構建産品頁面。
動态網站的缺點
由于動态網站比靜态網站更複雜(zá),因此從頭開(kāi)始創建它們需要更多的時間、精力和專業知(zhī)識。
可以使用網站構建器或内容管理系統(CMS) 來處理技術方面的事情,這樣就可以更加關注網站的内容和設計。例如,WordPress通過使用服務器端語言 PHP 動态構建其頁面來工(gōng)作。
使用動态網站的另一(yī)個權衡是性能可能會下(xià)降。動态網站在後端進行更多處理,以便向訪問者提供頁面,這可能會影響加載時間。有一(yī)些方法可以優化網站速度,并且網站建設軟件在這方面有所改進。盡管如此,在管理動态站點時,速度絕對是要牢記的,因爲幾分(fēn)之一(yī)秒的延遲會導緻更高的跳出率。
了解靜态和動态網站
在網絡的早期,所有網站都是靜态的——網站被保存爲存儲在服務器上的頁面集合,這些頁面可以在請求時交付給客戶端。
然而,随着用戶對網站的期望越來越高,例如更個性化的顯示、自動生(shēng)成的内容以及最終通過雲提供的成熟軟件,這種方法變得不那麽可行了。
靜态方法适用于想要快速觀看的沒有個性化的小(xiǎo)型網站。除此之外(wài),可能需要一(yī)個動态網站。