CSS——实现盒子在页面居中

1.三种常见方法

  1. 使用translate位移 + position定位实现
  2. 使用Grid布局实现
  3. 使用Flex布局实现

2.代码示例

2.1 translate + position:使用绝对定位,让盒子脱离文档流,通过top和left将盒子的左上角放到中心点上,然后使用translate移动使其居中。

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>页面水平垂直居中</title>
    <style>
      .box {
        position: absolute;
        width: 400px;
        height: 400px;
        top: 50%; /* 把元素的"上边缘"放到包含块高度的 50% 处 */
        left: 50%; /*  把元素的"左边缘"放到包含块宽度的 50% 处 */
        transform: translate(-50%, -50%);/*向左、向上各移动自身宽/高的 50%,让元素中心与包含块中心重合 */
        background-color: pink;
    }
    </style>
  </head>
  <body>
    <div class="box">
    </div>
  </body>
</html>

2.2 Grid布局:使用place-item:center实现居中。

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>页面水平垂直居中</title>
    <style>
    .parent {
        display: grid;
        place-items: center; /* 同时水平和垂直居中 */
        height: 100vh;       /* 为了示例效果,父元素设置全屏高度 */
    }
    .child {
        width: 100px;
        height: 100px;
        background-color: blue;
    }
   </style>
  </head>
  <body>
<div class="parent">
   <div class="child"></div>
</div>
  </body>
</html>

2.3 Flex布局:使用justify-content: center和align-items: center,通过控制主轴和交叉轴实现居中。

html 复制代码
<!DOCTYPE html>
<html lang="en">
  <head>
    <meta charset="UTF-8" />
    <meta name="viewport" content="width=device-width, initial-scale=1.0" />
    <title>页面水平垂直居中</title>
    <style>
     .parent {
        display: flex;
        justify-content: center; /* 水平居中 */
        align-items: center;    /* 垂直居中 */
        height: 100vh;          /* 为了示例效果,父元素设置全屏高度 */
    }
    .child {
        width: 100px;
        height: 100px;
        background-color: red;
    }
   </style>
  </head>
  <body>
<div class="parent">
   <div class="child"></div>
</div>
  </body>
</html>
相关推荐
华仔啊17 小时前
写 CSS 用 px?这 3 个单位能让页面自动适配屏幕
前端·css
静听松涛13317 小时前
提示词注入攻击的防御机制
前端·javascript·easyui
晚风予星17 小时前
简记 | 一个基于 AntD 的高效 useDrawer Hooks
前端·react.js·设计
栗子叶18 小时前
网页接收服务端消息的几种方式
前端·websocket·http·通信
菩提小狗18 小时前
Sqli-Labs Less-3 靶场完整解题流程解析-豆包生成
前端·css·less
智航GIS18 小时前
10.5 PyQuery:jQuery 风格的 Python HTML 解析库
python·html·jquery
澄江静如练_18 小时前
优惠券提示文案表单项(原生div写的)
前端·javascript·vue.js
C_心欲无痕18 小时前
ts - 关于Object、object 和 {} 的解析与区别
开发语言·前端·javascript·typescript
L Jiawen18 小时前
【Windows 系统】Chrome浏览器退出登录状态失效
前端·chrome·windows
IT_陈寒18 小时前
Java并发编程实战:从入门到精通的5个关键技巧,让我薪资涨了40%
前端·人工智能·后端