[CSS] 響應式設計

来源:https://www.cnblogs.com/feixianxing/p/18011533/css-responsive-design
-Advertisement-
Play Games

響應式設計旨在編寫一套代碼,在不同設備上都能有良好的表現。響應式設計有兩種思路:桌面端優先和移動端優先,它們的區別是先實現一種佈局,再使用媒體查詢設置斷點,實現不同屏幕尺寸下的佈局,逐漸過渡到另一端。即由大到小和由小到大的區別。 ...


響應式設計基本原則

1. 流式佈局

  • 頁面需要適應當前視口寬度(甚至高度);
  • 需要適配視口的元素,使用 % 單位(或者 vhvw),而不是 px
  • 使用 max-width 取代 width

2. 響應式單位

  • 對於大部分長度,使用 rem 單位取代 px,可以簡化整個佈局的自動縮放。

3. 靈活的圖像

  • 預設情況下,改變視口大小的時候,圖片不會自動縮放;
  • 使用%單位設置圖片的大小,並配合max-width使用。
  • 為不同尺寸的屏幕提供不同解析度的圖片。

4. 媒體查詢

  • 媒體查詢可以在特定的視口尺寸下應用特定的CSS樣式。(特定的視口尺寸成為斷點
  • 媒體查詢需要搭配上面三個原則才能實現響應式佈局。

響應式設計策略

桌面端與移動端的優先

響應式設計有兩種思路:桌面端優先和移動端優先,它們的區別是先實現一種佈局,再使用媒體查詢設置斷點,實現不同屏幕尺寸下的佈局,逐漸過渡到另一端。即由大到小和由小到大的區別。

在設置媒體查詢的斷點時:

  • 桌面端優先:使用max-width

    如下圖,我們首先假設我們開發的桌面端網頁應用寬度是大於1200px的,然後,我們開始考慮小尺寸屏幕的情況,設置max-width: 1200px的媒體查詢,匹配所有寬度≤1200px的屏幕。進一步細化後,最終設置max-width: 900pxmax-width: 600px

  • 移動端優先:使用min-width.

image-20240206182247182

:一種尺寸的屏幕可能會同時匹配上多個媒體查詢中的CSS選擇器,媒體查詢並不會改變選擇器的具體程度,因此最後的媒體查詢會覆蓋前面的媒體查詢。

移動端優先的優缺點

優點

  • 完全針對移動用戶進行了優化(移動端應用具有便捷性,市場需求量大,現代互聯網的許多流量都來自於手機,屬於優點);
  • 移動端的設計會更註重內容,而不是純粹的美學設計。

缺點

  • 逐步轉變到桌面版本的時候,佈局會顯得很空洞和過於簡化;
  • 由於優先考慮移動端,“畫板”小,創作自由度低,難以創建有區別度的產品;
  • 特定領域的用戶可能更關註桌面端應用而不是移動端。

斷點的選擇

image-20240206184540063

  • BAD:使用流行設備的尺寸作為斷點,這種策略針對流行的設備做了最大程度的優化,但是忽略了其它設備;同時,這種策略極度依賴設備尺寸,如果設備開發商突然修改了設備尺寸,則需要大範圍修改代碼。
  • GOOD:在互聯網上查詢儘可能多的設備尺寸,將他們聚集在一起,並選擇中間的稀疏的尺寸作為斷點。這種策略適用性廣,難度適中,推薦使用。
  • PERFECT:完全忽略設備的尺寸,只關註網頁的內容和設計,當屏幕大小到達某個尺寸後開始崩壞,則添加斷點。這種策略實現難度過大。

Screen Resolution Stats Worldwide | Statcounter Global Stats可以查看2023年屏幕尺寸的使用量占比。

image-20240206190005827

這些數據可以協助確定斷點,通常需要考慮4種或5種尺寸:手機、縱向平板、橫向平板、桌面端、(大型桌面端)。

下圖中的斷點分別是:600px,900px,1200px,1800px。

image-20240206185849050

能否使用hover?

我們使用響應式設計的初衷是為了用戶使用不同屏幕尺寸的設備都能獲得良好的體驗。但是到目前位置我們區分設備的指標只有簡單的屏幕寬度。

事實上,橫向平板和桌面端在大部分時候的佈局都是類似的,但是它們的操作方式卻截然不同,前者使用觸屏,後者使用滑鼠與鍵盤。

同時,現代UI設計者在桌面端的設計可能結合hover(滑鼠懸浮)與縮放、翻轉等動畫,這種交互設計使得部分按鈕或文本等內容在初始狀態下是隱藏的,而橫向平板的觸屏操作卻無法查看這些內容

當然,這種情況通常發生在桌面端優先的設計策略中,並且在相容橫向平板界面時,遺漏了對於交互、頁面內容的相容。

由此可見,僅通過屏幕寬度區分設備的媒體查詢是存在缺陷的,媒體查詢應進一步地檢查設備能否使用hover。

媒體查詢 匹配能否使用hover的設備

@media (hover:none){
    /* 這裡匹配不能hover的設備 */
}

@media (hover:hover){
    /* 這裡匹配可以hover的設備 */
}

SaSS實現響應式 案例

以 桌面端優先 為例,斷點選擇如下:

  • 0 - 600px:手機
  • 600 - 900px:平板豎向
  • 900 - 1200px:平板橫向
  • [1200 - 1800]:預設樣式,普通桌面端
  • 1800px + :大型桌面

使用mixin封裝一個媒體查詢管理器:

@mixin respond($breakpoint){
    @if $breakpoint == phone {
        @media only screen and (max-width: 37.5em) { @content; }     // 600px
    }
    @if $breakpoint == tab-port {
        @media only screen and (max-width: 56.25em) { @content; }     // 900px
    }
    @if $breakpoint == tab-land {
        @media only screen and (max-width: 75em) { @content; }    // 1200px
    }
    @if $breakpoint == big-desktop {
        @media only screen and (min-width: 112.5em) { @content; }    // 1800px
    }
}

需要註意的是,媒體查詢里的emrem單位都只和瀏覽器預設字體大小(16px)有關,和根節點的字體大小無關。

上面這段代碼中使用em而不是直接使用px是因為用戶可能會更改瀏覽器的預設字體大小,使用em更加靈活。

only screen使得媒體查詢更加嚴謹,當用戶打算列印頁面時,這些媒體查詢不應該生效。

使用

設置根節點的字體大小,使用上面封裝的mixin匹配不同的屏幕尺寸。

這裡font-size使用百分比而不是直接使用px與上文同理(用戶可能修改瀏覽器預設字體大小)。

html{
    // This defines what 1rem is
    font-size: 62.5%;   // 1rem = 10px, 10/16 = 62.5%

    @include respond(tab-land){ // width < 1200?
        font-size: 56.25%;    // 1rem = 9px, 9/16 = 56.25% 
    }

    @include respond(tab-port){ // width < 900?
        font-size: 50%;    // 1rem = 8px, 8/16 = 50%
    }

    @include respond(big-desktop){
        font-size: 75%;    // 1rem = 12px, 12/16 = 75%
    }
}

:媒體查詢需要註意代碼順序,應該先media(max-width: 900px),再media(max-width: 600px),這樣當屏幕尺寸小於600px時,雖然兩個媒體查詢都能匹配到,但是更加“精細”的後者可以正確地覆蓋前者。

如何實現響應式?

假設我們以桌面端優先,那麼此時CSS代碼都是基於桌面端屏幕尺寸的。

打開瀏覽器開發者工具,使用設備工具欄,拖動界面尺寸,觀察到哪一個斷點開始頁面開始崩壞,然後著手為該部分CSS代碼添加額外的代碼:

image-20240206235721032

需要註意由於選擇桌面端優先,並且配置媒體查詢的時候使用max-width,在寫不同尺寸的CSS代碼的時候應註意由大到小的順序。

如上圖,先tab-port(平板豎向)再phone(移動端)。

響應式圖像

應用場景:

  1. 不同尺寸的屏幕:桌面端大屏幕需要較大較清晰的圖片,移動端小屏幕對清晰度要求不高且註重圖片在網路傳輸過程中的流量消耗;
  2. 屏幕解析度不同(與尺寸無關):為低解析度屏幕(1x)和高解析度屏幕(2x)分別準備不同的圖片。

image-20240207011625432

HTML實現

實現方式

<picture class="footer__logo">
	<source srcset="img/logo-green-small-1x.png 1x, img/logo-green-small-2x.png 2x"
			media="(max-width: 37.5em)">
	<img srcset="img/logo-green-1x.png 1x, img/logo-green-2x.png 2x" alt="Full logo"
		 src="img/logo-green-2x.png">
</picture>
  • 首先,sourceimg的分離可以實現匹配不同的屏幕尺寸,source支持配置media,與媒體查詢一致,這裡設置的(max-width: 37.5em)匹配上手機的尺寸,當使用手機屏幕訪問時瀏覽器會自動選擇source的圖片,否則使用img的圖片。

  • 其次,使用srcset可以匹配不同解析度(像素密度)的屏幕,語法格式為:圖片路徑1 像素密度1, 圖片路徑2 像素密度2,如上述代碼,低解析度屏幕匹配1x標記,使用img/logo-*-1x.png圖片,高解析度屏幕匹配2x標記的圖片,這一選擇過程由瀏覽器自動完成。

  • 另外,可以通過設置多個source匹配多種屏幕尺寸,但沒必要,一般為手機尺寸單獨設置一個source就足夠了。

  • 最後,img需要繼續設置src,避免舊版瀏覽器無法正確識別srcset屬性。

CSS實現

使用媒體查詢也可以匹配不同解析度的屏幕。

@media (min-resolution: 192dpi) {
    /* 這裡匹配高解析度屏幕 */
}

192dpi是蘋果視網膜屏幕的數據,每英寸屏幕192像素點,超過這個數據的屏幕則認為是高解析度屏幕。

一般會在這裡設置使用較大的圖片,但是目前手機基本都是高解析度屏幕,也會匹配到這裡的大圖片,不太合理。

因此,可以添加媒體查詢的條件:

@media (min-resolution: 192dpi) and (min-width: 600px){
    /* 這裡匹配除了手機以外的高解析度屏幕 */
}

另外,大圖片不僅應用於高解析度屏幕,低解析度屏幕尺寸足夠大時也應該使用大圖片,如下:

@media (min-resolution: 192dpi) and (min-width: 600px),
    (min-width: 2000px){
    /* 這裡匹配除了手機以外的高解析度屏幕,或者尺寸足夠大的低解析度屏幕 */
}

考慮到min-resolution在safari不可用,使用-webkit-min-device-pixel-ratio

@media (min-resolution: 192dpi) and (min-width: 37.5em),
    (-webkit-min-device-pixel-ratio: 2) and (min-width: 37.5em),
    (min-width: 125em){
	...
}

您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • Ultralytics YOLOv8 基於深度學習和電腦視覺領域的尖端技術,在速度和準確性方面具有無與倫比的性能。其流線型設計使其適用於各種應用,並可輕鬆適應從邊緣設備到雲 API 等不同硬體平臺。YOLOv8 OBB 模型是YOLOv8系列模型最新推出的任意方向的目標檢測模型,可以檢測任意方向的... ...
  • RotateTransform旋轉 RotateTransform表示旋轉一個對象的角度。首先我們來看一下它的定義 public sealed class RotateTransform : Transform { public static readonly DependencyProperty ...
  • 最近做了幾個 WPF + MudBlazor 的小東西,每次從頭搭建環境比較繁瑣,然鵝搭建過程還沒啥技術含量,索性就直接做了個模板,方便以後使用。 1. 介紹 一個用來創建 .NET 8 + WPF + MudBlazor 的項目模板 適用於 VS2022 用法:vs插件市場下載 or 自己通過 G ...
  • 準備 今天學習的Demo是Data Binding中的Linq: 創建一個空白解決方案,然後添加現有項目,選擇Linq,解決方案如下所示: 查看這個Demo的效果: 開始學習這個Demo xaml部分 查看MainWindow.xaml: <Window x:Class="Linq.MainWind ...
  • 我一直有個夢想,就是自己開發App,運行在自己的手機上。但是選什麼語言呢?C#,Java或者其它? 我想,既然我已經用華為的手機,擁有鴻蒙系統,為什麼不嘗試一下鴻蒙開發呢?說乾就乾,找到官網,一步一步操作。首先是裝好開發環境: 按照官方的文檔操作是不難的,但還是遇到一些小問題,node.js的安裝路 ...
  • 摘要: 在開發iOS應用程式時,一個重要的任務是確保應用在不同的屏幕和設備上呈現出良好的用戶體驗。為了實現這一目標,iOS提供了尺寸類別、Auto Layout和Size Classes等強大的工具和技術。 尺寸類別是描述設備屏幕尺寸的屬性,它可以幫助開發者瞭解當前界面所在的設備環境。明確的設備尺寸... ...
  • 全新研發flutter3+dart3+photo_view跨多端仿微信App界面聊天Flutter3-Chat。 flutter3-chat基於最新跨全平臺技術flutter3+dart3+material-design+shared_preferences+easy_refresh構建的仿微信AP ...
  • 一、擴展函數 擴展函數可以方便地給現有類增加屬性和方法而不改動類地代碼。 二、原理 fun String.addTo(s: String): String{ return this + s } 反編譯: @Metadata( mv = {1, 6, 0}, k = 2, d1 = {"\u0000\ ...
一周排行
    -Advertisement-
    Play Games
  • 前言 微服務架構已經成為搭建高效、可擴展系統的關鍵技術之一,然而,現有許多微服務框架往往過於複雜,使得我們普通開發者難以快速上手並體驗到微服務帶了的便利。為瞭解決這一問題,於是作者精心打造了一款最接地氣的 .NET 微服務框架,幫助我們輕鬆構建和管理微服務應用。 本框架不僅支持 Consul 服務註 ...
  • 先看一下效果吧: 如果不會寫動畫或者懶得寫動畫,就直接交給Blend來做吧; 其實Blend操作起來很簡單,有點類似於在操作PS,我們只需要設置關鍵幀,滑鼠點來點去就可以了,Blend會自動幫我們生成我們想要的動畫效果. 第一步:要創建一個空的WPF項目 第二步:右鍵我們的項目,在最下方有一個,在B ...
  • Prism:框架介紹與安裝 什麼是Prism? Prism是一個用於在 WPF、Xamarin Form、Uno 平臺和 WinUI 中構建鬆散耦合、可維護和可測試的 XAML 應用程式框架 Github https://github.com/PrismLibrary/Prism NuGet htt ...
  • 在WPF中,屏幕上的所有內容,都是通過畫筆(Brush)畫上去的。如按鈕的背景色,邊框,文本框的前景和形狀填充。藉助畫筆,可以繪製頁面上的所有UI對象。不同畫筆具有不同類型的輸出( 如:某些畫筆使用純色繪製區域,其他畫筆使用漸變、圖案、圖像或繪圖)。 ...
  • 前言 嗨,大家好!推薦一個基於 .NET 8 的高併發微服務電商系統,涵蓋了商品、訂單、會員、服務、財務等50多種實用功能。 項目不僅使用了 .NET 8 的最新特性,還集成了AutoFac、DotLiquid、HangFire、Nlog、Jwt、LayUIAdmin、SqlSugar、MySQL、 ...
  • 本文主要介紹攝像頭(相機)如何採集數據,用於類似攝像頭本地顯示軟體,以及流媒體數據傳輸場景如傳屏、視訊會議等。 攝像頭採集有多種方案,如AForge.NET、WPFMediaKit、OpenCvSharp、EmguCv、DirectShow.NET、MediaCaptre(UWP),網上一些文章以及 ...
  • 前言 Seal-Report 是一款.NET 開源報表工具,擁有 1.4K Star。它提供了一個完整的框架,使用 C# 編寫,最新的版本採用的是 .NET 8.0 。 它能夠高效地從各種資料庫或 NoSQL 數據源生成日常報表,並支持執行複雜的報表任務。 其簡單易用的安裝過程和直觀的設計界面,我們 ...
  • 背景需求: 系統需要對接到XXX官方的API,但因此官方對接以及管理都十分嚴格。而本人部門的系統中包含諸多子系統,系統間為了穩定,程式間多數固定Token+特殊驗證進行調用,且後期還要提供給其他兄弟部門系統共同調用。 原則上:每套系統都必須單獨接入到官方,但官方的接入複雜,還要官方指定機構認證的證書 ...
  • 本文介紹下電腦設備關機的情況下如何通過網路喚醒設備,之前電源S狀態 電腦Power電源狀態- 唐宋元明清2188 - 博客園 (cnblogs.com) 有介紹過遠程喚醒設備,後面這倆天瞭解多了點所以單獨加個隨筆 設備關機的情況下,使用網路喚醒的前提條件: 1. 被喚醒設備需要支持這WakeOnL ...
  • 前言 大家好,推薦一個.NET 8.0 為核心,結合前端 Vue 框架,實現了前後端完全分離的設計理念。它不僅提供了強大的基礎功能支持,如許可權管理、代碼生成器等,還通過採用主流技術和最佳實踐,顯著降低了開發難度,加快了項目交付速度。 如果你需要一個高效的開發解決方案,本框架能幫助大家輕鬆應對挑戰,實 ...