CSS居中完全解决方案_html/css_WEB-ITnose

WBOY
發布: 2016-06-24 11:56:44
原創
861 人瀏覽過

上次面试面试官问到了,问了个定宽局中和不定宽局中,下来我把所有有关CSS居中都总结了一下

原文摘自我的前端博客,欢迎大家来访问

http://www.hacke2.cn

水平居中

行内元素

把行内元素嵌套在一个DIV中,并且在DIV中设置以下样式

a{ text-align: center; }
登入後複製

块级元素

对于定宽的块级元素,我们要设置起margin-top,margin-right 为auto

.center{ margin: 0 auto; }
登入後複製

多个块级元素(inline-block)

多个块级元素,我们将其display设置为inline-block;然后将父级元素设置一下属性

div{ text-align: center; }
登入後複製

多个块级元素(flex)

设置需要水平居中的块状元素的父元素display为flex ,并且justify-content属性为center即可

body{ display: flex; justify-content: center; }
登入後複製

垂直居中

单行 行内元素

将行内元素的height和line-height设置为一致即可

a{ height: 200px; line-height:200px; }
登入後複製

多行 行内元素

如果行内元素文字过多产生多行,则在父级元素设置display: table-cell;vertical-align:middle;

.container{ width: 300px; height: 300px; display: table-cell; vertical-align:middle; }
登入後複製

已知高度的块级元素

将块级元素设置绝对定位,top为50%,margin-top:-height/2

div{ height: 100px; position: absolute; top: 50%; margin-top: -50px; padding:0; }
登入後複製

未知高度的块级元素

使用CSS translate,将块级元素设置绝对定位,top为50%,transform: translateY(-50%);

div{ position: absolute; top: 50%; transform: translateY(-50%); padding:0; }
登入後複製

水平垂直居中

已知高度、宽度的元素

将块级元素设置绝对定位,top为50%,left:50%;margin-top:-height/2;margin-left:-width/2

div{ width: 150px; height: 150px; position: absolute; top: 50%; left: 50%; margin-top: -75px; margin-left: -75px; }
登入後複製

已知高度、宽度的元素(flex)

给父级使用flex布局

div{ display: flex; justify-content:center; align-items: center; }
登入後複製

未知高度、宽度的元素

使用CSS translate

div{ position:absolute; top:50%; left:50%; -webkit-transform:translate(-50%,-50%); -moz-transform:translate(-50%,-50%); transform:translate(-50%,-50%); }
登入後複製

相關標籤:
來源:php.cn
本網站聲明
本文內容由網友自願投稿,版權歸原作者所有。本站不承擔相應的法律責任。如發現涉嫌抄襲或侵權的內容,請聯絡admin@php.cn
熱門教學
更多>
最新下載
更多>
網站特效
網站源碼
網站素材
前端模板