头闻号

广州市拓羽化工有限公司

净水絮凝剂|石油蜡|氯化物|碳酸盐|硫酸盐|磷酸盐

首页 > 新闻中心 > 科技常识:利用纯CSS实现居中的七大方法示例
科技常识:利用纯CSS实现居中的七大方法示例
发布时间:2024-12-23 17:28:15        浏览次数:5        返回列表

今天小编跟大家讲解下有关利用纯CSS实现居中的七大方法示例 ,相信小伙伴们对这个话题应该有所关注吧,小编也收集到了有关利用纯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居中方法 各有各的优缺点 须根据实际情况选择最佳方案 希望本文的内容对大家的学习或者工作能带来一定的帮助 如果有疑问大家可以留言交流 谢谢大家对AIDI的支持。

来源:爱蒂网