本文主要是介绍CSS居中小谈-上下左右居中,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
http://web.jobbole.com/88804/
内联元素居中方案
水平居中设置:
- 行内元素 设置 text-align:center;
- Flex布局 设置display:flex;justify-content:center;(灵活运用,注意兼容性和前缀)
垂直居中设置:
- 父元素高度确定的单行文本(内联元素) 设置 line-height = height;
- 父元素高度确定的多行文本(内联元素)
- a:插入 table (插入方法和水平居中一样),然后设置 vertical-align:middle;
- b:先设置 display:table-cell 再设置 vertical-align:middle;
块级元素居中方案
水平居中设置:
- 定宽块状元素设置 左右 margin 值为 auto;
- 不定宽块状元素
- a:在元素外加入 table 标签(完整的,包括 table、tbody、tr、td),该元素写在 td 内,然后 设置 margin 的值为 auto;
- b:给该元素设置 displa:inine 方法;
- c:父元素设置 position:relative 和 left:50%,子元素设置 position:relative 和 left:50%;
垂直居中设置:
1.使用position:absolute(fixed),设置left、top、margin-left、margin-top的属性;
CSS
1 2 3 4 5 6 7 | .box{ position:absolute;/*或fixed*/ top:50%; left:50%; margin-top:-100px; margin-left:-200px; } |
2.利用position:fixed(absolute)属性,margin:auto这个必须不要忘记了;
CSS
1 2 3 4 5 6 7 8 | .box{ position: absolute;或fixed top:0; right:0; bottom:0; left:0; margin: auto; } |
3.利用display:table-cell属性使内容垂直居中;
CSS
1 2 3 4 5 6 7 8 | .box{ display:table-cell; vertical-align:middle; text-align:center; width:120px; height:120px; background:purple; } |
4.使用css3的新属性transform:translate(x,y)属性;
CSS
1 2 3 4 5 6 7 | .box{ position: absolute; transform: translate(50%,50%); -webkit-transform:translate(50%,50%); -moz-transform:translate(50%,50%); -ms-transform:translate(50%,50%); } |
5.最高大上的一种,使用:before元素;
CSS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 | .box{ position:fixed; display:block; background:rgba(0,0,0,.5); } .box:before{ content:''; display:inline-block; vertical-align:middle; height:100%; } .box.content{ width:60px; height:60px; line-height:60px; color:red; |
6.Flex布局;
CSS
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 | .box{ display: -webkit-box; display: -webkit-flex; display: -moz-box; display: -moz-flex; display: -ms-flexbox; display: flex;
水平居中 -webkit-box-align: center; -moz-box-align: center; -ms-flex-pack:center; -webkit-justify-content: center; -moz-justify-content: center; justify-content: center;
垂直居中 -webkit-box-pack: center; -moz-box-pack: center; -ms-flex-align:center; -webkit-align-items: center; -moz-align-items: center; align-items: center; } |
结语
博主暂时掌握了这些居中方法,读者如果还有好方法或是觉得那个地方不对,欢迎评论,不吝感谢。
这篇关于CSS居中小谈-上下左右居中的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!