12. CSS 布局與樣式技巧

在前端開發中,CSS 是控制頁面樣式和布局的核心技術。本文總結了 CSS 布局中的關鍵概念和實用技巧,包括 overflow 屬性、背景圖片處理、精靈圖技術、display 屬性、浮動布局以及清除浮動的方法。


一、overflow 屬性詳解

overflow 屬性用于控制當元素內容超出其容器時的顯示方式。常見值包括:

  • visible(默認):內容溢出時可見。
  • hidden:溢出部分隱藏。
  • scroll:始終顯示滾動條。
  • auto:瀏覽器智能判斷是否顯示滾動條。
  • text-overflow: ellipsis+white-space: nowrap`:當內容溢出時,用省略號代替。

示例代碼

.content {width: 100px;background-color: cornflowerblue;overflow: hidden; /* 隱藏溢出內容 */text-overflow: ellipsis; /* 溢出時顯示省略號 */white-space: nowrap; /* 文本不換行 */
}

應用場景:限制文本或內容顯示區域,避免頁面布局混亂。


二、背景圖片處理技巧

背景圖片是 CSS 中常用的裝飾手段,關鍵屬性包括:

  1. background-image:設置背景圖片路徑。
  2. background-repeat:控制圖片是否重復(如 no-repeat 禁止重復)。
  3. background-size:調整圖片尺寸(如 cover 完全覆蓋容器)。
  4. background-position:定位圖片位置(如 right bottom 右下角)。
  5. background-attachment:控制背景是否固定(如 fixed 實現視差效果)。

示例

.box {background-image: url(./bg2.jpg);background-repeat: no-repeat;background-size: cover;background-attachment: fixed; /* 背景固定,頁面滾動時不移動 */
}

三、精靈圖(CSS Sprites)技術

原理:將多張小圖合并為一張大圖,通過 background-position 定位顯示特定部分。
優勢:減少HTTP請求,提升加載速度。

關鍵點

  • 背景定位:通過 background-position 調整精靈圖中具體圖標的顯示位置。
  • 尺寸控制background-size 確保精靈圖適配容器。

示例代碼

.box {width: 300px;height: 300px;background-image: url(./icons.jpg);background-size: 700% 700%;background-position: -500% -200%;
}

四、display 屬性與元素類型

HTML 元素按布局方式分為:

  1. 塊元素

    • 默認獨占一行,寬高可設。
    • 示例:divh1-h6p 等。
  2. 行內元素與行內塊元素

    • 行內元素(如 aspan)寬高不可設,但可通過 display: inline-block 轉換為行內塊元素。
    • 示例:img 默認是行內塊元素,可設置寬高。
  3. 行內元素間隙問題

    • 原因:HTML 中行內元素換行會產生空白字符。
    • 解決方案:
      • 設置父元素 font-size: 0,子元素單獨設置字體大小。
      • 將行內元素寫成一行(不推薦,影響可讀性)。
      • 使用負外邊距或浮動布局消除間隙。

五、浮動布局與高度塌陷解決方案

浮動布局會脫離文檔流,導致父元素高度塌陷。
解決方案

  • 偽元素清除浮動:在父元素后添加偽元素 ::after,設置 content: ""display: blockclear: both,觸發 BFC(塊級格式化上下文)以解決高度塌陷問題。

示例代碼

.clearfix::after {content: "";display: block;clear: both;
}

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

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

相關文章

OpenCV---Canny邊緣檢測

一、基本概念與核心作用 Canny邊緣檢測是計算機視覺中最經典的邊緣檢測算法之一,由John Canny于1986年提出。其核心目標是在噪聲圖像中提取精確、單像素寬、連續的邊緣,廣泛應用于: 目標檢測預處理(如Robomaster中燈條、裝甲板的…

提效-點擊跳轉到源碼

1、localhost項目 例如【鯨島】這個中臺項目啟動地址是localhost。 使用chrome中的【click-to-react-component 】擴展, alt 鼠標左鍵 選擇dom后跳轉到對應文件。 click-to-react-component的原理(來自ai) click-to-react-component 的工作…

FeignClient發送https請求時的證書驗證原理分析

背景 微服務之間存在調用關系,且部署為 SSL 協議時,Feignt 請求報異常: Caused by: javax.net.ssl.SSLHandshakeException: PKIX path building failed: sun.security.provider.certpath.SunCertPathBuilderException: unable to find vali…

性能優化關鍵:link、script和meta的正確打開方式

link 標簽的主要屬性及其作用 屬性是否必填作用描述示例值rel是定義當前文檔與鏈接資源的關系(必須屬性)。常見值:stylesheet, icon, preload, preconnect 等。rel"stylesheet" rel"icon"href是指定鏈接資源的URL。href…

Linux `less` 命令深度解析與高階應用指南

Linux `less` 命令深度解析與高階應用指南 一、核心功能解析1. 基本作用2. 與類似工具對比二、選項系統詳解1. 常用基礎選項2. 高階選項組合三、高階應用場景1. 日志分析系統2. 代碼審查系統3. 數據管道處理四、特殊文件處理1. 大文件優化查看2. 二進制文件分析五、交互式命令大…

影刀RPA-20-高級操作題2

一、題目 二、鏈接 方法一:影刀應用分享: 高級考試題2-第二次 方法二:影刀應用分享: 高級考試題2 三、代碼 方法一: import xbot from xbot import print, sleep from .import package from .package import variables as glv from xbot…

C# NX二次開發-獲取面法向和UV等數據

通過ufun函數UF_MODL_ask_face_props可以獲取到面的法向數據和UV和半徑等數據。 代碼如下: double[] uvs new double[4];double[] param new double[2];double[] point new double[3];double[] u1 new double[3];double[] v1 new double[3];double[] u2 new d…

SpringBoot整合Sa-Token:實現RBAC權限模型

Java系列文章 文章目錄 Java系列文章前言一、基礎概念1.1 RBAC模型核心概念1.2 Sa-Token核心功能1.3 環境準備 二、表結構設計2.1 ER圖示例2.2 數據庫表設計2.2.1 用戶表2.2.2 角色表2.2.3 部門表2.2.4 權限表 三、SpringBoot整合Sa-Token3.1 sa-token基礎配置3.1.1 Maven配置3…

工商業儲能的“智慧大腦”:解密 Acrel-2000ES EMS 的核心功能與價值

安科瑞電氣顧強 市場背景:工商業儲能加速崛起 2022年中國已并網的儲能項目中,用戶側并網占比為8.36%,其中工商業儲能占據了用戶側高達98.6%的份額。驅動這一市場發展的關鍵因素日益顯著: 1.峰谷價差擴大: 全國各省市…

vue+threeJs 根據屏幕調整gltf模型的大小、重心、并更換騎車整體顏色

嗨,我是小路。今天主要和大家分享的主題是“vuethreeJs 根據屏幕調整gltf模型的大小、重心、并更換騎車整體顏色”。 項目案例示意圖 1.整體更換gltf模型的顏色 定義:整體代碼如下。顏色是事先設定的 const colorAry reactive(["rgb(21…

03 基于 java udp 做一個dns服務器 和 一個dns代理服務器

前言 這個也是 來自于一個朋友的需求 最終的目的是實現一個 dns 代理服務器, 當然 這本質也是一個 dns 服務器 并且 dns 代理服務器是依賴于 一個 dns 服務器的, 因此 順便給一個 dns 服務器的 demo 這里 主要是 基于 udp 的一個 dns 請求, 響應數據的交互 dns 服務器 …

【HITCSAPP 哈工大計算機系統期末大作業】 程序人生-Hello’s P2P

計算機系統 大作業 題 目 程序人生-Hello’s P2P 專 業 計算機與電子通信類 學   號 2023112915 班   級 23L0505 學 生 楊昕彥 指 導 教 師 劉宏偉 計算機科學…

第十周作業

一、CSRF 1、DVWA-High等級 2、使用Burp生成CSRF利用POC并實現攻擊 二、SSRF:file_get_content實驗,要求獲取ssrf.php的源碼 三、RCE 1、 ThinkPHP 2、 Weblogic 3、Shiro

PTA刷題筆記(難度預警!!!有詳解)

7-18 二分法求多項式單根 代碼如下&#xff1a; ? #include <stdio.h> #include <math.h>// 定義多項式函數 double polynomial(double x, double a3, double a2, double a1, double a0) {return a3 * x * x * x a2 * x * x a1 * x a0; }// 二分法求根函數 do…

打破傳統范式,線上 3D 畫展彰顯多元亮點

&#xff08;一&#xff09;沉浸式體驗&#xff0c;身臨其境賞畫? 線上 3D 畫展運用先進的 3D 建模和虛擬現實&#xff08;VR&#xff09;技術&#xff0c;高度還原了真實的展廳環境 。展廳內的布局、燈光&#xff0c;甚至墻壁的質感都被完美復刻&#xff0c;讓觀眾仿佛置身于…

Docker架構詳解

一,Docker的四大要素&#xff1a;Dockerfile、鏡像(image)、容器(container)、倉庫(repository) 1.dockerfile&#xff1a;在dockerfile文件中寫構建docker的命令,通過dockerbuild構建image 2.鏡像&#xff1a;就是一個只讀的模板&#xff0c;鏡像可以用來創建docker容器&…

【工具類】常用的工具類——CollectionUtil

目錄 cn.hutool.core.collection.CollectionUtil集合創建集合清空集合判空集合去重集合過濾集合轉換集合合并集合交集集合差集集合是否包含元素集合是否包含指定元素&#xff08;自定義條件&#xff09;集合分頁集合分組集合轉字符串元素添加元素刪除根據屬性轉Map獲取元素獲取…

從零起步搭建基于華為云構建碳排放設備管理系統的產品設計

目錄 &#x1f33f; 華為云 IoT&#xff1a;輕松上手碳排放設備管理系統搭建 &#x1f30d; 逐步搭建搭建規劃 &#x1f680; 一、系統藍圖&#xff1a;5大核心模塊&#xff0c;循序漸進 1?? 設備管理與數據采集層 2?? 數據傳輸與協議轉換層 3?? 數據處理與分析層…

華為OD機試真題—— 小明減肥(2025B卷:100分)Java/python/JavaScript/C/C++/GO最佳實現

2025 B卷 100分 題型 本專欄內全部題目均提供Java、python、JavaScript、C、C++、GO六種語言的最佳實現方式; 并且每種語言均涵蓋詳細的問題分析、解題思路、代碼實現、代碼詳解、3個測試用例以及綜合分析; 本文收錄于專欄:《2025華為OD真題目錄+全流程解析+備考攻略+經驗分…

數據結構 -- 插入排序(直接插入排序和希爾排序)

插入排序 算法思想 每次將?個待排序的記錄按其關鍵字大小插入到前面已排好序的子序列中&#xff0c;直到全部記錄插入完成。 代碼實現 void InsertSort(int A[],int n){int i,j,temp;for(i 1;i<n;i){if(A[i]<A[i-1]){temp A[i]; //用temp暫存A[i]for(ji-1;j>…