文章内容
1、水平居中
1 | margin : 0 auto ; |
2、文字的水平居中
利用line-height设为height的一样即可
1 | < div class = "wrap" >Hello World</ div > |
1 2 3 4 5 6 | . wrap { line-height : 200px ; /*垂直居中关键*/ text-align : center ; height : 200px ; font-size : 36px ; background-color : #ccc ; } |
3、padding填充
利用padding和background-clip配合实现div的水平垂直居中:通过background-clip设置为content-box,将背景裁剪到内容区外沿,再利用padding设为外div减去内div的差的一半,来实现
1 2 3 | < div class = "parent" > < div class = "children" ></ div > </ div > |
01 02 03 04 05 06 07 08 09 10 11 12 | .parent{ margin : 0 auto ; width : 200px ; height : 200px ; background-color : red ; } .children { width : 100px ; height : 100px ; padding : 50px ; background-color : black ; background-clip : content-box ; /*居中的关键*/ } |
4、hacks, hacks(小技巧)
有许多 hacks ,负 margin,影子元素 ::before 等。如果你的内容不是固定大小的话,它们大部分是很脆弱的
5、translate(-50%,-50%)
用 position 加 translate translate(-50%,-50%) 比较奇特,百分比计算不是以父元素为基准,而是以自己为基准。这个技巧相当嚣张,同样适用于没固定大小的内容,min-width,max-height,overflow:scroll等
01 02 03 04 05 06 07 08 09 10 11 12 | #ex 3 _container{ width : 200px ; height : 200px ; background-color :yellow; position : relative ; } #ex 3 _content{ left : 50% ; top : 50% ; transform : translate ( -50% , -50% ); -webkit- transform : translate ( -50% , -50% ); background-color : gray ; color : white ; position : absolute ; } |
1 | < div id = "ex3_container" >< div id = "ex3_content" >Hello World</ div ></ div > |
6、绝对定位居中
绝对定位的元素的位置相对于最近的已定位祖先元素,如果元素没有已定位的祖先元素,那么它的位置相对于最初的包含块。父容器元素:position: relative
注意:高度必须定义,建议加 overflow: auto,防止内容溢出
1 2 3 4 5 6 7 8 | .Absolute-Center { width : 50% ; height : 50% ; overflow : auto ; margin : auto ; position : absolute ; top : 0 ; left : 0 ; bottom : 0 ; right : 0 ; } |
7、视口居中
内容元素:position: fixed,z-index: 999,记住父容器元素position: relative
1 2 3 4 5 6 7 8 9 | .Absolute-Center.is-Fixed { width : 50% ; height : 50% ; overflow : auto ; margin : auto ; position : fixed ; top : 0 ; left : 0 ; bottom : 0 ; right : 0 ; z-index : 999 ; } |
8、响应式
百分比宽高,最大、最小宽度均可以,加 padding 也可以
01 02 03 04 05 06 07 08 09 10 11 | .Absolute-Center.is-Responsive { width : 60% ; height : 60% ; min-width : 400px ; max-width : 500px ; padding : 40px ; overflow : auto ; margin : auto ; position : absolute ; top : 0 ; left : 0 ; bottom : 0 ; right : 0 ; } |
9、偏移
只要margin: auto; 在,内容块将垂直居中,top, left, bottom, right 可以设置偏移
1 2 3 4 5 6 7 8 9 | .Absolute-Center.is-Right { width : 50% ; height : 50% ; margin : auto ; overflow : auto ; position : absolute ; top : 0 ; left : auto ; bottom : 0 ; right : 20px ; text-align : right ; } |
10、溢出
居中内容比父容器高时,防止溢出,加 overflow: auto (没有任何 padding 时,也可以加 max-height: 100%;)
1 2 3 4 5 6 7 8 9 | .Absolute-Center.is-Overflow { width : 50% ; height : 300px ; max-height : 100% ; margin : auto ; overflow : auto ; position : absolute ; top : 0 ; left : 0 ; bottom : 0 ; right : 0 ; } |
11、调整尺寸
resize 属性可以让尺寸可调。 设置 min- /max- 限制尺寸,确定加了 overflow: auto
01 02 03 04 05 06 07 08 09 10 11 | .Absolute-Center.is-Resizable { min-width : 20% ; max-width : 80% ; min-height : 20% ; max-height : 80% ; resize : both ; overflow : auto ; margin : auto ; position : absolute ; top : 0 ; left : 0 ; bottom : 0 ; right : 0 ; } |
12、margin填充
利用将子div的margin-top设置为父div高度减去子div高度的一半,然后再通过overflow设置为hidden来触发父div的BFC,LESS代码如下
1 2 3 | < div class = "parent" > < div class = "children" ></ div > </ div > |
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 | @parentWidth: 200px ; @childrenWidth: 50px ; .parent { margin : 0 auto ; height :@parentWidth; width :@parentWidth; background : red ; overflow : hidden ; /*触发BFC*/ } .children { height :@childrenWidth; width :@childrenWidth; margin-left : auto ; margin-right : auto ; margin-top : (@parentWidth - @childrenWidth) / 2 ; background : black ; } |
13、absolute定位
利用position:absolute搭配top,left 50%,再将margin设为负值也可以对div进行水平垂直居中,首先还是需要定义父子div。其中的margin中的值为该div宽度的一半
1 2 3 | < div class = "parent" > < div class = "children" ></ div > </ div > |
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 | .parent { position : relative ; margin : 0 auto ; width : 200px ; height : 200px ; background-color : red ; } .children { position : absolute ; left : 50% ; top : 50% ; margin : -25px 0 0 -25px ; height : 50px ; width : 50px ; background-color : black ; } |
14、图片居中
一般的图片居中都是和text-align一样,将图片包装在一个div中,将该div的text-align设为center即可。
有一种特殊的方式,利用了一个图片进行占位,以让父容器获得高宽,从而让进行-50%偏移的图片能有一个参照容器作百分比计算。优点是可以不知道图片的大小,随便放张尺寸不超过父容器的图片上去都能做到居中。另外,兼容性好,IE6都是能顺利兼容的。代码如下
1 2 3 4 5 | < div class = "parent" > < p > < img class = "hidden-img" src = "1.jpg" alt = "" /> < img class = "show-img" src = "1.jpg" alt = "" /></ p > </ div > |
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 | .parent { position : relative ; width : 100% ; height : 200px ; background : red ; } p { position : absolute ; top : 50% ; left : 50% ; } .hidden-img { visibility : hidden ; } .show-img { position : absolute ; right : 50% ; bottom : 50% ; } |
15、transform居中
上面讲到的div居中的例子中,div的宽度都是固定的,然而实际项目中,有可能遇到不定宽的div,特别是响应式或者移动端的设计中,更加常见。所以下面介绍一种不需要定宽的div水平垂直居中方法。
首先利用float,将需要居中的div的父div也就是children的宽度收缩,然后left:50%,将children的左边与水平中线对齐。这个时候,还没有真正居中,需要将children-inner左移动-50%,这样就水平居中了。
再来说说垂直方向,先将children的top设为50%,然后其上边和垂直中线对齐了,同样,需要将children-inner上移动-50%。但是这个50%是计算不出来的,所以我们用到了transform : translate3d(0, -50%, 0);
1 2 3 4 5 | < div class = "parent" > < div class = "children" > < div class = "children-inline" >我是水平垂直居中噢!</ div > </ div > </ div > |
01 02 03 04 05 06 07 08 09 10 11 12 13 14 15 16 17 18 19 20 | .parent { float : left ; width : 100% ; height : 200px ; background-color : red ; } .children { float : left ; position : relative ; top : 50% ; left : 50% ; } .children- inline { position : relative ; left : -50% ; -webkit-transform : translate 3 d( 0 , -50% , 0 ); transform : translate 3 d( 0 , -50% , 0 ); background-color : black ; color : white ; } |
16、flex居中
这种方式最为简便,就是兼容性不好,不过随着时间的前进,各大浏览器一定会都兼容的
1 2 3 | < div class = "parent" > < div class = "children" >我是通过flex的水平垂直居中噢!</ div > </ div > |
01 02 03 04 05 06 07 08 09 10 11 12 13 | html,body{ width : 100% ; height : 200px ; } .parent { display : flex ; align-items : center ; /*垂直居中*/ justify-content : center ; /*水平居中*/ width : 100% ; height : 100% ; background-color : red ; } .children { background-color : blue ; } |