css 實現 html 元素內文字水平垂直居中的N種方法

? ? ? ? 上一篇博文寫了div 中元素居中的N種常用方法,那么單個html元素:div(塊級元素代表),span(行內元素代表)中的文字如何水平垂直都居中呢?實現方法如下:

????????本文例子使用的 html body結構下的模型如下:

<body><div class="container">文字居中顯示</div>
</body>

? ? ? ? 例子居中效果都如下圖:

注:當把div 換成其他塊級元素,如<p>或<h1>~<h6>時,以下方法仍然奏效。但當把div換成行內元素,如<span>時,第4種方法將失效。?

? ? ? ?1、彈性布局 設置容器項目在橫軸和縱軸上都居中對齊

<style>.container{height: 200px;width: 200px;border: 1px solid black;background-color: aliceblue;display: flex;justify-content: center;align-items: center;}
</style>

????????

????????2、使用 table-cell 顯示????????

????????????????使用 table-cell 可以實現 div 中文字的垂直居中,然后在使用text-align: center可實現水平居中

<style>.container{height: 200px;width: 200px;border: 1px solid black;background-color: aliceblue;display: table-cell;vertical-align: middle;text-align: center;}	
</style>

?????????3、使用 Grid 布局

????????????????display: grid + place-items: center

<style>.container{height: 200px;width: 200px;border: 1px solid black;background-color: aliceblue;display: grid;place-items: center;}	
</style>

????????? 4、使用 line-height

????????????????設置line-height的值和為div的height值,實現垂直居中,使用text-align實現水平居中。該方法只能使用于單行文本,如文本超過單行,文字將會溢出。且該方法不適用于span等行內元素

<style>.container{height: 200px;width: 200px;border: 1px solid black;background-color: aliceblue;text-align: center;line-height: 200px;}	
</style>

? ? ? ? ????????當多行文字時,如下:

<body><div class="container">文字居中顯示文字居中顯示文字居中顯示</div>
</body>

? ? ? ? 當用該方法用于span等行內元素時:為span設置的寬高將失效,因為默認情況下,行內元素無法設置寬度和高度,其寬度和高度都是由它們所包含的內容決定的。有關html塊級元素、行內元素、行內塊級元素的說明請看該篇博文:HTML 塊級元素、行內元素和行內塊級元素

<body><span class="container">文字居中顯示</span>
</body>

? ? ? ? 要想讓span等行內元素也實現div的效果,使用display:block 或?display:inline-block 即可

<style>.container{height: 200px;width: 200px;border: 1px solid black;background-color: aliceblue;display: block;            /* 把span顯示變成塊級元素 */text-align: center;line-height: 200px;}	
</style>

? ? ? ? 5、使用 text-align: center + padding? ?

? ? ? ? ? ? ? ?使用?text-align: center 可使文字水平居中,當沒有固定高度時,使用 padding-top 和?padding-bottom 相同高度即可實現垂直居中。當要求固定高度時,先看文字的高度,然后再計算出??padding-top 和?padding-bottom 相同的高度也能實現垂直居中

<style>/* 不限定高度時,container 不設置 height 屬性值使用 text-align: center + padding-top、padding-bottom 相同高度*/.container{width: 200px;border: 1px solid black;background-color: aliceblue;text-align: center;padding-top:50px;padding-bottom:50px;}
</style>

<style>/*  限定高度時(如div總高度限定 200px),container 不設置 height 屬性值使用 text-align: center + padding-top、padding-bottom 要根據div高度減去文字高度再平分剩余的高度假如文字高度占20px,那么padding-top、padding-bottom 都是90px*/.container{width: 200px;border: 1px solid black;background-color: aliceblue;text-align: center;padding-top:90px;padding-bottom:90px;}
</style>

  • ?組合上篇 div找那個元素居中和本篇html元素居中的方法綜合實現子div在父div中居中顯示并且子div中的文字居中

