博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
不定宽高垂直居中分析
阅读量:5924 次
发布时间:2019-06-19

本文共 3019 字,大约阅读时间需要 10 分钟。

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

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

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

    

第一种方案

111

第二种方案

111

水平垂直居中的随意内容

  

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

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

  1.水平居中知识点

text-align:center

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

  2.vertical-align知识点

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

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

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

水平垂直居中的随意内容

#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以下的浏览器不支持  的table系value,所以你只能在IE8及以上浏览器以及非IE浏览器下才能看到效果;

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

水平垂直居中的随意内容

#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{ 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)实现垂直居中,只支持高版本

        
555666

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

 
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 通过。

    

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

我是居中对齐的。

我不帅,我不帅。

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

我是居中对齐的ss。

我不帅,我不帅。

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

   

  资料参考:

    未知尺寸元素水平垂直居  

 

转载地址:http://kexvx.baihongyu.com/

你可能感兴趣的文章
mysql添加外键
查看>>
利用MyEclipse连接数据库并自动生成基于注解或者XML的实体类
查看>>
函数进阶
查看>>
第七周
查看>>
P1631 序列合并
查看>>
P1281 书的复制
查看>>
mongo同步到es
查看>>
用C#下的Raw
查看>>
mysql / sqlserver / oracle 常见数据库分页
查看>>
combo
查看>>
spring mvc 支持json
查看>>
Access数据库SQL注入(Access SQL Injection)
查看>>
个人学习C++过程中对const的总结:初始化系列之用字面值常量与其他类型的值初始化的区别(一)...
查看>>
自动化学习笔记之接口测试(一)
查看>>
深度学习常用方法
查看>>
完成端口模型开发
查看>>
CentOS Linux release 7.6.1810全新安装 Zimbra 8.8.12邮箱
查看>>
出现蓝屏代码0x0000007b的原因及解决办法
查看>>
C++ File 类学习总结
查看>>
权限框架 - shiro 自定义realm
查看>>