经验首页 前端设计 程序设计 Java相关 移动开发 数据库/运维 软件/图像 大数据/云计算 其他经验
当前位置:技术经验 » HTML/CSS » HTML5 » 查看文章
固定定位下的div水平居中
来源:cnblogs  作者:致爱丽丝  时间:2019/9/18 8:49:13  对本文有异议

发现了一个之前未留意的知识点,做个笔记。

当一个块级元素的父元素开启了flex布局后,我们可以很轻松的将这个元素居中对齐,可以在父元素上加

  1. justify-content: center;
  2. align-items: center;/*单行下的居中对齐*/

 或

  1. justify-content: center;
  2. align-content: center;
  3. flex-wrap: wrap;/*多行下的居中对齐*/

 然而,这种对齐方式是基于父元素开启了flex布局方式,假设该子元素开启了固定定位后,这种对齐方式便会失效,因为固定定位脱离了文档流,不受父元素的影响,父元素内对子元素的定位方式自然就不起作用了,那么问题来了:能否将这个固定定位的盒子居中显示呢?

方法是人想出来的。

在这里,我们可以结合css3和百分比定位达到目的:

  1. .search_box {
  2. position: fixed;
  3. top: 0;
  4. left: 50%;
  5. -webkit-transform: translateX(-50%);
  6. transform: translateX(-50%);
  7. width: 100%;
  8. max-width: 540px;
  9. min-width: 320px;
  10. /* 固定定位,脱离文档流 */
  11. height: 44px;
  12. /* 通过与left配合,使这个div居中显示 */
  13. }

  第一步:定位在50%,此时盒子会在居中靠右位置,但盒子的起点位于屏幕居中位置, top: 0;  left: 50%; //以屏幕为基准,定位使盒子移动屏幕的一半 

 

 

第二步:使用transform:translateX(-50%):将盒子水平向左位移到自身宽度的一半。//以自身为基准 ,通过transform使盒子移动自身宽度的一半

 

 这样,就完成了水平居中显示.

原文链接:http://www.cnblogs.com/hjk1124/p/11532725.html

 友情链接:直通硅谷  点职佳  北美留学生论坛

本站QQ群:前端 618073944 | Java 606181507 | Python 626812652 | C/C++ 612253063 | 微信 634508462 | 苹果 692586424 | C#/.net 182808419 | PHP 305140648 | 运维 608723728

W3xue 的所有内容仅供测试,对任何法律问题及风险不承担任何责任。通过使用本站内容随之而来的风险与本站无关。
关于我们  |  意见建议  |  捐助我们  |  报错有奖  |  广告合作、友情链接(目前9元/月)请联系QQ:27243702 沸活量
皖ICP备17017327号-2 皖公网安备34020702000426号