理解CSS居中

我想很多在前端学习或者开发过程中,肯定会遇到如何让你的元素居中的问题,网上google肯定会有很多的解决方法。今天我就个人的项目与学习经验谈谈个人理解css如何让元素居中。

要理解css的居中,首先必须理解css的元素分类以及css的盒模型(box model)。

a. 元素分类。

在css中把元素分为块级元素、内联元素以及内联块级元素。

块级元素最明显的特征就是: { display: block; }  。块级元素独占一行,默认情况元素的width默认为100%,但可以修改元素的height, width等样式;例如html中的<div>, <p>, <ul>, <li>, <hx>, <form>等。

内联元素最明显的特征是  { display: inline; }  。也叫行内元素,可以与其他行内元素共享一行,但是其height, width, margin-top, margin-bottom均不可设置。例如html中的<span>, <a>, < label>, <input>等。

内联块级元素,也就是行内块级元素  { display: inline-block; }  。顾名思义,内联块级元素既有块级元素的特征,也有内联元素的特征。也就是inline-block可以与其他元素共享一行,也可以设置height, width等样式。

b. 盒模型(box model)。

在css中,所有的元素都有盒模型,打开chrome审查任何一个网页的元素都会看到一个盒模型。

图1. css盒模型

正如图1所示,一个盒模型有margin, border, padding以及盒子本身的尺寸(height, width),从字面量上通俗地讲就是(多个)盒子的间距、盒子的边框、盒子内的填充、以及盒子的宽、高。我们可以通过css修改这些样式,例如:

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Document</title>
 6     <style>
 7         div{
 8             width: 300px;
 9         }
10         div.box-model{
11             margin: 10px;
12             padding: 10px;
13             border: solid 2px;
14             width: 100px;
15             height: 60px;
16             display: inline-block;
17             background: #999;
18         }
19     </style>
20 </head>
21 <body>
22     <div>
23         <div class="box-model">div1</div>
24         <div class="box-model">div2</div>
25         <div class="box-model">div3</div>
26         <div class="box-model">div4</div>
27     </div>
28 </body>
29 </html>

           

              图2. css盒模型样式的修改

接下来讲如何对一个元素进行居中:

1.水平居中:

1.1内联元素的居中

  对内联元素居中只需要给其父元素设置   {text-align: center; }   即可;

2.2块级元素

  2.2.1宽度固定;若块级元素的宽度是固定的可以同时设置其左右的边距  { margin-left: auto; margin-right: auto; }  为自动让其居中;

  2.2.2宽度不定,我们在开发过程中,我们块级元素的宽度大多数是不固定的,对宽度未知的块级元素有很多种方法,现在主要讲一些方法,最主要的是其思想,大家一定要注意体会其思想。

    a.利用<table>标签;将元素放在<td>中,给table增加样式  { margin-left: auto; margin-right: auto; }

    b.将块状元素修改为内联元素利用内联元素的方法,即修改元素的  { display: inline; }  ,并修改其父元素的  {text-align: center; }  。

    c.给父元素设置float,并设置  { float:left; position:relative; left:50%; }  ,在给该块级元素设置  { position:relative; left:-50%; }  即可。

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Document</title>
 6     <style>
 7         .width-block{
 8             width: 200px;
 9             margin-left: auto;
10             margin-right: auto;
11             background: #9cc;
12         }
13         table{
14             margin:0 auto;
15         }
16         table div{
17             background: #9cc;
18         }
19         .float-father{
20             float: left;
21             position: relative;
22             left: 50%;
23         }
24         .float{
25             position: relative;
26             left: -50%;
27             background: #fcc;
28         }
29     </style>
30 </head>
31 <body>
32     <div>
33         <div class=‘width-block‘>div center with width</div>
34     </div>
35     <table>
36         <tbody>
37             <tr>
38                 <td>
39                     <div>div center with table</div>
40                 </td>
41             </tr>
42         </tbody>
43     </table>
44     <div class=‘float-father‘>
45         <div class=‘float‘>
46             div with float father
47         </div>
48     </div>
49 </body>
50 </html>

    总结:

    方法a:虽然实现了块级元素的居中,但是却增加了没有语义的标签。

    方法b:改变了标签元素特性,使其成为了内联元素,使得其失去了块状元素的固有特性,如height, width等。

    方法c:设置了position为relative,且改变了其层模型属性。

