首頁  >  文章  >  web前端  >  【CSS筆記十】CSS樣式設定小技巧

【CSS筆記十】CSS樣式設定小技巧

黄舟
黄舟原創
2016-12-29 14:02:291073瀏覽

一、水平居中設定:行內元素 
我們常會在實際工作中遇到需要設定水平居中的場景,例如為了美觀,文章的標題一般都是水平居中顯示的。

這裡我們又得分兩種情況:行內元素 還是 塊狀元素 ,塊狀元素裡面又分為定寬塊狀元素,以及不定寬塊狀元素。今天我們先來了解行內元素怎麼進行水平居中?

如果被設定元素為文字、圖片等行內元素時,水平居中是透過為父元素設定 text-align:center 來實現的。 (父元素與子元素:如下面的html程式碼中,div是「我想要在父容器中水平居中顯示」這個文字的父元素。反之這個文字是div的子元素)如下程式碼:

html程式碼:

<body> <div class="txtCenter">我想要在父容器中水平居中显示。</div> </body>
css代码:
<style> .txtCenter{ text-align:center; } </style>

二、水平居中設定:定寬塊狀元素 
當被設定元素為塊狀元素時用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」 是可以隨意設定的。

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

在實際工作中我們會遇到需要為「不定寬度的塊狀元素」設定居中,例如網頁上的分頁導航,因為分頁的數量是不確定的,所以我們不能透過設定寬度來限制它的彈性。 (不定寬塊狀元素:塊狀元素的寬度width不固定。)

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

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

這一小節來講一下第一種方法:

為什麼選擇方法一加入table標籤? 是利用table標籤的長度自適應性—即不定義其長度也不預設父元素body的長度(table其長度根據其內文本長度決定),因此可以看做一個定寬度塊元素,然後再利用定寬度塊狀居中的margin的方法,使其水平居中。

第一步:為需要設定的居中的元素外面加入一個 table 標籤 ( 包括 

、、 )。

第二步:為這個 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>

四、水平居中總結:不定寬塊狀元素方法二 
除了上一節講到的插入table標籤,可以使不定寬塊狀元素方法二 
除了上一節講到的插入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; } 3
</style>

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


三、水平居中總結:不定寬塊狀元素方法三 

除了前兩節講到的插入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>

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

🎜

六、垂直居中:父元素高度确定的单行文本 
我们在实际工作中也会遇到需要设置垂直居中的场景,比如好多报纸的文章标题在左右一侧时,常常会设置为垂直居中,为了用户体验性好。

这里我们又得分两种情况:父元素高度确定的单行文本,以及父元素高度确定的多行文本。

本节我们先来看第一种父元素高度确定的单行文本, 怎么设置它为垂直居中呢?

父元素高度确定的单行文本的竖直居中的方法是通过设置父元素的 height 和 line-height 高度一致来实现的。(height: 该元素的高度,line-height: 顾名思义,行高(行间距),指在文本中,行与行之间的 基线间的距离 )。

line-height 与 font-size 的计算值之差,在 CSS 中成为“行间距”。分为两半,分别加到一个文本行内容的顶部和底部。

这种文字行高与块高一致带来了一个弊端:当文字内容的长度大于块的宽时,就有内容脱离了块。

如下代码:

<div class="container"> hi,imooc! </div>

css代码:

<style> .container{ height:100px; line-height:100px; background:#999; } </style>

七、垂直居中:父元素高度确定的多行文本一 
父元素高度确定的多行文本、图片等的竖直居中的方法有两种:

方法一:使用插入 table (包括tbody、tr、td)标签,同时设置 vertical-align:middle。

css 中有一个用于竖直居中的属性 vertical-align,在父元素设置此样式时,会对inline-block类型的子元素都有用。下面看一下例子:

html代码:

<body> <table><tbody><tr><td class="wrap"> <div> <p>看我是否可以居中。</p> </div> </td></tr></tbody></table> </body>

css代码:

table td{height:500px;background:#ccc}

因为 td 标签默认情况下就默认设置了 vertical-align 为 middle,所以我们不需要显式地设置了。

八、垂直居中:父元素高度确定的多行文本二 
除了上一节讲到的插入table标签,可以使父元素高度确定的多行文本垂直居中之外,本节介绍另外一种实现这种效果的方法。但这种方法兼容性比较差,只是提供大家学习参考。

在 chrome、firefox 及 IE8 以上的浏览器下可以设置块级元素的 display 为 table-cell(设置为表格单元显示),激活 vertical-align 属性,但注意 IE6、7 并不支持这个样式, 兼容性比较差。

html代码:

<div class="container"> <div> <p>看我是否可以居中。</p> <p>看我是否可以居中。</p> <p>看我是否可以居中。</p> </div> </div>

css代码:

<style> .container{ height:300px; background:#ccc; display:table-cell;/*IE8以上及Chrome、Firefox*/ vertical-align:middle;/*IE8以上及Chrome、Firefox*/ } </style>

这种方法的好处是不用添加多余的无意义的标签,但缺点也很明显,它的兼容性不是很好,不兼容 IE6、7而且这样修改display的block变成了table-cell,破坏了原有的块状元素的性质。

九、隐性修改display类型 
有一个有趣的现象就是当为元素(不论之前是什么类型元素,display:none 除外)设置以下 2 个句之一:

position : absolute
float : left 或 float:right

简单来说,只要html代码中出现以上两句之一,元素的display显示类型就会自动变为以 display:inline-block(块状元素)的方式显示,当然就可以设置元素的 width 和 height 了,且默认宽度不占满父元素。

如下面的代码,小伙伴们都知道 a 标签是 行内元素 ,所以设置它的 width 是 没有效果的,但是设置为 position:absolute 以后,就可以了。

<div class="container"> <a href="#" title="">进入课程请单击这里</a> </div>

css代码

<style> .container a{ position:absolute; width:200px; background:#ccc; } </style>

 以上就是【CSS笔记十】CSS样式设置小技巧的内容,更多相关内容请关注PHP中文网(www.php.cn)!


陳述:
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn