固定定位下的div水平居中
程序员文章站
2022-11-01 15:22:51
发现了一个之前未留意的知识点,做个笔记。 当一个块级元素的父元素开启了flex布局后,我们可以很轻松的将这个元素居中对齐,可以在父元素上加 justify-content: center; align-items: center;/*单行下的居中对齐*/ 或 justify-content: cen ......
发现了一个之前未留意的知识点,做个笔记。
当一个块级元素的父元素开启了flex布局后,我们可以很轻松的将这个元素居中对齐,可以在父元素上加
justify-content: center;
align-items: center;/*单行下的居中对齐*/
或
justify-content: center;
align-content: center;
flex-wrap: wrap;/*多行下的居中对齐*/
然而,这种对齐方式是基于父元素开启了flex布局方式,假设该子元素开启了固定定位后,这种对齐方式便会失效,因为固定定位脱离了文档流,不受父元素的影响,父元素内对子元素的定位方式自然就不起作用了,那么问题来了:能否将这个固定定位的盒子居中显示呢?
方法是人想出来的。
在这里,我们可以结合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%; //以屏幕为基准,定位使盒子移动屏幕的一半
第二步:使用transform:translatex(-50%):将盒子水平向左位移到自身宽度的一半。//以自身为基准 ,通过transform使盒子移动自身宽度的一半
这样,就完成了水平居中显示.
下一篇: 取名字的规律
推荐阅读
-
固定定位下的div水平居中
-
css3 flex实现div内容水平垂直居中的几种方法
-
HTML设置div水平居中的方式
-
纯CSS实现DIV悬浮的示例代码(固定位置)
-
CSS实现子元素div水平垂直居中的示例
-
熟练掌握CSS+DIV,能在记事本下熟练写静态页,做过10多个静态网站项目,只懂一点PHP语法和MySQL语法,剩下的全都不懂,只自学了半个月,用什么软件,和什么框架能让我立刻参加工作,能让我这个水平也能写出PHP程序?
-
html中的水平居中和垂直居中的问题。(固定高度与高度不定)_html/css_WEB-ITnose
-
HTML5:footer定位(底部+居中)的探讨+div图片居中问题
-
如何在页面下固定位置显示数据库的值
-
通过定位实现的div块网页中固定效果_html/css_WEB-ITnose