2.垂直居中:

2.1 父元素高度确定的情况下单行文本:只要设置其父元素的line-height与其高度一致即可;

 1 <!DOCTYPE html>
 2 <html lang="en">
 3 <head>
 4     <meta charset="UTF-8">
 5     <title>Document</title>
 6     <style type="text/css">
 7         #div1{
 8             height: 100px;
 9             background: #fcc;
10             line-height: 100px;
11             border: solid;
12         }
13     </style>
14 </head>
15 <body>
16     <div id=‘div1‘>
17         <div>single line text</div>
18     </div>
19 </body>
20 </html>
21
22 单行文本

2.2 父元素高度确定的多行文本

  a. 利用<table>标签,css中有一个用于垂直居中的属性vertical-align,但是这个样式只有在table标签中的th或者td中才会生效。因此借助table标签可以使元素垂直居中;

 1 <table>
 2     <tbody>
 3         <tr>
 4             <td>
 5                 <div>
 6                     <div>text1</div>
 7                     <div>text2</div>
 8                     <div>text3</div>
 9                 </div>
10             </td>
11         </tr>
12     </tbody>
13 </table>
1 td{
2      height: 200px;
3      vertical-align: middle;/*td默认为middle,可以不设置 */
4      }

  b. 利用  { display: table-cell; }  ,其实也是跟方法a类似,这里是通过display来激活vertical-align属性,但是IE8以前的浏览器不支持table-cell。与a方法不同的是这里需要显示去设置  { vertical-align: middle; }  。

1 <div id="table-cell">
2      <div>div1</div>
3      <div>div2</div>
4      <div>div3</div>
5      <div>div4</div>
6  </div>
1 #table-cell{
2             display:table-cell;
3             vertical-align:middle;
4             height:200px;
5             background:#fcc;
6             border: solid;
7         }

2.3高度不确定

可以设置父元素的padding对top和bottom一致  { padding-top: 50px; padding-bottom: 50px; }   来控制元素的垂直居中,但是必须是父元素能够设置padding-top和padding-bottom,也就是父元素为行内元素肯定不行。

1  <div class=‘bypadding‘>
2      <div>div1</div>
3      <div>div2</div>
4      <div>div3</div>
5      <div>div4</div>
6  </div>
.bypadding{
             padding:50px 0;
             border:solid;
             background: #fcc;
         }

总结,在常用CSS居中的解决方法中,我们需要理解css的块级元素、内联元素,并在解决过程中巧妙运用块级元素以及内联元素的特性,有时候可以借助table标签的特性。

文章地址:http://www.cnblogs.com/alvinwei1024/p/4616322.html

时间: 2024-11-08 20:54:45

理解CSS居中的相关文章

理解CSS盒子模型

什么是CSS的盒子模式呢?为什么叫它是盒子?先说说我们在网页设计中常听的属性名:内容(content).填充(padding).边框(border).边界(margin), CSS盒子模式都具备这些属性. 这些属性我们可以把它转移到我们日常生活中的盒子(箱子)上来理解,日常生活中所见的盒子也具有这些属性,所以叫它盒子模式.那么内容就是盒子里装的东西:而填充就是怕盒子里装的东西(贵重的)损坏而添加的泡沫或者其它抗震的辅料:边框就是盒子本身了:至于边界则说明盒子摆放的时候的不能全部堆在一起,要留一定

深入理解CSS中的margin

1.css margin可以改变容器的尺寸 元素尺寸 可视尺寸--标准盒子模型中盒子的宽度是不包括margin值的,clientWidth 占据尺寸--包括margin的宽度 outWidth不在标准之中,jquery中有相对应的方法 margin与可视尺寸 1.1使用那个与没有设定width/height的普通block水平元素 2.2只适用于水平方向尺寸 <body style="background-color:#1a2b3c"> <div style=&quo

深入理解CSS中的层叠上下文和层叠顺序(转)

