CSS3 基礎布局技術與響應式設計

1. CSS3 基礎與布局技術

1.1 Flexbox 布局

Flexbox 是一種一維布局模型,適合用于在一個方向上(行或列)排列元素。

基本概念:

  • 容器(Container):應用?display: flex;?的元素。
  • 項目(Item):容器內的子元素。

常用屬性:

  • 容器屬性:

    • display: flex;:將容器設置為 Flexbox 布局。
    • flex-direction: row | row-reverse | column | column-reverse;:定義主軸方向。
    • justify-content: flex-start | flex-end | center | space-between | space-around | space-evenly;:定義項目在主軸上的對齊方式。
    • align-items: flex-start | flex-end | center | baseline | stretch;:定義項目在交叉軸上的對齊方式。
    • flex-wrap: nowrap | wrap | wrap-reverse;:定義項目是否換行。
  • 項目屬性:

    • flex: <grow> <shrink> <basis>;:定義項目的伸縮性。
    • align-self: auto | flex-start | flex-end | center | baseline | stretch;:定義單個項目在交叉軸上的對齊方式。

示例代碼:

<div class="flex-container"><div class="item">1</div><div class="item">2</div><div class="item">3</div>
</div>
.flex-container {display: flex;justify-content: space-between;align-items: center;height: 200px;background-color: #f4f4f4;
}.item {background-color: #ccc;padding: 20px;margin: 5px;
}

解釋:

  • .flex-container?是 Flexbox 容器,display: flex;?啟用了 Flexbox 布局。
  • justify-content: space-between;?讓項目在主軸上均勻分布,兩端對齊。
  • align-items: center;?讓項目在交叉軸上居中對齊。
1.2 Grid 布局

Grid 是一種二維布局模型,適合用于在行和列兩個方向上進行布局。

基本概念:

  • 容器(Container):應用?display: grid;?的元素。
  • 項目(Item):容器內的子元素。

常用屬性:

  • 容器屬性:

    • display: grid;:將容器設置為 Grid 布局。
    • grid-template-columns: <track-size> ...;:定義列的大小。
    • grid-template-rows: <track-size> ...;:定義行的大小。
    • gap: <row-gap> <column-gap>;:定義行和列之間的間隙。
    • justify-items: start | end | center | stretch;:定義項目在單元格內的水平對齊方式。
    • align-items: start | end | center | stretch;:定義項目在單元格內的垂直對齊方式。
  • 項目屬性:

    • grid-column: <start> / <end>;:定義項目占據的列。
    • grid-row: <start> / <end>;:定義項目占據的行。
    • justify-self: start | end | center | stretch;:定義單個項目在單元格內的水平對齊方式。
    • align-self: start | end | center | stretch;:定義單個項目在單元格內的垂直對齊方式。

示例代碼:

<div class="grid-container"><div class="item">1</div><div class="item">2</div><div class="item">3</div><div class="item">4</div><div class="item">5</div><div class="item">6</div>
</div>
.grid-container {display: grid;grid-template-columns: repeat(3, 1fr);grid-template-rows: repeat(2, 100px);gap: 10px;background-color: #f4f4f4;
}.item {background-color: #ccc;padding: 20px;text-align: center;
}

解釋:

  • .grid-container?是 Grid 容器,display: grid;?啟用了 Grid 布局。
  • grid-template-columns: repeat(3, 1fr);?定義了三列,每列的寬度相等。
  • grid-template-rows: repeat(2, 100px);?定義了兩行,每行的高度為 100px。
  • gap: 10px;?定義了行和列之間的間隙為 10px。

2. 響應式設計

2.1 媒體查詢(Media Queries)

媒體查詢允許你根據設備的特性(如屏幕寬度、高度等)應用不同的樣式。

基本語法:

@media (條件) {/* 滿足條件時應用的樣式 */
}

常用條件:

  • max-width:最大寬度。
  • min-width:最小寬度。
  • orientation: portrait | landscape;:設備方向。

示例代碼:

/* 默認樣式 */
body {background-color: lightblue;
}/* 當屏幕寬度小于等于 600px 時應用的樣式 */
@media (max-width: 600px) {body {background-color: lightcoral;}
}/* 當屏幕寬度大于 600px 且小于等于 900px 時應用的樣式 */
@media (min-width: 601px) and (max-width: 900px) {body {background-color: lightgreen;}
}

