CSS元素居中有多少方法
发布时间:2023-09-16 13:52:40 所属栏目:语言 来源:
导读:在实际应用中,我们有时候会遇到“CSS元素居中有多少方法,分别是什么”这样的问题,我们该怎样来处理呢?下文给大家介绍了解决方法,希望这篇“CSS元素居中有多少方法,分别是什么”文章能帮助
在实际应用中,我们有时候会遇到“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属性,适合用于移动端。 六、Flexbox居中法 父元素:display: flex; justify-content: center; align-items: center; 注:该方法使用了Flexbox弹性布局,移动端兼容性也存在很大问题。 七、Flexbox+margin居中法 父元素:display: flex; 子元素:margin: auto; 注:同上,兼容IE10+ (编辑:汽车网) 【声明】本站内容均来自网络,其相关言论仅代表作者个人观点,不代表本站立场。若无意侵犯到您的权利,请及时与联系站长删除相关内容! |
推荐文章
站长推荐