by zhangxinxu from http://www.zhangxinxu.com 本文地址:http://www.zhangxinxu.com/wordpress/?p=5115 零.世间的道理都是想通的 在这个世界上,凡事都有个先后顺序,凡物都有个论资排辈.比方说食堂排队打饭,对吧,讲求先到先得,总不可能一拥而上.再比如说话语权,老婆的话永远是对的,领导的话永远是对的. 在CSS届,也是如此.只是,一般情况下,大家歌舞升平,看不出什么差异,即所谓的众生平等.但是,当发生冲突发生纠葛的时

深入理解CSS中的层叠上下文和层叠顺序

零.世间的道理都是想通的 在这个世界上,凡事都有个先后顺序,凡物都有个论资排辈.比方说食堂排队打饭,对吧,讲求先到先得,总不可能一拥而上.再比如说话语权,老婆的话永远是对的,领导的话永远是对的. 在CSS届,也是如此.只是,一般情况下,大家歌舞升平,看不出什么差异,即所谓的众生平等.但是,当发生冲突发生纠葛的时候,显然,是不可能做到完全等同的,先后顺序,身份差异就显现出来了.例如,杰克和罗斯,只能一人浮在木板上,此时,出现了冲突,结果大家都知道的.那对于CSS世界中的元素而言,所谓的“冲突”指什

深入理解CSS盒子模型

前言:前阵子在做一个项目时,在页面布局方面遇到了一点小问题,于是上stackoverflow上求助.ifaou在帮助我解决我问题的同时,还推荐我阅读一篇有关CSS盒子模型的文章<The CSS Box Model>,阅读之后受益匪浅,才知道自己对盒子模型知识还是如此欠缺.恰逢学期末,项目验收后暂时告一段落,有空闲的时间.于是想把这篇文章翻译出来,一方面再给自己一点挑战和锻炼,另一方面也给大家参考,让更多的人受益. 这篇文章适合初级web设计朋友,让你对盒子模型有更近一步的理解.但是在阅读这篇文

深入理解css中的定位属性:position

深入理解css中的定位属性:position 在网页设计中,position属性的使用是非常重要的.有时如果不能认识清楚这个属性,将会给我们带来很多意想不到的困难. position属性共有四种不同的定位方法,分别是static.fixed.relative.absolute. 第一部分:static static定位是HTML元素的默认值,即没有定位,元素出现在正常的流中,因此,这种定位就不会收到top,bottom,left,right的影响. 如html代码如下: <div class=&qu

CSS居中完全解决方案

上次面试面试官问到了,问了个定宽局中和不定宽局中,下来我把所有有关CSS居中都总结了一下 原文摘自我的前端博客,欢迎大家来访问 http://www.hacke2.cn 水平居中 行内元素 把行内元素嵌套在一个DIV中,并且在DIV中设置以下样式 a{ text-align: center; } 块级元素 对于定宽的块级元素,我们要设置起margin-top,margin-right 为auto .center{ margin: 0 auto; } 多个块级元素(inline-block) 多个

css居中问题

学习过程中遇到css居中问题 , 也查阅了资料,每个人的方法都不尽相同,而且当时看懂了,过后就记混淆了;so作为一个前端小白,也来写一下俗话说好脑子不如烂笔头,毕竟自己知道的也不多,其实是抱着学习和交流的态度啦.话不多说,直接来(注:本文中的属性都是在chrome浏览器下试验的); 一 : 一个父盒子,一个子盒子如何居中(高度已知) 最简单的一种: 就是使用定位,父盒子relative,子盒子absolute,然后子盒子left和top值各50%;在设置margin值,left和top值是本身盒

CSS居中集合&amp;图片视口最大化

http://www.w3cplus.com/css/vertically-center-content-with-css CSS制作水平垂直居中对齐(分别介绍水平和垂直居中的方法,优缺点分析) http://www.cnblogs.com/rubylouvre/p/3274273.html CSS 居中大全(比较全面的居中方法) http://www.zhangxinxu.com/wordpress/?p=3794 张大神:margin:auto实现绝对定位元素的水平垂直居中 http://w