发现了一个以前未留意的知识点,作个笔记。javascript
当一个块级元素的父元素开启了flex布局后,咱们能够很轻松的将这个元素居中对齐,能够在父元素上加css
justify-content: center; align-items: center;/*单行下的居中对齐*/
或java
justify-content: center; align-content: center; flex-wrap: wrap;/*多行下的居中对齐*/
然而,这种对齐方式是基于父元素开启了flex布局方式,假设该子元素开启了固定定位后,这种对齐方式便会失效,由于固定定位脱离了文档流,不受父元素的影响,父元素内对子元素的定位方式天然就不起做用了,那么问题来了:可否将这个固定定位的盒子居中显示呢?css3
方法是人想出来的。web
在这里,咱们能够结合css3和百分比定位达到目的:布局
.search_box { position: fixed; top: 0; left: 50%; -webkit-transform: translateX(-50%); transform: translateX(-50%); width: 100%; max-width: 540px; min-width: 320px; /* 固定定位,脱离文档流 */ height: 44px; /* 经过与left配合,使这个div居中显示 */ }
第一步:定位在50%,此时盒子会在居中靠右位置,但盒子的起点位于屏幕居中位置, top: 0; left: 50%; //以屏幕为基准,定位使盒子移动屏幕的一半 flex
第二步:使用transform:translateX(-50%):将盒子水平向左位移到自身宽度的一半。//以自身为基准 ,经过transform使盒子移动自身宽度的一半3d
这样,就完成了水平居中显示.orm