解釋:

  • max-width: 600px;?當屏幕寬度小于等于 600px 時,背景顏色變為?lightcoral
  • min-width: 601px?和?max-width: 900px?當屏幕寬度在 601px 到 900px 之間時,背景顏色變為?lightgreen
2.2 移動優先(Mobile First)

移動優先是一種設計理念,首先為移動設備設計樣式,然后通過媒體查詢逐步增強為大屏幕設備的樣式。

示例代碼:

/* 移動設備樣式 */
body {background-color: lightblue;font-size: 14px;
}/* 平板設備樣式 */
@media (min-width: 600px) {body {font-size: 16px;}
}/* 桌面設備樣式 */
@media (min-width: 900px) {body {font-size: 18px;}
}

解釋:

  • 默認樣式是為移動設備設計的,背景顏色為?lightblue,字體大小為?14px
  • 當屏幕寬度大于等于 600px 時,字體大小變為?16px
  • 當屏幕寬度大于等于 900px 時,字體大小變為?18px

3. 綜合示例

以下是一個結合 Flexbox、Grid 和響應式設計的綜合示例:

<!DOCTYPE html>
<html lang="en">
<head><meta charset="UTF-8"><meta name="viewport" content="width=device-width, initial-scale=1.0"><title>Responsive Layout</title><style>/* 移動設備樣式 */body {font-family: Arial, sans-serif;margin: 0;padding: 0;background-color: #f4f4f4;}.container {display: grid;grid-template-columns: 1fr;gap: 10px;padding: 10px;}.header, .footer {background-color: #333;color: white;text-align: center;padding: 10px;}.nav {display: flex;justify-content: space-around;background-color: #444;padding: 10px;}.nav a {color: white;text-decoration: none;}.main {background-color: white;padding: 10px;}/* 平板設備樣式 */@media (min-width: 600px) {.container {grid-template-columns: 1fr 3fr;}.nav {flex-direction: column;justify-content: flex-start;}.nav a {margin: 5px 0;}}/* 桌面設備樣式 */@media (min-width: 900px) {.container {grid-template-columns: 1fr 3fr;}.main {display: grid;grid-template-columns: repeat(2, 1fr);gap: 10px;}}</style>
</head>
<body><div class="container"><header class="header"><h1>Header</h1></header><nav class="nav"><a href="#">Home</a><a href="#">About</a><a href="#">Services</a><a href="#">Contact</a></nav><main class="main"><section><h2>Section 1</h2><p>Content of section 1.</p></section><section><h2>Section 2</h2><p>Content of section 2.</p></section></main><footer class="footer"><p>Footer</p></footer></div>
</body>
</html>

解釋: ? 默認樣式是為移動設備設計的,使用單列布局。

  • 當屏幕寬度大于等于 600px 時,使用雙列布局,導航欄變為垂直排列。
  • 當屏幕寬度大于等于 900px 時,主內容區域使用雙列布局。

總結

  • Flexbox?適合一維布局,Grid?適合二維布局。
  • 媒體查詢?允許你根據設備特性應用不同的樣式,移動優先?是一種設計理念,首先為移動設備設計樣式,然后逐步增強為大屏幕設備的樣式。

?

本文來自互聯網用戶投稿,該文觀點僅代表作者本人,不代表本站立場。本站僅提供信息存儲空間服務,不擁有所有權,不承擔相關法律責任。
如若轉載,請注明出處:http://www.pswp.cn/pingmian/72806.shtml
繁體地址,請注明出處:http://hk.pswp.cn/pingmian/72806.shtml
英文地址,請注明出處:http://en.pswp.cn/pingmian/72806.shtml

如若內容造成侵權/違法違規/事實不符,請聯系多彩編程網進行投訴反饋email:809451989@qq.com,一經查實,立即刪除!

相關文章

鴻蒙NEXT項目實戰-百得知識庫01

代碼倉地址&#xff0c;大家記得點個star IbestKnowTeach: 百得知識庫基于鴻蒙NEXT穩定版實現的一款企業級開發項目案例。 本案例涉及到多個鴻蒙相關技術知識點&#xff1a; 1、布局 2、配置文件 3、組件的封裝和使用 4、路由的使用 5、請求響應攔截器的封裝 6、位置服務 7、三…

【DeepSeek應用】本地部署deepseek模型后,如何在vscode中調用該模型進行代碼撰寫,檢視和優化?

若已成功在本地部署了 DeepSeek 模型(例如通過 vscode-llm、ollama 或私有 API 服務),在 VS Code 中調用本地模型進行代碼撰寫、檢視和優化的完整流程如下: 1. 準備工作:確認本地模型服務狀態 模型服務類型: 若使用 HTTP API 服務(如 FastAPI/Flask 封裝),假設服務地址…

jenkins 配置郵件問題整理

版本&#xff1a;Jenkins 2.492.1 插件&#xff1a; A.jenkins自帶的&#xff0c; B.安裝功能強大的插件 配置流程&#xff1a; 1. jenkins->系統配置->Jenkins Location 此處的”系統管理員郵件地址“&#xff0c;是配置之后發件人的email。 2.配置系統自帶的郵件A…

Android Coil3階梯preload批量Bitmap拼接扁平寬圖,Kotlin

Android Coil3階梯preload批量Bitmap拼接扁平寬圖&#xff0c;Kotlin <uses-permission android:name"android.permission.WRITE_EXTERNAL_STORAGE" /><uses-permission android:name"android.permission.READ_EXTERNAL_STORAGE" /><uses-p…

C++基礎 [八] - list的使用與模擬實現

目錄 list的介紹 List的迭代器失效問題 List中sort的效率測試 list 容器的模擬實現思想 模塊分析 作用分析 list_node類設計 list 的迭代器類設計 迭代器類--存在的意義 迭代器類--模擬實現 模板參數 和 成員變量 構造函數 * 運算符的重載 運算符的重載 -- 運…

【系統架構設計師】操作系統 - 特殊操作系統 ③ ( 微內核操作系統 | 單體內核 操作系統 | 內核態 | 用戶態 | 單體內核 與 微內核 對比 )

文章目錄 一、微內核操作系統1、單體內核 操作系統2、微內核操作系統 引入3、微內核操作系統 概念4、微內核操作系統 案例 二、單體內核 與 微內核 對比1、功能對比2、單體內核 優缺點3、微內核 優缺點 一、微內核操作系統 1、單體內核 操作系統 單體內核 操作系統 工作狀態 : …

系統思考:惡性循環

去年&#xff0c;我給一家知名人力資源公司交付了兩個項目——一個在6月&#xff0c;另一個在8月&#xff0c;至今半年多了依然沒有收到課酬。催促多次&#xff0c;得到的答復卻各式各樣&#xff1a;銷售說老板卡了額度&#xff0c;老板說具體情況還需了解。每一次的推諉&#…

基于springboot的房屋租賃系統(008)

摘 要 社會的發展和科學技術的進步&#xff0c;互聯網技術越來越受歡迎。網絡計算機的生活方式逐漸受到廣大人民群眾的喜愛&#xff0c;也逐漸進入了每個用戶的使用。互聯網具有便利性&#xff0c;速度快&#xff0c;效率高&#xff0c;成本低等優點。 因此&#xff0c;構建符…

視頻翻譯器免費哪個好?輕松玩轉視頻直播翻譯

你是不是覺得看外語視頻很麻煩&#xff1f;每次遇到喜歡的外語電影、電視劇或動漫&#xff0c;總是要等字幕組的翻譯&#xff0c;或者因為語言不通而錯過精彩的情節。 這個時候&#xff0c;掌握多語種直播翻譯方案就顯得尤為重要&#xff0c;有了實時字幕&#xff0c;看外語視…

在cherry studio中使用MCP——本地文件管理FileSystem

cherry studio是一款開源的AI助手工具&#xff0c;可以便捷地利用API訪問各種LLM&#xff0c;有關cherry studio的使用這里不再多說&#xff0c;可以參考這篇文章https://blog.csdn.net/m0_65494437/article/details/145478823 官網&#xff1a;https://cherry-ai.com/ MCP是什…

從點燈開始的51單片機生活

陵谷紛紜新事改&#xff0c;筑臺土石未應遲。 目錄 sfr與sbit&#xff1f;不靠定時器的delay_ms延時函數所謂寄存器 sfr與sbit&#xff1f; 這第一課咱們主要來先理解一下sfr與sbit&#xff0c;以下可能是咱們這些新手朋友常見的點燈代碼&#xff1a; #include<regx52.h&g…

Django系列教程(13)——Cookie和Session應用場景及案例

目錄 什么是cookie&#xff0c;cookie的應用場景及缺點 Django中如何使用cookie Cookie使用示例 什么是session及session的工作原理 Django中如何使用會話session Session使用示例 小結 HTTP協議本身是”無狀態”的&#xff0c;在一次請求和下一次請求之間沒有任何狀態保…

c++類和對象(下篇)下

下面就來補充一下c雷和對象最后一點內容. 首先先補充一下上一篇博客上c類和對象(下篇)上-CSDN博客最后學習的靜態成員變量的小練習求123...n_牛客題霸_牛客網 (nowcoder.com)下面就是題解.靈活的運用了靜態成員變量不銷毀的特點,建立數組利用構造函數來完成n次相加. class A{ …

《TCP/IP網絡編程》學習筆記 | Chapter 19:Windows 平臺下線程的使用

《TCP/IP網絡編程》學習筆記 | Chapter 19&#xff1a;Windows 平臺下線程的使用 《TCP/IP網絡編程》學習筆記 | Chapter 19&#xff1a;Windows 平臺下線程的使用內核對象內核對象的定義內核對象歸操作系統所有 基于 Windows 的線程創建進程與線程的關系Windows 中線程的創建方…

分布式事務解決方案:Seata原理詳解與實戰教程

一、為什么需要Seata&#xff1f; 在微服務架構中&#xff0c;跨服務的事務管理成為核心痛點&#xff1a; 傳統事務失效&#xff1a;服務拆分導致無法使用本地事務數據不一致風險&#xff1a;網絡抖動、服務宕機等情況導致數據錯亂復雜場景處理難&#xff1a;涉及多個數據庫、…

docker需要sudo才能使用

一種方法是添加當前用戶到docker組里去&#xff0c;當時添加的時候貌似是沒問題的&#xff0c;但是現在又不可以了 產生的報錯 ? docker images Cannot connect to the Docker daemon at unix:///home/ying/.docker/desktop/docker.sock. Is the docker daemon running?解決…

學習記錄 6 pointnet復現

一、復現代碼 然后去找相關的2d的聲吶圖像分類的算法 融合可以搞的&#xff0c;雖然有文獻但是不多&#xff0c;感覺也是可以的 """ Author: Benny Date: Nov 2019 """import os import sys import torch import numpy as npimport datetime …

Linux 文件操作-標準IO函數3- fread讀取、fwrite寫入、 fprintf向文件寫入格式化數據、fscanf逐行讀取格式化數據的驗證

目錄 1. fread 從文件中讀取數據 1.1 讀取次數 每次讀取字節數 < 原內容字節數 1.2 讀取次數 每次讀取字節數 > 原內容字節數 2.fwrite 向文件中寫入數據 2.1寫入字符串驗證 2.2寫入結構體驗證 3. fprintf 將數據寫入到指定文件 4. fscanf 從文件中逐行讀取內容…

Python 中下劃線 “_” 的多面性:從變量到約定

# Python中下劃線“_”的多面性&#xff1a;從變量到約定 在Python的語法體系里&#xff0c;下劃線“_”看似毫不起眼&#xff0c;實則扮演著極為重要且多樣化的角色。它不僅能作為普通變量參與編程&#xff0c;更在多個特殊場景下有著獨特的用途與約定。深入理解下劃線的各種…

深入 Linux 聲卡驅動開發:核心問題與實戰解析

1. 字符設備驅動如何為聲卡提供操作接口&#xff1f; 問題背景 在 Linux 系統中&#xff0c;聲卡被抽象為字符設備。如何通過代碼讓應用程序能夠訪問聲卡的錄音和播放功能&#xff1f; 核心答案 1.1 字符設備驅動的核心結構 Linux 字符設備驅動通過 file_operations 結構體定…