純css實現-讓字符串在文字少時顯示為居中對齊,而在文字多時顯示為左對齊

純css實現-讓字符串在文字少時顯示為居中對齊,而在文字多時顯示為左對齊

使用flex實現

思路

  1. 容器樣式(.container):

    • Flex容器的BFC性質使得其內部的子元素(.text-box)在水平方向上能夠居中,通過justify-content: center;實現。
  2. 文本框樣式(.text-box): BFC阻止了文本框從Flex容器中溢出,確保文本框的背景顏色不會延伸到Flex容器之外。

在文本少時,子元素寬度等于文本長度,但父容器讓其居中,就表現出子元素中文本是居中的。
而文本多時,子元素寬度等于容器長度,雖然父容器也讓子元素居中,子元素也在父容器中居中了。不過子元素中文本向左對齊,于是用戶看到的就是子元素文本的向左對齊的表現形式。

源碼

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><style>.container {display: flex;justify-content: center;margin: 10px 10%;background-color: blue;}.text-box {background-color: red;}</style></head><body><div class="container"><div class="text-box">文字少-居中對齊,文字多-左對齊|</div></div><div class="container"><div class="text-box">文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|</div></div></body>
</html>

使用flex實現

使用text-align實現

思路

  1. 容器樣式(.container):

    • 使用 text-align: center; 將容器內的文本內容在水平方向上居中對齊。
  2. 文本框樣式(.text-box):

    • 使用 display: inline-block; 將文本框設置為內聯塊,使其在容器中水平居中。
    • 設置文本框的文本對齊方式為左對齊,通過 text-align: left; 實現。

在文本少時,子元素寬度等于文本長度,但父容器讓其居中,就表現出子元素中文本是居中的。
而文本多時,子元素寬度等于容器長度,雖然父容器也讓子元素居中,子元素也在父容器中居中了。不過子元素中文本向左對齊,于是用戶看到的就是子元素文本的向左對齊的表現形式。

源碼

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><style>.container {text-align: center;background: skyblue;margin: 10px 10%;}.text-box {display: inline-block;text-align: left;background: yellow;}</style></head><body><div class="container"><div class="text-box">文字少-居中對齊,文字多-左對齊|</div></div><div class="container"><div class="text-box">文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|</div></div></body>
</html>

使用text-align實現

使用table布局實現

思路

  1. 文本框樣式(.text-box):

    • 使用 display: table; 屬性將容器元素設為表格布局,使其具備表格的一些特性。
    • 設置 margin: 10px auto; 來實現水平方向上的居中效果。
  2. 文本內容樣式(.text-content):

    • 使用 display: table-cell; 屬性使文本內容元素具備表格單元格的特性,可以讓其在垂直方向上撐滿整個父元素。

通過這些樣式的組合,實現了兩個不同大小的文本框,其中文本內容在第一個文本框中單行顯示并在水平方向上居中,而在第二個文本框中,文本內容可以多行顯示,仍然在水平方向上保持居中。表格布局的使用在這里能夠提供一些表格特性,同時 table-cell 元素的特性確保了垂直方向上的撐滿效果-撐滿時就是向左對齊的效果。

源碼

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><style>.text-box {display: table;margin: 10px auto;background: skyblue;}.text-content {display: table-cell;background: red;}</style></head><body><div class="text-box"><div class="text-content"><p>文字少-居中對齊,文字多-左對齊|</p></div></div><div class="text-box"><div class="text-content"><p>文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|</p></div></div></body>
</html>

使用table布局實現

使用bfc實現

思路

  1. 容器樣式(.container):正常的塊級元素,內部是正常的塊級作用域。

  2. 文本框樣式(.text-box):

    • width: fit-content;讓子元素有了一個與文本大小的寬度。
    • margin: 0px auto;通過BFC讓其可以水平居中。

在文本少時,子元素寬度等于文本長度,但父容器讓其居中,就表現出子元素中文本是居中的。
而文本多時,子元素寬度等于容器長度,雖然父容器也讓子元素居中,子元素也在父容器中居中了。不過子元素中文本向左對齊,于是用戶看到的就是子元素文本的向左對齊的表現形式。

源碼

