本頁使用了標題或全文手工轉換

回應式網頁設計

維基百科,自由的百科全書
前往: 導覽搜尋
「內容就像水」,這是一個說明RWD原則的說法。
Html5 css3 styling.svg
層疊樣式表

響應式網頁設計英語:Responsive web design,通常縮寫為RWD),或稱自適應網頁設計回應式網頁設計對應式網頁設計。 是一種網頁設計的技術做法,該設計可使網站在不同的裝置(從桌面電腦顯示器到行動電話或其他行動產品裝置)上瀏覽時對應不同解析度皆有適合的呈現,減少使用者進行縮放、平移和捲動等操作行為。[1][2][3]對於網站設計師和前端工程師來說,有別於過去需要針對各種裝置進行不同的設計,使用此種設計方式將更易於維護網頁。此概念於2010年5月由國外著名網頁設計師Ethan Marcotte所提出。[4]

採用 RWD 設計的網站[1][5]使用CSS3 Media queries英語Media queries[3][6][7]即一種對 @media 規則的擴充功能[8],以及串流的基於比例的網格[9]和自適應大小的圖像[10][11][12][13]以適應不同大小的裝置:

  • 串流網格概念要求頁面元素使用相對單位如百分比或字型排印學調整大小,而不是絕對的單位如像素[9]
  • 靈活的圖像也以相對單位調整大小(最大到 100%),以防止它們顯示在包含它們的元素外面。
  • Media queries英語Media queries允許網頁根據存取站點裝置的特點而使用不同 CSS 樣式規則,最常用的是瀏覽器的寬度。

回應式網頁設計變得更加重要,因為移動流量現在占網際網路流量的一半以上[14]。因此,Google宣布行動裝置時代的到來(Mobilegeddon)(2015年4月21日),並開始提高移動友好的網站的評級,如果搜尋是被從一個行動裝置發起[15]

相關概念[編輯]

移動優先,不引人注目的 JavaScript 和漸進增強[編輯]

「移動優先」和「Unobtrusive JavaScript」/「漸進增強」(考慮一種新的網站設計時的策略)是先於 RWD 的相關概念: 基礎的手機瀏覽器不理解 JavaScript 或者 media queries,因此建議的做法是建立一個只有基本框架的網站,然後再為智慧型手機和 PC 提供增強功能;而不是試著「優雅降級」——讓一個複雜的,圖像豐富的站點工作在最基本的行動電話上。[16][17][18][19]

基於瀏覽器,特性或裝置探測的漸進增強[編輯]

在一個網站必須支援缺乏 JavaScript 的基本的行動裝置的情況下,瀏覽器 (用戶代理) 探測 (也叫做「瀏覽器嗅探英語Browser-sniffing」),和行動裝置探測英語Mobile device detection[17][20]是推斷某些 HTML 和 CSS 特性是否受支援的兩種方式 (作為漸進增強的基礎)—然而,這些方法不完全可靠。

對於能力更強的行動電話和 PC,可以直接測試瀏覽器對 HTML/CSS 功能的支援 (識別裝置或者用戶代理字串) 的 JavaScript 框架如 Modernizr, jQueryjQuery Mobile英語JQuery Mobile等流行起來。Polyfills英語Polyfill可以被用於添加對一些功能的支援—比如,支援 media queries (RWD 所需要的),和在 (舊版本) Internet Explorer 上提高 HTML 5 支援。功能探測在較舊的瀏覽器上也可能不完全可靠: 某些也許會報告一個特性可用,然而它或者是缺失,或者是實現的如此拙劣以至實質上無法工作。[21][22]

挑戰和其它辦法[編輯]

Luke Wroblewski 總結出了 RWD 和移動設計中的一些挑戰,還建立了一個多裝置布局模式的目錄。[23][24][25]他提議,比起單純的 RWD 手段,Device Experience 或者 RESS (通過伺服器端元件的回應式網頁設計, Responsive Web Design with Server Side Components) 等方法可以提供對行動裝置更加最佳化的用戶體驗。[26][27][28]樣式表語言如Sass的伺服器端「動態 CSS英語Dynamic Cascading Style Sheets」實現可以是這種做法的一部分。

RWD 的一個問題是橫幅廣告和影片不是串流的。[29]然而搜尋廣告英語Search advertising和 (橫幅) 顯示廣告支援特定的裝置平台目標,和為桌面,智慧型手機和基本的行動裝置提供不同的廣告尺寸格式。可以為不同平台使用不同的著陸頁英語Landing pageURL[30]或者可以用 AJAX 顯示一個頁面上的不同廣告變體。[24][31][20]

