zoukankan      html  css  js  c++  java
  • 纯CSS七大居中方法 前端王睿

    记得有次找工作面试的时候,一面试官问了一个CSS方面的问题:如何让元素在浏览器窗口中上下左右居中。我记得当时给了个答案是,先用JS获取浏览器窗口高度,然后给body设置line-height为窗口高度并设置text-align:center, 接着再设置该元素display:inline-block和vertical-align:middle。唉,现在想想自己都觉得累。

    难道就一定要用到JS吗?就不能有一种只用CSS方法就能实现元素居中的方法吗?答案是,有!而且方法远不止一种!

    一、line-height居中法
    父元素:text-align: center; line-height:600px; font-size: 0;

    子元素:display: inline-block; vertical-align: middle;

    注:600px必须为父元素的高度,这里还需注意的一点是font-size需设为零,若未写该属性将导致元素并不能精确垂直居中。该方法即为我面试时所答的方法,缺点很明显,父元素高度须确定。(兼容IE8+)

    二、table-cell居中法
    父元素:display: table-cell; text-align: center; vertical-align: middle;

    子元素:display: inline-block;

    注:兼容IE8+

    三、上下左右定位+margin居中法
    父元素:position: relative;

    子元素:position: absolute; left: 0; right: 0; top: 0; bottom: 0; margin: auto;

    注:兼容IE8+

    四、50%定位+margin居中法
    父元素:position: relative;

    子元素:position: absolute; left: 50%; top: 50%; margin: -200px 0 0 -200px;

    注:200px须为该子元素的宽高的一半。例如该子元素宽为100px,高为50px,那么margin取值为-25px 0 0 -50px。该方法缺点是须确定子元素宽高。(兼容IE8+)

    五、50%定位+translate居中法
    父元素:position: relative;

    子元素:position: absolute; left: 50%; top: 50%; transform: translate(-50%,-50%);

    注:该方法使用了CSS3 transform属性,适合用于移动端。(兼容IE9+)

    六、Flexbox居中法
    父元素:display: flex; justify-content: center; align-items: center;

    注:该方法使用了Flexbox弹性布局,移动端兼容性也存在很大问题。(兼容IE10+)

    七、Flexbox+margin居中法
    父元素:display: flex;

    子元素:margin: auto;

    注:同上,兼容IE10+

    以上就是今天所要介绍的七种纯CSS居中方法,各有各的优缺点,须根据实际情况选择最佳方案。

    本文为原创文章,转载请注明出处,谢谢!

    作者:前端王睿
    链接:https://www.jianshu.com/p/f3df6ccc050a
    来源:简书
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

  • 相关阅读:
    upc组队赛3 T-net【贪心】
    upc组队赛5 Assembly Required【思维】
    upc组队赛5 Bulbs
    upc组队赛5 Ingenious Lottery Tickets【排序】
    upc组队赛5 Hunter’s Apprentice 【判断多边形边界曲线顺逆时针】
    upc组队赛5 Ground Defense【枚举】
    upc组队赛4 Go Latin
    upc组队赛4 TV Show Game 【2-SAT】
    POJ 3250 Bad Hair Day【单调栈入门】
    016.NET5_MVC_视图组件扩展定制
  • 原文地址:https://www.cnblogs.com/ellafive/p/13156601.html
Copyright © 2011-2022 走看看