響應式Web設計
在設計中經常遇到這幾個問題:
1.想要網站相容手機、平板電腦、pc,就得為不同的裝置定製不同的版本。
2.想要網站的某些頁面在寬屏顯示器下一行顯示更多的內容,又得為寬屏定製一個版本。
3.很多人並不是在全屏的情況下瀏覽我們的頁面,如果讓頁面隨著瀏覽器寬度改變而相應的調整會不會比較好?
有沒有辦法能有效解決這些問題呢?
響應式Web設計(Responsive Web design)的理念是頁面的設計與開發應當根據裝置環境(螢幕尺寸、螢幕定向、系統平臺等)以及使用者行為(改變視窗大小等)進行相應的響應和調整。具體的實踐方式由多方面組成,包括彈性網格和佈局、圖片、CSS media query的使用等。無論使用者正在使用pc、平板電腦,或者手機,無論是全屏顯示還是非全屏的情況,無論螢幕是橫向還是豎向,頁面都應該能夠自動切換解析度、圖片尺寸及相關指令碼功能等,以適應不同裝置。
響應式web設計對互動設計和前端實現提出了更高的要求,需要考慮清楚不同解析度下頁面的佈局變化、內容的縮放等。
響應式Web設計的優勢:
- 開發、維護、運營成本優勢:頁面只有一個,只是針對不同的解析度、不同的裝置環境進行了一些不同的設計,所以在開發、維護和運營上,相對多個版本,能節約成本。
- 相容性優勢:移動裝置新的尺寸層出不窮,定製的版本通常只適用於某些規格的裝置,如果新的裝置解析度變化較大,則往往不能相容,而開發新的版本需要時間,這段時間內的訪問就是個問題,但是響應式Web設計可以提前預防這個問題。
- 操作靈活:響應式設計是針對頁面的,可以只對必要的頁面進行改動,其他頁面不受影響。
例項展示
當瀏覽器寬度變小時,左右兩欄的寬度都有縮小,左邊的banner圖片和視訊也相應縮小,右邊的頭像列表由一排4個變為一排兩個。
當瀏覽器寬度進一步變小後,頁面由兩欄結構變為一欄結構,部分內容的尺寸進一步縮小,搜尋區域也從導航裡挪到了導航外。
響應式頁面的設計流程
第一步:確定需要相容的裝置型別、螢幕尺寸
通過使用者研究,瞭解使用者使用的裝置分佈情況,確定需要相容的裝置型別、螢幕尺寸。
裝置型別:包括移動裝置(手機、平板)和pc。對於移動裝置,設計和實現的時候注意增加手勢的功能。
螢幕尺寸:包括各種手機螢幕的尺寸(包括橫向和豎向)、各種平板的尺寸(包括橫向和豎向)、普通電腦螢幕和寬屏。
需要考慮的問題:
- 某個頁面進行響應式設計時其適用的尺寸範圍是哪些?比如,1688搜尋結果頁面,跨度可以從手機到寬屏,而1688首頁,由於結構過於複雜,想直接遷移到手機上,不太現實,不如直接設計一個手機版的首頁。
- 結合使用者需求和實現成本,對適用的尺寸進行取捨。比如一些功能操作的頁面,使用者一般沒有在移動端進行操作的需求,沒有必要進行響應式設計。
第二步:製作線框原型
針對確定下來的幾個尺寸分別製作不同的線框原型,需要考慮清楚不同尺寸下,頁面的佈局如何變化,內容尺寸如何縮放,功能、內容的刪減,甚至針對特殊的環境作特殊化的設計等。這個過程需要設計師和前端開發人員保持密切的溝通。
第三步:測試線框原型
將圖片匯入到相應的裝置進行一些簡單的測試,可幫助我們儘早發現可訪問性、可讀性等方面存在的問題。
第四步:視覺設計
注意,移動裝置的螢幕畫素密度與傳統電腦螢幕不一樣,在設計的時候需要保證內容文字的可讀性、控制元件可點選區域的面積等。
第五步:前端實現
與傳統的web開發相比,響應式設計的頁面由於頁面佈局、內容尺寸發生了變化,所以最終的產出更有可能與設計稿出入較大,需要前端開發人員和設計師多溝通。
相關文章
- Responsive Web Design 響應式網頁設計Web網頁
- 使用Reactor響應式程式設計React程式設計
- 函式響應式程式設計與RxSwift函式程式設計Swift
- [譯] 響應式 Web 應用(四)Web
- [譯] 響應式 Web 應用(五)Web
- 響應式設計?響應式設計的基本原理是什麼?如何做?
- 淺談前端響應式設計(一)前端
- 淺談前端響應式設計(二)前端
- 響應式程式設計入門(RxJava)程式設計RxJava
- 響應式程式設計庫RxJava初探程式設計RxJava
- web app響應式字型設定!rem之我見WebAPPREM
- SpringBoot中的響應式web應用Spring BootWeb
- 揚帆起航:從指令式程式設計到函式響應式程式設計程式設計函式
- 響應式程式設計簡介之:Reactor程式設計React
- Tailwind CSS 響應式設計實戰指南AICSS
- 響應式程式設計機制總結程式設計
- token響應式設定
- 完美解釋 Javascript 響應式程式設計原理JavaScript程式設計
- Ajax、JSON、響應式設計和Node.jsJSONNode.js
- 對響應式程式設計的懷疑 - lukaseder程式設計
- RxJS 系列故事(1)——理解響應式程式設計JS程式設計
- Kotlin Flow響應式程式設計,StateFlow和SharedFlowKotlin程式設計
- Web應用課 2.4 CSS——flex、響應式佈局WebCSSFlex
- web響應式佈局之 meta詳解Web
- 開發響應式web頁面的經驗Web
- 使用Java 9 Flow進行響應式程式設計Java程式設計
- 響應式程式設計與MVVM架構—理論篇程式設計MVVM架構
- Spring 5與Spring cloud的響應式程式設計之旅SpringCloud程式設計
- Vue3設計思想及響應式原始碼剖析Vue原始碼
- 前端RxJs響應式程式設計之運算子實踐前端JS程式設計
- Vue響應式—-資料響應式原理Vue
- Spring Boot 中的響應式程式設計和 WebFlux 入門Spring Boot程式設計WebUX
- 響應式程式設計在Android 中的一些探索程式設計Android
- RxDart——Dart和Flutter中的響應式程式設計入門DartFlutter程式設計
- Spring響應式Reactive程式設計的10個陷阱 -Jeroen RosenbergSpringReact程式設計ROS
- 一文帶你響應式網頁設計入門網頁
- 響應式程式設計基礎教程:Spring Boot 與 Lettuce 整合程式設計Spring Boot
- 響應式網頁中的高度設計,你認真的嗎?網頁
- [譯]Flutter 響應式程式設計:Steams 和 BLoC 實踐範例Flutter程式設計BloC