CSS居中完全解决方案
2016-02-26 09:53
489 查看
水平居中
行内元素
把行内元素嵌套在一个DIV中,并且在DIV中设置以下样式a{ text-align:center; }
块级元素
对于定宽的块级元素,我们要设置起margin-top,margin-right为auto.center{
margin:0auto;
}
多个块级元素(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/2div{
height:100px;
position:absolute;
top:50%;
margin-top:-50px;
padding:0;
}
未知高度的块级元素
使用CSStranslate,将块级元素设置绝对定位,top为50%,transform:translateY(-50%);div{
position:absolute;
top:50%;
-webkit-transform:translateY(-50%);
-moz-transform:translateY(-50%);
transform:translateY(-50%);
padding:0;
}
水平垂直居中
已知高度、宽度的元素
将块级元素设置绝对定位,top为50%,left:50%;margin-top:-height/2;margin-left:-width/2div{
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;
}
未知高度、宽度的元素
使用CSStranslatediv{ position:absolute; top:50%; left:50%; -webkit-transform:translate(-50%,-50%); -moz-transform:translate(-50%,-50%); transform:translate(-50%,-50%); }
相关文章推荐
- css+div
- 【CSS3】不错的博客
- 几种常用 css3 选择器解释
- 【CSS3】box-sizing 属性
- 【CSS3】CSS生成内容:content
- 【CSS3】CSS3外轮廓属性
- 【CSS3】自由缩放属性resize
- css 透明度
- css 效果收集
- 2016/2/25 html+css学习资源
- CSS定位属性Position详解
- CSS:在input、pre中左边加上一个图标(一行和多行)
- 史上最全的CSS hack方式一览
- HTML+CSS慕课网学习总结(四)
- 理解CSS前景色和透明度
- CSS水平/垂直居中方法一览
- 导航条div+css实现
- CSS学习
- 一些常用css技巧的为什么(二)我所理解的line-height
- 详解css3中webkit-animation