利用:before垂直居中的问题

在上次的直播课程中,若愚老师讲了两种垂直居中的方法,
html代码如下:

<!DOCTYPE html>
<html>
<head>
  <meta charset="utf-8">
  <title>JS Bin</title>
</head>
<body>
  <div class="wrap">
     <div class="box">
      ![](http://js.jirengu.com/images/dave.min.svg)   
    
  </div>
   
</div>
  
    <div class="box2">
      ![](http://js.jirengu.com/images/dave.min.svg)
    </div>
  

</body>
</html>

CSS代码如下:

.wrap{
  display: table;
  width: 100%;
}
.box{
  height: 200px;
  border: 1px solid red;
  text-align: center;
  display: table-cell;
  vertical-align: middle;
}
.box>img{
  width: 100px;
} 
.box2>img{
  width: 180px;
  vertical-align: middle;
}
.box2{

  height: 300px;
  border: 1px solid blue;
  text-align: center;
}
.box2:before{
  content:'';
  display: inline-block;
  width: 0px;
  height: 100%;
  vertical-align: middle;
}

垂直居中

为方便调试,在贴一个JSbin的地址:
垂直居中

重点讨论伪类:before使用场景

在做实战15的时候想利用before来解决页头的垂直居中,但是使用起来发现没有达到想要的效果。仔细分析代码发现问题如下:

.box2:before{
  content:'';
  display: inline-block;
  width: 0px;
  height: 100%;
  vertical-align: middle;
}

在创建伪类后,使用了display:inline-block和heigh:100%这两行代码,这就意味着那个想要垂直居中的元素也需要display:inline-block,那么img本身就是inline-block,所以这个方法用在图片上是OK的,但是用在文字上就出现了问题,本来我想要的效果是这样:

想要的效果

结果确是这样:

现实效果

通过这个列子可以得知,这个方法用在图片(单行)或者单行文字是OK的,多行文字的垂直居中还是适用table-cell比较好。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 14,682评论 1 92
  • 收听音频,戳链接,旧号itclan已暂停使用,欢迎关注微信itclanCoder公众号可收听更多音频 前言 关于网...
    itclanCoder阅读 12,530评论 3 30
  • H5移动端知识点总结 阅读目录 移动开发基本知识点 calc基本用法 box-sizing的理解及使用 理解dis...
    Mx勇阅读 10,115评论 0 26
  • 大小不固定的图片和多行文字的垂直水平居中一、大小不固定,多行文字的垂直居中① 单行文字可能很多人都知道如何让单行文...
    Wang_Yong阅读 3,931评论 0 0
  • 我叫狗蛋,大家好。 自从在十七号失业之后,我就成了十八岁的孩子,开始希望有人关注我,而且最好是不爱我的人,于是我开...
    消失的卡卡鹦鹉阅读 4,771评论 0 5