绝对定位元素的水平垂直居中是前端开发中经常遇到的问题,下面将详细讲解3种任选的方法。
绝对定位元素的水平垂直居中是前端开发中经常遇到的问题,下面将详细讲解3种任选的方法。
方法一:使用绝对定位实现水平垂直居中
首先,在 CSS 中设置绝对定位,并将 left 和 top 设置为 50%。此时元素的左上角将位于页面的中心。
.position{
position:absolute;
left:50%;
top:50%;
}
接下来,需要使用 JavaScript 将元素的宽度和高度分别除以 2,再利用 marginLeft 和 marginTop 将其移回以左上角为基准的位置。
let element = document.querySelector('.position');
element.style.marginLeft = - element.offsetWidth / 2 + 'px';
element.style.marginTop = - element.offsetHeight / 2 + 'px';
方法二:使用 flexbox 实现水平垂直居中
使用 flexbox 实现水平垂直居中可以更方便。
首先,在容器中设置 display: flex 声明容器使用 flex 布局。
.container{
display:flex;
justify-content:center;
align-items:center;
}
接下来,将要进行居中的元素包裹在容器中即可。
<div class="container">
<div class="box"></div>
</div>
方法三:使用 CSS3 transform 实现水平垂直居中
使用 CSS3 transform 可以让元素相对于自身的中心点旋转,从而实现居中。首先设置绝对定位,并将 top 和 left 设置为 50%,同时在元素中添加如下代码:
.position {
position:absolute;
left:50%;
top:50%;
transform: translate(-50%,-50%);
}
此时元素的左上角将位于页面的中心。
接下来,可以用 CSS3 transform 进行旋转,如下所示:
.position{
position:absolute;
left:50%;
top:50%;
transform: translate(-50%,-50%) rotate(45deg);
}
其中 rotate(45deg) 表示元素将相对于自身的中心点旋转 45 度。
示例:
<div class="container">
<div class="box"></div>
</div>
.container{
display:flex;
justify-content:center;
align-items:center;
}
.box{
width:200px;
height:200px;
background-color:#ccc;
}
.position{
position:absolute;
left:50%;
top:50%;
}
.position{
position:absolute;
left:50%;
top:50%;
transform: translate(-50%,-50%) rotate(45deg);
}
以上就是三种实现绝对定位元素水平垂直居中的方法,任选其一即可。
本文标题为:绝对定位元素的水平垂直居中的方法(3种任选)
基础教程推荐
- 小程序实现瀑布流动态加载列表 2022-08-30
- 深度剖析JavaScript作用域从局部到全局一网打尽 2023-07-09
- 一个自动居中的导航条实例与相关问题 DIV+CSS 2022-10-16
- 第6天:XHTML代码规范 2022-11-07
- JS基础---html中事件冒泡和捕获 2023-10-26
- vue 段落文字溢出中间... 尾部添加文字 组建 2023-10-08
- 基于ajax后台返回的数据为空前台显示出现undefined的解决方法 2023-02-22
- react-redux的connect与React.forwardRef结合ref失效的解决 2023-07-09
- ajax请求后台接口数据与返回值处理js的实例讲解 2023-02-22
- JavaScript对象与JSON格式的转换及JSON.stringify和JSO 2022-08-30
