【最全】CSS盒子(div)水平垂直居中居然還有這種方式

来源:https://www.cnblogs.com/et-008/archive/2022/07/11/16467933.html
-Advertisement-
Play Games

純前端實現-tab卡片化樣式切換 html內容 <!DOCTYPE html> <html> <head> <meta charset="utf-8" /> <title>選項卡切換</title> <link rel="stylesheet" type="text/css" href="./css ...


最全的CSS盒子(div)水平垂直居中佈局,對CSS 佈局掌握程度決定你在 Web 開發中的開發頁面速度。

相對於屏幕

image

方法一:利用定位

<div class="box"></div>
<style>
    body {
        background: green;
    }
    .box {
        position: fixed;
        top: 50%;
        left: 50%;
        margin: -150px 0 0 -150px;
        width: 300px; 
        height: 300px;
        background: orange;
    }
</style>

設置 Position 為 fixed 定位,top 和 left 各設置 50%,margin 設置負的容器寬高的一半。

方法二:利用 transform

<div class="box"></div>
<style>
    body {
        background: green;
    }
    .box {
        position: fixed;
        top: 50%;
        left: 50%;
        width: 300px; 
        height: 300px;
        transform: translate(-50%, -50%);
        background: orange;
    }
</style>

設置 Position 為 fixed 定位,top 和 left 各設置 50%,transform 的 translate 設置上、左 -50%。

方法三:利用 margin auto

<div class="box"></div>
<style>
    body {
        background: green;
    }
    .box {
        position: fixed;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        width: 300px; 
        height: 300px;
        background: orange;
    }
</style>

設置 Position 為 fixed 定位,上、右、下、左設置為 0,margin 設置為 auto。

相對於父容器

image

方法一:利用定位

<div class="parent">
    <div class="child"></div>
</div>
<style>
    .parent {
        position: relative;
        margin: 100px auto 0;
        width: 500px; 
        height: 500px;
        background: green;
    }
    .child {
        position: absolute;
        top: 50%;
        left: 50%;
        margin: -100px 0 0 -100px;
        width: 200px; 
        height: 200px;
        background: orange;
    }
</style>

父容器設置為相對定位,子容器設置為絕對定位,top 和 left 各設置 50%,margin 設置負的子容器寬高的一半。

方法二:利用 transform

<div class="parent">
    <div class="child"></div>
</div>
<style>
    .parent {
        position: relative;
        margin: 100px auto 0;
        width: 500px; 
        height: 500px;
        background: green;
    }
    .child {
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%, -50%);
        width: 200px; 
        height: 200px;
        background: orange;
    }
</style>

父容器設置為相對定位,子容器設置為絕對定位,top 和 left 各設置 50%,transform 的 translate 設置上、左 -50%。

方法三:利用 margin auto

<div class="parent">
    <div class="child"></div>
</div>
<style>
    .parent {
        position: relative;
        margin: 100px auto 0;
        width: 500px; 
        height: 500px;
        background: green;
    }
    .child {
        position: absolute;
        top: 0;
        right: 0;
        bottom: 0;
        left: 0;
        margin: auto;
        width: 200px; 
        height: 200px;
        background: orange;
    }
</style>

父容器設置為相對定位,子容器設置為絕對定位,上、右、下、左設置為 0,margin 設置為 auto。

方法四:利用 flex

<div class="parent">
    <div class="child"></div>
</div>
<style>
    .parent {
        position: relative;
        margin: 100px auto 0;
        width: 500px; 
        height: 500px;
        display: flex;
        justify-content: center;
        align-items: center;
        background: green;
    }
    .child {
        width: 200px; 
        height: 200px;
        background: orange;
    }
</style>

父容器 display 設置為 flex,水平垂直設置為居中。

方法五:計算父盒子與子盒子的空間距離

<div class="parent">
    <div class="child"></div>
</div>
<style>
    .parent {
        margin: 100px auto 0;
        width: 500px; 
        height: 500px;
        overflow: hidden;
        background: green;
    }
    .child {
        margin: 150px auto;
        width: 200px; 
        height: 200px;
        background: orange;
    }
</style>

計算父盒子與子盒子的空間距離。

微信交流群

前端面試劍指 Offer (3群)


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

-Advertisement-
Play Games
更多相關文章
  • Permute mac是一款非常好用的萬能媒體格式轉換工具,可以幫助用戶轉換自己需要的音頻視頻格式。Permute 3 for mac最新特別版帶給大家!Permute 3 for mac支持當前所有流行的音視頻格式,使用非常方便,Permute 3中文版分享給需要的朋友,趕快試試吧! 詳情:Per ...
  • Downie 4 for Mac(mac最好用的視頻下載軟體) Mac視頻下載軟體哪個好?Downie for Mac 是一款Mac OS平臺上最好用的Mac視頻下載工具,支持1000多個不同的視頻網站,支持國內的優酷、騰訊視頻、bilibili、土豆、愛奇藝、網易、搜狐、微博以及國外的Youtub ...
  • 鏡像下載、功能變數名稱解析、時間同步請點擊 阿裡雲開源鏡像站 一、操作系統 OS(Operating System)既操作系統,是一個包含通用目的或者功能的軟體程式,這些通用目的包含了以下幾項: 硬體驅動 記憶體管理 進程管理 網路管理 安全管理 文件管理 OS主要有三大分類,既伺服器OS、桌面OS以及移動設 ...
  • 分組查詢:關鍵字group by的用法 group:組 by:通過 group by :通過....。分組group by列名:通過指定列來分組 一般情況下在題目中出現 "每個" "各個" "不同的" 這一類詞語時基本都會用到group by 分組關鍵字 語法: select 列名 from表名 g ...
  • 一鍵直達直播間 一、直播介紹 之前的內容,我們為大家分享了Taier入門及控制台,以及Taier的Web前端架構介紹,本期我們為大家分享Taier數據開發介紹。 本次直播我們將從Taier的數據開發功能介紹,到任務運行、功能可擴展點以及未來將發佈的taier1.2為大家進行詳細講解,通過本次分享,希 ...
  • 01檢索數據 SQL60 從 Customers 表中檢索所有的 ID 編寫 SQL 語句,從 Customers 表中檢索所有的cust_id select * from Customers; SQL61 檢索併列出已訂購產品的清單 【問題】編寫SQL 語句,檢索併列出所有已訂購商品(prod_i ...
  • XR技術的發展,為用戶帶來了全新的體驗模式。那麼,作為支撐XR發展主要學科之一的圖形學,將迎來哪些發展新機遇?移動應用開發者,該如何擁抱3D數字化轉型? 7月15日,HDD·HMS Core. Sparkle應用創新分論壇將邀請圖形領域學者、分析師、技術和產品專家,共同探討圖形技術的發展現狀和趨勢, ...
  • JavaScript基本知識點——帶你逐步解開JS的神秘面紗 在我們前面的文章中已經深入學了HTML和CSS,在網頁設計中我們已經有能力完成一個美觀的網頁框架 但僅僅是網頁框架不足以展現出網頁的魅力,JS由此而生! JavaScript概述 JavaScript是一門弱類型腳本語言,其源代碼在發往客 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...