<!DOCTYPE html>
<html lang="en"><head><meta charset="UTF-8" /><meta name="viewport" content="width=device-width, initial-scale=1.0" /><style>.container {background-color: blue;margin: 10px 0px 0px 0px;}.text-box {margin: 0px auto;width: fit-content;background-color: red;}</style></head><body><div class="container"><div class="text-box">文字少-居中對齊,文字多-左對齊|</div></div><div class="container"><div class="text-box">文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|文字少-居中對齊,文字多-左對齊|</div></div></body>
</html>

使用bfc實現

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

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

相關文章

生態環境數據分析新篇章:Meta分析、R語言、Matlab、貝葉斯、結構方程模型等的前沿實踐

目錄 ①Meta分析在生態環境領域里的應用 ②R語言在生態環境領域中的應用 ③MATLAB在生態環境數據處理與分析中的應用 ④基于R語言piecewiseSEM結構方程模型在生態環境應用 ⑤R語言貝葉斯方法在生態環境領域中的高階技術應用 更多應用 為了Meta分析問題的設計、基礎理論、…

【菜鳥入門!】Matlab零基礎快速入門教程

數學建模競賽中&#xff0c;編程軟件是必不可缺少的&#xff0c;比如大家都熟知的MATLAB多數同學們都會經常用到&#xff0c;今天給大家介紹一些MATLAB的基本元素&#xff0c;希望幫助大家更好的掌握編寫基本的函數&#xff01; 變量和數組 MATLAB 程序的基本數據單元是數組。一…

rm刪除未釋放空間,linux sync有時不起作用

此時需要重啟系統即可. Linux中的sync命令用于將文件系統的緩沖區數據立即寫入磁盤&#xff0c;以確保數據的持久性。123456 sync命令沒有任何選項&#xff0c;簡單執行即可。它會將文件系統緩沖區中的數據寫入磁盤&#xff0c;并更新文件系統的超級塊及其他元數據。使用sync命…

Vue.js的雙向綁定原理

Vue的雙向綁定 vue雙向綁定是其最重要的核心亮點&#xff0c;其原理也很簡單&#xff0c;這里做個簡單總結 vue2的雙向綁定是利用的Object.definePropertyvue3的雙向綁定是利用的 ES6Porxy中的defineProperty(target, propKey, propDesc 其作用類似于Object.defineProperty …

您想要擁有 Apple Vision Pro 的原因

自從2024年2月2日Apple Vision Pro發布以來&#xff0c;網上已經有很多關于如何使用這款蘋果最新設備的示例。該平臺引入的空間計算新世界能夠完成許多在其他設備上無法完成的事情。Reddit 上的這個人能夠以 51202160 的分辨率從他的 PC 上串流游戲&#xff01;在本文中&#x…

SpringMVC01、回顧MVC

1、回顧MVC 1.1、什么是MVC MVC是模型(Model)、視圖(View)、控制器(Controller)的簡寫&#xff0c;是一種軟件設計規范。是將業務邏輯、數據、顯示分離的方法來組織代碼。MVC主要作用是降低了視圖與業務邏輯間的雙向偶合。MVC不是一種設計模式&#xff0c;MVC是一種架構模式。…

Docker部署前后端服務示例

使用Docker部署js前端 1.創建Dockerfile 在項目跟目錄下創建Dockerfile文件&#xff1a; # 使用nginx作為基礎鏡像 FROM nginx:1.19.1# 指定工作空間 WORKDIR /data/web# 將 yarn build 打包后的build文件夾添加到工作空間 ADD build build# 將項目必要文件添加到工作空間&a…

數據結構—>帶你深入了解單鏈表(基礎篇)

?作者簡介&#xff1a;大家好&#xff0c;我是橘橙黃又青&#xff0c;一個想要與大家共同進步的男人&#x1f609;&#x1f609; &#x1f34e;個人主頁&#xff1a;橘橙黃又青-CSDN博客 前面我們學習了順序表&#xff0c;今天我們來學習與順序表類似的單鏈表 1.&#x1f3…

鴻蒙Harmony應用開發—ArkTS聲明式開發(通用屬性:透明度設置)

設置組件的透明度。 說明&#xff1a; 從API Version 7開始支持。后續版本如有新增內容&#xff0c;則采用上角標單獨標記該內容的起始版本。 opacity opacity(value: number | Resource) 設置組件的不透明度。 卡片能力&#xff1a; 從API version 9開始&#xff0c;該接口…

香橙派AIpro快速上手指南

