從零開始學習html(十五)css樣式設置小技巧——上

来源:http://www.cnblogs.com/guxinglang/archive/2017/05/22/6816037.html
-Advertisement-
Play Games

一、水平居中設置-行內元素 1 <!DOCTYPE HTML> 2 <html> 3 <head> 4 <meta charset="utf-8"> 5 <title>定寬塊狀元素水平居中</title> 6 <style> 7 div{ 8 border:1px solid red; 9 marg ...


一、水平居中設置-行內元素

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>定寬塊狀元素水平居中</title>
 6 <style>
 7 div{
 8     border:1px solid red;
 9     margin:20px;
10 }
11 .txtCenter{
12     text-align:center;
13 }
14 
15 </style>
16 </head>
17 
18 <body>
19 <div class="txtCenter">我想要在父容器中水平居中顯示。</div>
20 
21 <!--下麵是任務部分-->
22 
23 <div class="imgCenter"><img src="http://img.mukewang.com/52da54ed0001ecfa04120172.jpg" /></div>
24 </body>
25 </html>
水平居中設置-行內元素

我們在實際工作中常會遇到需要設置水平居中的場景,比如為了美觀,文章的標題一般都是水平居中顯示的。

 

這裡我們又得分兩種情況:行內元素 還是 塊狀元素 ,塊狀元素裡面又分為定寬塊狀元素,以及不定寬塊狀元素。

 

我們先來瞭解一下行內元素怎麼進行水平居中?

 

如果被設置元素為文本、圖片等行內元素時,水平居中是通過給父元素設置 text-align:center 來實現的。

 

(父元素和子元素:如下麵的html代碼中,div是“我想要在父容器中水平居中顯示”這個文本的父元素。反之這個文本是div的子元素 )如下代碼:

 

html代碼:

<body>
  <div class="txtCenter">我想要在父容器中水平居中顯示。</div>
</body>

css代碼:

<style>
  .txtCenter{
    text-align:center;
  }
</style>

 

任務

來試試:把圖片設置為水平居中顯示。

 

 

參考代碼:

div.imgCenter{

text-align:center;

}

 

二、水平居中設置-定寬塊狀元素

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta http-equiv="Content-Type" content="text/html; charset=utf-8">
 5 <title>定寬塊狀元素水平居中</title>
 6 <style>
 7 div{
 8     border:1px solid red;
 9     
10     width:200px;
11     margin:20px auto;
12 }
13 
14 </style>
15 </head>
16 
17 <body>
18 <div>我是定寬塊狀元素,我要水平居中顯示。</div>
19 </body>
20 </html>
水平居中設置-定寬塊狀元素

當被設置元素為 塊狀元素 時用 text-align:center 就不起作用了,這時也分兩種情況:定寬塊狀元素和不定寬塊狀元素。

 

這一小節我們先來講一講定寬塊狀元素。(定寬塊狀元素:塊狀元素的寬度width為固定值。)

 

滿足定寬和塊狀兩個條件的元素是可以通過設置“左右margin”值為“auto”來實現居中的。我們來看個例子就是設置 div 這個塊狀元素水平居中:

html代碼:

<body>
  <div>我是定寬塊狀元素,哈哈,我要水平居中顯示。</div>
</body>

css代碼:

<style>
div{
    border:1px solid red;/*為了顯示居中效果明顯為 div 設置了邊框*/
    
    width:200px;/*定寬*/
    margin:20px auto;/* margin-left 與 margin-right 設置為 auto */
}

</style>

也可以寫成:

margin-left:auto;
margin-right:auto;

註意:元素的“上下 margin” 是可以隨意設置的。

 

任務

試試看:這種水平居中的方法兩個2個條件缺一不可,不信?

 

你可以嘗試把例子中的 width:200px 刪除,還它是否還可以居中顯示。

 
因為DIV塊元素本身就沒有寬度,高度,它是個容器,可以無限放大,無限縮小。因為,如果沒有寬度,那麼居中就沒有任何意義樓。   水平居中分為:塊狀元素和行內元素居中兩種,行內元素用text-align:center;塊狀元素用:margin:0 auto;  

三、水平居中總結-不定寬塊狀元素方法(一)

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>不定寬塊狀元素水平居中</title>
 6 <style>
 7 table{
 8     margin:0 auto;
 9 }
10 
11 /*下麵是任務區代碼*/
12 .wrap{
13     background:#ccc;
14 }
15 </style>
16 </head>
17 
18 <body>
19 <div>
20 <table>
21   <tbody>
22     <tr><td>
23     <ul>
24         <li>我是第一行文本</li>
25         <li>我是第二行文本</li>
26         <li>我是第三行文本</li>
27     </ul>
28     </td></tr>
29   </tbody>
30 </table>
31 </div>
32 
33 <div class="wrap">
34   設置我所在的div容器水平居中  
35 </div>
36 </body>
37 </html>
水平居中總結-不定寬塊狀元素方法(一)

在實際工作中我們會遇到需要為“不定寬度的塊狀元素”設置居中,比如網頁上的分頁導航,因為分頁的數量是不確定的,

 

所以我們不能通過設置寬度來限制它的彈性。(不定寬塊狀元素:塊狀元素的寬度width不固定。)

 

不定寬度的塊狀元素有三種方法居中(這三種方法目前使用的都很多):

  1. 加入 table 標簽
  2. 設置 display: inline 方法:與第一種類似,顯示類型設為 行內元素,進行不定寬元素的屬性設置
  3. 設置 position:relative 和 left:50%:利用 相對定位 的方式,將元素向左偏移 50% ,即達到居中的目的

我們來講一下第一種方法:

為什麼選擇方法一加入table標簽? 是利用table標簽的長度自適應性---即不定義其長度也不預設父元素body的長度(table其長度根據其內文本長度決定),

 

因此可以看做一個定寬度塊元素,然後再利用定寬度塊狀居中的margin的方法,使其水平居中。

 

第一步:為需要設置的居中的元素外面加入一個 table 標簽 ( 包括 <tbody>、<tr>、<td> )。

第二步:為這個 table 設置“左右 margin 居中”(這個和定寬塊狀元素的方法一樣)。

舉例如下:

html代碼:

<div>
 <table>
  <tbody>
    <tr><td>
    <ul>
        <li>我是第一行文本</li>
        <li>我是第二行文本</li>
        <li>我是第三行文本</li>
    </ul>
    </td></tr>
  </tbody>
 </table>
</div>

css代碼:

<style>
table{
    border:1px solid;
    margin:0 auto;
}
</style>

 

任務

來試試:補充代碼實現右側中的 class 為 wrap 的 div 水平居中顯示(要註意是這個 div元素 居中,而不是裡面的文本居中啊)。

 

四、水平居中總結-不定寬塊狀元素方法(二)

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>不定寬塊狀元素水平居中</title>
 6 <style>
 7 .container{text-align:center;}
 8 .container ul{list-style:none;margin:0;padding:0;display:inline;}
 9 .container li{margin-right:8px;display:inline;}
10 </style>
11 </head>
12 
13 <body>
14 <div class="container">
15     <ul>
16         <li><a href="#">1</a></li>
17         <li><a href="#">2</a></li>
18         <li><a href="#">3</a></li>
19     </ul>
20 </div>
21 </body>
22 </html>
水平居中總結-不定寬塊狀元素方法(二)

除了上一節講到的插入table標簽,可以使不定寬塊狀元素水平居中之外,第2種實現這種效果的方法,改變元素的display類型為行內元素,利用其屬性直接設置。

 

第二種方法:改變塊級元素的 display 為 inline 類型(設置為 行內元素 顯示),然後使用 text-align:center 來實現居中效果。如下例子:

html代碼:

<body>
<div class="container">
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</div>
</body>

css代碼:

<style>
.container{
    text-align:center;
}
/* margin:0;padding:0(消除文本與div邊框之間的間隙)*/
.container ul{
    list-style:none;
    margin:0;
    padding:0;
    display:inline;
}
/* margin-right:8px(設置li文本之間的間隔)*/
.container li{
    margin-right:8px;
    display:inline;
}
</style>

這種方法相比第一種方法的優勢是不用增加無語義標簽,但也存在著一些問題:它將塊狀元素的 display 類型改為 inline,變成了行內元素,所以少了一些功能,比如設定長度值。

 

 

五、水平居中總結-不定寬塊狀元素方法(三)

 1 <!DOCTYPE HTML>
 2 <html>
 3 <head>
 4 <meta charset="utf-8">
 5 <title>不定寬塊狀元素水平居中</title>
 6 <style>
 7 .container{
 8     float:left;
 9     position:relative;
10     left:50%
11 }
12 
13 .container ul{
14     list-style:none;
15     margin:0;
16     padding:0;
17     
18     position:relative;
19     left:-50%;
20 }
21 .container li{float:left;display:inline;margin-right:8px;}
22 
23 
24 /*下麵是代碼任務區*/
25 
26 .wrap-center{
27     background:#ccc;
28     
29     
30 }
31 </style>
32 </head>
33 
34 <body>
35 <div class="container">
36     <ul>
37         <li><a href="#">1</a></li>
38         <li><a href="#">2</a></li>
39         <li><a href="#">3</a></li>
40     </ul>
41 </div>
42 
43 <!--下麵是代碼任務區-->
44 <div class="wrap">
45     <div class="wrap-center">我們來學習一下這種方法。</div>
46 </div>
47 </body>
48 </html>
水平居中總結-不定寬塊狀元素方法(三)

除了前兩節講到的插入table標簽,以及改變元素的display類型,可以使不定寬塊狀元素水平居中之外,第3種實現這種效果的方法,設置浮動和相對定位來實現。

 

方法三:通過給父元素設置 float,然後給父元素設置 position:relative 和 left:50%,子元素設置 position:relative 和 left: -50% 來實現水平居中。

 

我們可以這樣理解:假想ul層的父層(即下麵例子中的div層)中間有條平分線將ul層的父層(div層)平均分為兩份,

 

ul層的css代碼是將ul層的最左端與ul層的父層(div層)的平分線對齊;

 

而li層的css代碼則是將li層的平分線與ul層的最左端(也是div層的平分線)對齊,從而實現li層的居中。

 

代碼如下:

<body>
<div class="container">
    <ul>
        <li><a href="#">1</a></li>
        <li><a href="#">2</a></li>
        <li><a href="#">3</a></li>
    </ul>
</div>
</body>

css代碼:

<style>
.container{
    float:left;
    position:relative;
    left:50%
}

.container ul{
    list-style:none;
    margin:0;
    padding:0;
    
    position:relative;
    left:-50%;
}
.container li{float:left;display:inline;margin-right:8px;}
</style>

 

這三種方法使用得都非常廣泛,各有優缺點,具體選用哪種方法,可以視具體情況而定。

任務

來試試:添加代碼為任務區中的 class 為 wrap-center 的div設置水平居中。

 

 

 

這裡面很重要的一個點就是父元素設置了float,float中有一個很重要的特性——“設置了float的元素,會生成塊級框”;步驟如下:
1. 父元素position: relative; left: 50%;——父元素的左邊線與屏幕的中心線對齊
2. 父元素float——使得父元素生成了塊級框,也就是使得父元素的寬度 = 子元素的寬度,如果沒有float,則父元素的寬度還是屏幕的寬度
3. ·子元素position:relative; left:-50%;註意:left是相對於父元素的寬度進行偏移的,而此時父元素的寬度=子元素的寬度;實現居中  

 

/*text-align:center(文本居中)*/
/*list-style:none(消除li圓點)     margin:0;padding:0(消除文本與div邊框之間的間隙   display:inline(變成行內元素,也就是把ul文本列變成行。另外從border來看未設置inline之前寬度是無限的,設置後寬度變為隨文本寬度)*/
/*margin-right:8px(設置li文本之間的間隔) display:inline(變成行內元素,也就是把li文本列變成行*/  
  沒看懂
您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 工作中接到新項目,開發前都需要先規劃項目目錄,然後一個個創建文件,搭建sass編譯環境,下載jquery,Swiper等類庫... 這些準備工作都要花上不少時間。每做一個項目,都會遇到同樣的問題,再重覆一遍嗎? 是時候做點改變了:編寫自己的cli工具,一行命令,3秒鐘進入coding狀態! 本文以自 ...
  • JavaWeb一--瀏覽器技術 一、HTTP協議 1.1 HTTP定義 HTTP(Hypertext Transport Protocol),超文本傳輸協議。 一種詳細規定了瀏覽器和web伺服器之間互相通信的規則,通過網際網路傳送萬維網文檔的數據傳送協議。 1.2 協議原理 1.3 請求格式 * 第一 ...
  • 項目的需要,要整一個視頻直播,但又不想在其他平臺那種直播室盜鏈展示,那我就直接用播放器來實現rtmp流媒體伺服器推流吧!沒廢話,走起 1.你要有一個媒體伺服器,暫時用【盤古雲】,這個還好,算是不錯的平臺了。註冊就能用,貌似免費的一樣,哈哈不管那麼多先搭建一個,看圖: 圖解:【1】菜單,進入創建一個媒 ...
  • 昨天,我接到的公司老司機的命令,要求我完成一個萬年曆,目的是想通過日曆來利用ajax顯示報名信息。平時不怎麼重視日曆的我遇到了很多麻煩,幸好在公司的一臺機器上找到了問題解決的思路。雖然不知道這位sir是誰,但是我還是要感謝他,他的思路讓我明白了什麼是閏年,什麼是小月大月,跳轉月份的規則...總之,如 ...
  • 左圖為本博客右側截取的GIF圖,右圖為代碼效果 HTML: css: JS: 此效果主要通過間隔取兩數之間的隨機數來改變標簽的樣式。 ...
  • 通常我們設置元素的寬和高樣式經常會出現一些問題,比如以下css的設置: 比如以下的代碼: 實際上我們期望的結果可能是這樣: 但是實際上是這樣的: 因為我們實際的寬度和高度是這樣計算出來的: width(寬) + padding(內邊距) + border(邊框) = 元素實際寬度 height(高) ...
  • 文檔對象模型(Document Object Model,DOM)是使用 W3C 定義的 API (Application Program Interface) 來操作 HTML 文檔 (此處不局限於 HTML,亦可操作 XHTML、XML 等),使用戶可以與進行頁面交互。 它使用對象的表示方式來表 ...
  • 在JavaScript中,回調函數具體的定義為:函數A作為參數(函數引用)傳遞到另一個函數B中,並且這個函數B執行函數A。我們就說函數A叫做回調函數。如果沒有名稱(函數表達式),就叫做匿名回調函數。 callback 不一定用於非同步,一般同步(阻塞)的場景下也經常用到回調,比如要求執行某些操作後執行 ...
一周排行
    -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.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...