歷史[編輯]

Ethan Marcotte 在他在 A List Apart英語A List Apart 的文章中發明了術語 Responsive Web Design (RWD)。[1]他在他 2011 年關於這個主題所寫的簡短的書中描述了回應式網頁設計的理論和實踐。[32]回應式設計被 .net 雜誌英語.net (magazine) 列為 2012 年頂級網頁設計趨勢的第二名 (漸進增強是第一名)。他們也列出了 Ethan Marcotte 最喜歡的回應式站點之中的 20 個。[2]

參見[編輯]

外部連結[編輯]

參考資料[編輯]

  1. ^ 1.0 1.1 1.2 Marcotte, Ethan. Responsive Web Design. A List Apart. May 25, 2010. 
  2. ^ 2.0 2.1 Ethan Marcotte's 20 favourite responsive sites. .net magazine. October 11, 2011. 
  3. ^ 3.0 3.1 Gillenwater, Zoe Mickley. Examples of flexible layouts with CSS3 media queries. Stunning CSS3: 320. Dec 15, 2010. ISBN 978-0-321-722133. 
  4. ^ 響應式網頁設計的概念. 慈濟醫療志業數位學習電子報. [2017-02-10]. 
  5. ^ Pettit, Zoe Nick. Beginner’s Guide to Responsive Web Design. TeamTreehouse.com blog. Aug 8, 2012. 
  6. ^ Gillenwater, Zoe Mickley. Crafting quality media queries. Oct 21, 2011. 
  7. ^ Responsive design—harnessing the power of media queries. Google Webmaster Central. Apr 30, 2012. 
  8. ^ W3C @media rule
  9. ^ 9.0 9.1 Marcotte, Ethan. Fluid Grids. A List Apart. March 3, 2009. 
  10. ^ Marcotte, Ethan. Fluid images. A List Apart. June 7, 2011. 
  11. ^ Adaptive Images. 
  12. ^ Hannemann, Anselm. The road to responsive images. net Magazine. Sept. 7, 2012. 
  13. ^ Jacobs, Denise. 21 top tools for responsive web design. .net Magazine. August 23, 2011. 
  14. ^ Cisco Visual Networking Index: Global Mobile Data Traffic Forecast Update 2014–2019 White Paper. Cisco. January 30, 2015 [August 4, 2015]. 
  15. ^ Official Google Webmaster Central Blog: Rolling out the mobile-friendly update. Official Google Webmaster Central Blog. [August 4, 2015]. 
  16. ^ Wroblewski, Luke. Mobile First. November 3, 2009. 
  17. ^ 17.0 17.1 Firtman, Maximiliano. Programming the Mobile Web. July 30, 2010: 512. ISBN 978-0-596-80778-8. 
  18. ^ Graceful degradation versus progressive enhancement. February 3, 2009. 
  19. ^ Designing with Progressive Enhancement. March 1, 2010: 456. ISBN 978-0-321-65888-3. 
  20. ^ 20.0 20.1 Server-Side Device Detection: History, Benefits And How-To. Smashing magazine. September 24, 2012. 
  21. ^ BlackBerry Torch: The HTML5 Developer Scorecard | Blog. Sencha. 2010-08-18 [2012-09-11]. 
  22. ^ Motorola Xoom: The HTML5 Developer Scorecard | Blog. Sencha. 2011-02-24 [2012-09-11]. 
  23. ^ Wroblewski, Luke. Mobilism: jQuery Mobile. May 17, 2011. 
  24. ^ 24.0 24.1 Wroblewski, Luke. Rolling Up Our Responsive Sleeves. February 6, 2012. 
  25. ^ Wroblewski, Luke. Multi-Device Layout Patterns. March 14, 2012. 
  26. ^ Wroblewski, Luke. Responsive Design ... or RESS. February 29, 2012. 
  27. ^ Wroblewski, Luke. RESS: Responsive Design + Server Side Components. September 12, 2011. 
  28. ^ Andersen, Anders. Getting Started with RESS. May 9, 2012. 
  29. ^ Snyder, Matthew; Koren, Etai. The state of responsive advertising: the publishers' perspective. .net Magazine. Apr 30, 2012. 
  30. ^ Google AdWords Targeting (Device Platform Targeting)
  31. ^ JavaScript and Responsive Web Design Google Developers
  32. ^ Marcotte, Ethan. Responsive Web Design. 2011: 143. ISBN 978-0-9844425-7-7.