高度不定垂直居中_不定宽高垂直居中分析

昨天做移动项目是,遇到这样一个案例,如图,图片容器随着视口宽度进行自由拉伸扩张,图片不定宽高,垂直居中:

当时做这个布局的时候,我一直想到用display:table-cell通过vertical-align:middle,来实现居中,可以当我在同一个节点用position:absolute,会导致此居中问题失效。

最后想到的解决方案,案例如下,不定宽高垂直居中:

.wrap,.wrap1{

width:30%;

padding-top:30%;

background:#eee;

position:relative;

}

.wrap p,.wrap1 p{

position:absolute;

top:0;

left:0;

width:100%;

height:100%;

}

.wrap p img{

max-width:100%;

max-height:100%;

position:absolute;

top:50%;

left:50%;-webkit-transform-origin:50% 50%;-webkit-transform:translate3d(-50%,-50%,0);

}

.wrap1 p{text-align:center;font-size:0;}

.wrap1 p:after{

width:0;

height:100%;

display:inline-block;

vertical-align:middle;

content:"";

}

.wrap1 p img{

display:inline-block;

max-width:100%;

max-height:100%;

vertical-align:middle;

margin:0auto;

}

第一种方案

111

第二种方案

111

水平垂直居中的随意内容

下面我们将分别介绍三种垂直居中的解决方案:

已咀嚼一下以前的几个老知识点:

1.水平居中知识点

text-align:center

对于水平居中可能不需要太多的介绍,所有主流浏览器均支持 text-align 属性,只需要取值 center 即可;

2.vertical-align知识点

vertical-align适用于 inline level, inline-block level 及 table-cells 元素上

所有主流浏览器均支持 vertical-align 属性,所以使用该属性来实现垂直居中是一个不错的想法;

一、利用display:table-cell;vertical-align:middle;进行不定高度,垂直居中 例子demo

水平垂直居中的随意内容

#demo{

display:table;

width:500px;

margin:10px auto;

background:#eee;

}

#demo p{

display:table-cell;

height:100px;

vertical-align:middle;

}

既然table能实现,自然也就会想到将 display 设置为table系value来实现。当然,该方案是有局限性的,因为IE8以下的浏览器不支持 display 的table系value,所以你只能在IE8及以上浏览器以及非IE浏览器下才能看到效果;

二、利用display:inline-block;vertical-align:middle;进行不定高度,垂直居中  例子DEMO

水平垂直居中的随意内容

#demo{

height:100px;

text-align:center;

}

#demo:after{

display:inline-block;

width:0;

height:100%;

vertical-align:middle;

content:'';

}

#demo p{

display:inline-block;

vertical-align:middle;

}

这里有一点需要非常注意:参照以上代码,如果我们的内容容器p的宽度为100%时,就会导致#demo:after被挤出不在一行,这个是由于inline元素间隔导致的,可以设置font:0消除,如果为了保持全兼容,可以不用伪类,使用span标签去替代。

完美解决方案:例子demo

这是一个终极实现的水平垂直居中实例

#demo{

height:100px;

text-align:center;

font-size:0; //注意这里是去除文字间隔,放在内容宽度为100%时挤出换行

}

#demo:after,#demo span{

display:inline-block;*display:inline;*zoom:1;

width:0;

height:100%;

vertical-align:middle;

}

#demo:after{

content:'';

}

#demo p{

display:inline-block;*display:inline;*zoom:1;

vertical-align:middle;

font-size:16px;

}

三、利用translate3d(-50%,-50%,0)实现垂直居中,只支持高版本

.box{position:absolute;top:50%;left:50%;-webkit-transform-origin:50% 50%;-webkit-transform:translate3d(-50%,-50%,0)}//原理有点跟 top:50%;left:50%;margin:-height/2 0 0 -width/2类似,这种是要知道高度,但是这个不需要

555666

四、利用两级嵌套,两次left,top实现居中

html,body{width: 100%; height: 100%; margin: 0; padding: 0;}

.wrp{position: fixed; width: 100%; height: 100%; left: 0; top: 0; background-color: rgba(0,0,0,.5);}

.box{position: absolute; left: 50%; top: 50%;}

.box2{position: relative; left: -50%; top: -50%; background-color: #f60000; color: #fff; padding: 10px;}

sssssfdsfd

利用两个不定宽高的div相嵌。外围的div用absolute定位,left:50%,top:50%。这样外围的div的左上角处于水平垂直居中状 态。内部的div使用relative定位,这样可以利用自身的宽高撑开外围的div,再用left:-50%,top:-50%;(用margin- left,margin-top也可以,就是利用取值的是参照外围div的宽高的原理)实现内部div的几何中心与外围的div左上角重合。这样实现了垂 直水平剧中。这个原理有点像使用translate(-50%,-50%)来实现水平垂直居中,不过我用的是css1.0的代码,所以兼容性很好 IE6.0~IE11 chrome,firefox都可以

五、使用 box-align and box-pack 属性居中,必须在box-align控制垂直方向,box-pack水平方向,但是这种只能在display:box弹性盒子容器下使用

兼容性,firefox,chrome,ios7以上,andriod4.0以上

亲测:小米MI2CS、小米MI3/魅族魅蓝note、荣耀6、iphone4s、iphone6 plus 通过。

{

width:350px;

height:400px;

border:1px solid black;/*Firefox*/display:-moz-box;-moz-box-pack:center;-moz-box-align:center;/*Safari, Chrome, and Opera*/display:-webkit-box;/**水平居中**/

-webkit-box-pack:center;/***垂直居中**/

-webkit-box-align:center;/*W3C*/display:box;

box-pack:center;

box-align:center;

}

.box{padding:10px;background:orange}

使用 box-align and box-pack 属性居中

我是居中对齐的。

我不帅,我不帅。

使用 box-align and align-items 属性居中

我是居中对齐的ss。

我不帅,我不帅。

display:-webkit-box;

display:-moz-box;

display:-ms-box;

display:-o-box;

display:box;

width:350px;

height:200px;-webkit-box-align:center;-webkit-align-items: center;-ms-flex-align: center;

align-items: center;

}

.boxlf{

width:20px;

height:100%;

background:red;

}

.boxflex .box{/*display:block;*/

-webkit-box-flex: 1;-moz-box-flex: 1;

box-flex: 1;

}

注释:IE 不支持 box-pack 和 box-align 属性。

资料参考:

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值