根据CSS中块级元素和行内元素的不同特征,其居中显示的方式也有差异,下面就水平和竖直居中的情况做一总结:
1.水平居中
1.1 给父元素设置text-aglin:center;可以实现文本、图片等行内元素的水平居中。
1.2 确定宽度的块级元素的水平居中是通过设置margin-left和margin-right的值为auto来实现。
1.3 对于宽度值不确定的块级元素的居中可以使用以下三种方式,可根据实际情况选择不同方案:
1.3.1 改变块级元素的display值为inline,然后使用text-aglin:center来实现居中,
但此做法的缺点是将块级元素转化为行内元素后就无法设置长宽,当然还有行内元素的其他局限性。
1.3.2 利用table。table本身不是块级元素(display的常用值包含block,compact,inline,table,none,marker).
其宽度靠其单元格中的内部元素的宽度“撑起”,即使不设置宽度也可以利用margin-left/right:auto来实现居中。
当然,使用table标签将会明显增加代码中的无语义标签。
1.3.3 通过给父级元素设置float和position:relative以及left:-50%,给子元素设置position:relative和left:-50%,
也可以实现水平居中,但是relative的位置属性不好控制。
2.竖直居中
2.1 父元素高度不确定的文本、图片、块级元素的竖直居中是通过设置父元素相同的上下边距实现的。
2.2 父元素高度确定的单行文本的竖直居中是给父元素设置line-height:(父元素的height值)来实现。
2.3 父元素高度确定的多行文本、图片、块级元素的竖直居中,分三种情况处理:
2.3.1 父元素为td和th时,可用vertical-align
2.3.2 对于不是此类型的父元素在Firefox和IE8下可用display:table-cell来激活成td或th类型
2.3.3 如果以上两种情况都不满足,则需要给元素添加表格标签,so sad~~~
1.水平居中
1.1 给父元素设置text-aglin:center;可以实现文本、图片等行内元素的水平居中。
1.2 确定宽度的块级元素的水平居中是通过设置margin-left和margin-right的值为auto来实现。
1.3 对于宽度值不确定的块级元素的居中可以使用以下三种方式,可根据实际情况选择不同方案:
1.3.1 改变块级元素的display值为inline,然后使用text-aglin:center来实现居中,
但此做法的缺点是将块级元素转化为行内元素后就无法设置长宽,当然还有行内元素的其他局限性。
1.3.2 利用table。table本身不是块级元素(display的常用值包含block,compact,inline,table,none,marker).
其宽度靠其单元格中的内部元素的宽度“撑起”,即使不设置宽度也可以利用margin-left/right:auto来实现居中。
当然,使用table标签将会明显增加代码中的无语义标签。
1.3.3 通过给父级元素设置float和position:relative以及left:-50%,给子元素设置position:relative和left:-50%,
也可以实现水平居中,但是relative的位置属性不好控制。
2.竖直居中
2.1 父元素高度不确定的文本、图片、块级元素的竖直居中是通过设置父元素相同的上下边距实现的。
2.2 父元素高度确定的单行文本的竖直居中是给父元素设置line-height:(父元素的height值)来实现。
2.3 父元素高度确定的多行文本、图片、块级元素的竖直居中,分三种情况处理:
2.3.1 父元素为td和th时,可用vertical-align
2.3.2 对于不是此类型的父元素在Firefox和IE8下可用display:table-cell来激活成td或th类型
2.3.3 如果以上两种情况都不满足,则需要给元素添加表格标签,so sad~~~