<head><meta charset="utf-8" /><title></title><style>.container{height: 300px;width: 300px;border: 1px solid black;background-color: aliceblue;display: flex;justify-content: center;align-items: center;}.box{width: 150px;height: 150px;background: #55a9ff;display: flex;justify-content: center;align-items: center;}</style></head>
<body><div class="container"><div class="box">文字居中顯示</div></div>
</body>

? ? ? ? 注:box 中可使用上述第1,第3,第4,第5種方法實現組合文字居中,第2種display: table-cell講失效?

以上方法如有錯誤請各位不吝指教,如以后有別的方法將會往下繼續添加,各位有其他方法可留言告知。

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

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

相關文章

WebAPIs 第二天

DOM事件基礎 事件監聽事件類型事件對象 一.事件監聽 ① 概念&#xff1a;就是讓程序檢測是否有事件發生&#xff0c;一旦有事件觸發&#xff0c;就立即調用一個函數做出響應&#xff0c;也成為綁定事件或者注冊事件 ② 語法&#xff1a;元素對象.addEventListener(事件類型&…

機器學習---對數幾率回歸

1. 邏輯回歸 邏輯回歸&#xff08;Logistic Regression&#xff09;的模型是一個非線性模型&#xff0c; sigmoid函數&#xff0c;又稱邏輯回歸函數。但是它本質上又是一個線性回歸模型&#xff0c;因為除去sigmoid映射函 數關系&#xff0c;其他的步驟&#xff0c;算法都是…

從零開始,貪吃蛇小游戲系列專欄完美收官!

&#x1f3ae; 從零開始&#xff0c;貪吃蛇小游戲系列專欄完美收官&#xff01; &#x1f40d; 各位游戲開發探索者們&#xff0c;大家好&#xff01;我是[億元程序員]&#xff0c;一位擁有8年游戲開發經驗的主程。經過一段時間的努力&#xff0c;我很高興地宣布&#xff0c;我…

阿里云預裝LAMP應用導致MySQL不顯示訪問密碼如何解決

&#x1f600;前言 本篇博文是關于阿里云云服務器ECS部署MySQL過程中出現的一下坑&#xff0c;希望能夠幫助到您&#x1f60a; &#x1f3e0;個人主頁&#xff1a;晨犀主頁 &#x1f9d1;個人簡介&#xff1a;大家好&#xff0c;我是晨犀&#xff0c;希望我的文章可以幫助到大家…

SUB-1G SOC芯片DP4306F 32 位 ARM Cortex-M0+內核替代CMT2380F32

DP4306F是一款高性能低功耗的單片集成收發機&#xff0c;集成MO核MCU&#xff0c;工作頻率可覆蓋200MHiz^ 1000MHz。 支持230/408/433/470/868/915頻段。該芯片集成了射頻接收器、射頻發射器、頻率綜合器、GFSK調制器、GFSK解調器等功能模塊。通過SPI接口可以對輸出功率、頻道選…

gitlab-Runner搭建

root wget https://packages.gitlab.com/runner/gitlab-runner/packages/fedora/29/gitlab-runner-12.6.0-1.x86_64.rpm/download.rpm rpm -ivh download.rpm ---- 安裝 rpm -Uvh download.rpm -----更新升級 然后運行&#xff1a; gitlab-runner register --url https://git…

RabbitMQ相關面試題

用到了哪些MQ?什么使用場景?MQ的組成部分?MQ宕機了怎么辦?如何進行持久化的? MQ的選型? Kafka:高吞吐量、低延遲的分布式消息隊列,主要用于大規模數據處理和流式處理 RocketMQ:RocketMQ是阿里巴巴開源的分布式消息隊列,具有高吞吐量、低延遲、高可靠性等特點 RabbitM…

【Go 基礎篇】Go語言浮點類型:探索浮點數的特點與應用

介紹 浮點數是計算機編程中用于表示實數的一種數據類型&#xff0c;用于處理具有小數部分的數值。Go語言&#xff08;Golang&#xff09;提供了兩種主要的浮點數類型&#xff1a;float32和float64&#xff0c;分別用于單精度和雙精度浮點數的表示。本篇博客將深入探討Go語言中…

38 | 浦發銀行股票分析案例

本文將通過一個浦發銀行股票分析案例,探討如何從多個維度對股票進行分析,包括基本面、技術面和市場環境等因素。我們將深入挖掘浦發銀行的財務數據、業務模式以及市場定位,以了解其內在價值和潛在風險。同時,我們還將考察技術面的指標,如價格走勢、均線形態等,以揭示市場…

linux 命令--常用關機命令

1.使用shutdown命令 shutdown命令是Linux系統下最常用的關機命令之一。它可以讓系統在指定時間內進行關機或者重啟操作。例如&#xff0c;下面的命令可以讓系統在5分鐘后進行關機操作&#xff1a; sudo shutdown -h5其中&#xff0c;“-h”表示關機&#xff0c;“5”表示5分鐘…

ThinkPHP8命名規范-ThinkPHP8知識詳解

本文主要講解thinkphp8的命名規范&#xff0c;主要包括&#xff1a;遵循PHP自身的PSR-2命名規范和PSR-4自動加載規范、目錄和文件命名規范、函數和類、屬性命名規范、常量和配置命名規范、數據表和字段命名規范、不能使用PHP保留字。 在使用thinkphp8開發項目之前&#xff0c;…

C#使用OpenCv(OpenCVSharp)圖像全局二值化處理實例

本文實例演示C#語言中如何使用OpenCv(OpenCVSharp)對圖像進行全局二值化處理。 目錄 圖像二值化原理 函數原型 參數說明 實例 效果 圖像二值化原理

線程轉換狀態,傻傻分不清等待和阻塞嗎?你還在暴力的停止線程嗎?

線程切換 線程創建之后&#xff0c;調用start()方法開始運行。當線程執行wait()方法之后&#xff0c;線程進入等待狀態。進入等待狀態的線程需要依靠其他線程的通知才能夠返回到運行狀態&#xff0c;而超時等待狀態相當于在等待狀態的基礎上增加了超時限制&#xff0c;也就是超…

騰訊云服務器競價實例是什么?適用于什么行業?有啥優惠?

騰訊云服務器CVM計費模式分為包年包月、按量計費和競價實例&#xff0c;什么是競價實例&#xff1f;競價實例和按量付費相類似&#xff0c;優勢是價格更劃算&#xff0c;缺點是云服務器實例有被自動釋放風險&#xff0c;騰訊云服務器網來詳細說下什么是競價實例&#xff1f;以及…

GUI、多線程編程、網絡編程簡介

GUI、多線程編程、網絡編程簡介 文章目錄 GUI簡介什么是GUIGUI有什么用使用方法 多線程編程什么是多線程編程多線程編程有什么用提高程序的響應能力提高程序的性能實現異步編程并發數據訪問和共享資源實現復雜的算法和任務分解 進行多線程編程的步驟 網絡編程什么是網絡編程網絡…

JMeter處理接口簽名之BeanShell實現MD5加密

項目A需要給項目B提供一個接口&#xff0c;這個接口加密了&#xff0c;現在需要測試這個接口&#xff0c;需要怎么編寫腳本呢&#xff1f;實現接口簽名的方式有兩種&#xff1a;BeanShell實現MD5加密和函數助手實現MD5加密&#xff0c;之前已經分享過了函數助手實現MD5加密&…

React如何配置env環境變量

React版本&#xff1a; "react": "^18.2.0" 1、在package.json平級目錄下創建.env文件 2、在‘.env’文件里配置環境變量 【1】PUBLIC_URL 描述&#xff1a;編譯時文件的base-href 官方描述&#xff1a; // We use PUBLIC_URL environment variable …

從KM到Cure Models:常用生存分析方法的優缺點

一、引言 生存分析是一種用于研究個體生命長度或事件發生時間的統計方法。在許多領域中&#xff0c;如醫學、社會學、經濟學和工程學等&#xff0c;生存分析被廣泛應用于分析個體的生存時間&#xff0c;并研究相關因素對生存時間的影響。通過生存分析&#xff0c;我們可以評估特…

交換排序——選擇排序和冒泡排序的區別是什么?

今天重溫一下算法&#xff0c;其實剛開始我覺得冒泡排序和選擇排序是一樣的&#xff0c;因為他們排序過程中都是通過相鄰的數據比較找到最小/最大的數據&#xff0c;通過不斷思考和學習才明白&#xff0c;兩者還是有區別的。 冒泡排序 概念 冒泡排序(Bubble Sort)&#xff0…

SpringBoot使用thymeleaf模版引擎配置自定義錯誤頁面

1、要在Spring Boot項目中配置自定義的錯誤頁面&#xff0c;你可以遵循以下步驟&#xff1a; 1.1、pom.xml引入thymeleaf <dependency><groupId>org.springframework.boot</groupId><artifactId>spring-boot-starter-thymeleaf</artifactId><…