1 前言 作為業界首款基于昇騰深度研發的AI開發板&#xff0c;Orange Pi AIpro無論在外觀上、性能上還是技術服務支持上都非常優秀&#xff0c;其8/20TOPS澎湃算力是目前開發板市場中所具備的最大算力&#xff0c;能覆蓋生態開發板者的主流應用場景&#xff0c;讓用戶實踐各種創…

深入理解Redis中的漸進式Rehash技術

1. 引言 Redis是一款高性能的鍵值存儲系統,被廣泛應用于緩存、隊列、計數器等場景,因其快速、穩定的特性備受開發者青睞。在Redis的背后,有著許多復雜的數據結構和算法支撐著其高效運行,而其中之一就是Rehash操作。 Rehash是Redis中的一個關鍵操作,負責在數據量增加時對…

Web自動化測試平臺開發---Automated_platform

一、項目簡介 歷時一個假期&#xff0c;Automated_platform 第一版完工&#xff0c;是一款基于po模式的自動化測試平臺,采用后端技術為DjangoceleryRabbitMQmysql 配置mysql數據庫&#xff0c;進行數據遷移后&#xff0c;運行項目后&#xff0c;即可成功訪問http://127.0.0.1:8…

5. 升級 Spring Boot(Upgrading Spring Boot)

5. 升級 Spring Boot&#xff08;Upgrading Spring Boot&#xff09; 項目 wiki 提供如何從 Spring Boot 早期版本升級的說明。請按照 release notes 部分查找要升級到的版本。 升級說明總是版本說明的第一部分。如果您的版本落后一個以上&#xff0c;請確保您已經查看了所跳…

【軟考】數據結構之隊列和棧

目錄 1.例題一1.1題目1.2 題目截圖1.3 題目分析 1.例題一 1.1題目 輸出受限的雙端隊列是指元素可以從隊列的兩端輸入&#xff0c;但只能從隊列的一端輸出&#xff0c;如下圖所示&#xff0c;若有e1&#xff0c;e2&#xff0c;e3&#xff0c;e4依次進入輸出受限的雙端隊列&…

Nginx-location匹配規則

每次配置Nginx的時候&#xff0c;不是多個這匹配不上就是那匹配不上&#xff0c;多個斜線少個斜線的&#xff0c;然后頭疼&#xff0c;尤其多層代理之后&#xff0c;真是瘋狂掉頭發 #mermaid-svg-Z1ScpZFefeixtnn3 {font-family:"trebuchet ms",verdana,arial,sans-s…

Linux——進程控制(一)進程的創建與退出

目錄 一、進程創建 1.寫時拷貝 2.創建多個進程 二、進程終止 1.main函數的返回值 2.bash中的$? 3.自定義退出碼 4.C語言的錯誤碼 5.錯誤碼與退出碼的區別 6.代碼異常終止 7.exit函數 8.總結 一、進程創建 在之前&#xff0c;我們學過linux中的非常重要的函數——…

Git 將dev1.0分支的某些commit合并到dev分支上

前言&#xff1a;dev1.0是新開發的需求內容&#xff0c;但是部分熱更內容在此分支提交&#xff0c;如今需要把熱更的內容發到dev環境&#xff0c;但是dev1.0新需求未開發完畢&#xff0c;不可更新到dev環境。 現在在dev1.0分支 git pull #拉取當前分支最新內容git log #查看最…

3. 文字陰影

<!DOCTYPE html> <html lang"en"><head><meta charset"UTF-8" /><meta name"viewport" content"widthdevice-width, initial-scale1.0" /><title>文字陰影</title><style>*{margin: …

速賣通店鋪營銷秘籍:如何巧妙運用活動提升轉化率

對于速賣通賣家而言&#xff0c;想要提升店鋪的成交率&#xff0c;除了依賴付費推廣外&#xff0c;更重要的是如何通過店鋪營銷來吸引和留住潛在買家。今天&#xff0c;我們就來深入探討一下速賣通店鋪營銷的幾個關鍵策略。 首先&#xff0c;我們要明確一點&#xff0c;速賣通平…

IDEA中的Structure模塊使用詳解

IDEA中的Structure模塊使用詳解 類方法的展示 從左往右介紹&#xff1a; 1、最開頭的 m 標識是表示為方法&#xff0c;如出現 f 標識則表示為屬性&#xff1b; 2、m后面跟著的是方法或者屬性的訪問修飾符&#xff1a; #紅色關閉的鎖表示為private&#xff1b; #圓圈表示不帶…