CSS水平居中与垂直居中的方法

当我们页面布局的时候,通常需要把某一个元素居中,这一篇文章为大家介绍一下居中的几种方法,本人文笔有限,请见谅!

一.水平居中

行内元素 水平居中的方法,我们使用text-align:center;

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>水平居中</title>
    <style>
        .box {
            /* 给块元素设置宽高 */
            width: 300px;
            height: 50px;
            background-color: orange;
            /* 水平居中 */
            text-align: center;
        }
    </style>
</head>
<body>
    <div class="box">
        <span>我是需要水平居中的文字</span>
    </div>
</body>
</html>


块元素水平居中 的方法
1.margin(外边距)的方法来做,使用margin:0 auto;

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>水平居中</title>
    <style>
        .box {
            /* 给块元素设置宽高 */
            width: 300px;
            height: 50px;
            background-color: orange;
            margin: 0 auto; 
        }
    </style>
</head>
<body>
    <div class="box"></div>
</body>
</html>

2.使用absolute加margin-left的方法

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>水平居中</title>
    <style>
        .box {
            /* 给加一个绝对定位 */
            position: absolute;
            /* 向右百分之50 */
            left: 50%;
            /* 外边距再减自身宽度的一半 */
            margin-left: -150px;
            /* 给块元素设置宽高 */
            width: 300px;
            height: 50px;
            background-color: orange;
        }
    </style>
</head>
<body>
    <div class="box">我是定位加margin</div>
</body>
</html>


3.使用absolute加transform

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>水平居中</title>
    <style>
        .box {
            /* 给加一个绝对定位 */
            position: absolute;
            /* 向右百分之50 */
            left: 50%;
            /* 横向上向左移动自身宽度的一半 */
            transform: translateX(-50%);
            /* 给块元素设置宽高 */
            width: 300px;
            height: 50px;
            background-color: orange;
        }
    </style>
</head>
<body>
    <div class="box">我是定位加transform</div>
</body>
</html>


4.flex弹性盒子方法

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>水平居中</title>
    <style>
      .father {
        width: 400px;
        height: 400px;
        background-color: orange;
        /* 给父级开启弹性盒子 */
        display: flex;
        /* 主轴对齐方式 */
        justify-content: center;
      }
      .son {
        width: 200px;
        height: 200px;
        background-color: pink;
      }
    </style>
</head>
<body>
    <div class="father">
        <div class="son"></div>
    </div>
</body>
</html>

二.垂直居中

行内元素垂直居中,使用line-height

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>垂直居中</title>
    <style>
        .box {
            width: 300px;
            height: 50px;
            background-color: orange;
            /* 行高等于全部高度 */
            line-height: 50px;
        }
    </style>
</head>
<body>
    <div class="box"><span>我是垂直居中</span></div>
</body>
</html>

块元素垂直居中方法:
1.使用absolute加margin-top的方法

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>垂直居中</title>
    <style>
        .boss {
            position: relative;
            width: 300px;
            height: 200px;
            background-color: pink;
        }
        .box {
            /* 给加一个绝对定位 */
            position: absolute;
            /* 向下百分之50 */
            top: 50%;
            /* 外边距再减自身高度的一半 */
            margin-top: -25px;
            /* 给块元素设置宽高 */
            width: 300px;
            height: 50px;
            background-color: orange;
        }
    </style>
</head>
<body>
    <div class="boss">
        <div class="box">我是定位加margin</div>
    </div>
</body>
</html>

2.flex方法

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>水平居中</title>
    <style>
      .father {
        width: 400px;
        height: 400px;
        background-color: orange;
        /* 给父级开启弹性盒子 */
        display: flex;
        /* 侧轴对齐方式 */
        align-items: center;
      }
      .son {
        width: 200px;
        height: 200px;
        background-color: pink;
      }
    </style>
</head>
<body>
    <div class="father">
        <div class="son"></div>
    </div>
</body>
</html>


3.使用absolute加transform

html 复制代码
<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <title>垂直居中</title>
    <style>
        .boss {
            position: relative;
            width: 300px;
            height: 300px;
            background-color: pink;
        }
        .box {
            /* 给加一个绝对定位 */
            position: absolute;
            /* 向下百分之50 */
            top: 50%;
            /* 横向上向上移动自身宽度的一半 */
            transform: translateY(-50%);
            /* 给块元素设置宽高 */
            width: 300px;
            height: 50px;
            background-color: orange;
        }
    </style>
</head>
<body>
    <div class="boss">
        <div class="box">我是定位加transform</div>
    </div>
</body>
</html>


感谢大家的阅读,如有什么不对的地方,可以向我提出,感谢大家!

相关推荐
郑州光合科技余经理7 小时前
同城配送调度系统实战:JAVA微服务
java·开发语言·前端·后端·微服务·中间件·php
一只小bit8 小时前
Qt 绘图核心教程:从基础绘制到图像操作全解析
前端·c++·qt·gui
乾元8 小时前
绕过艺术:使用 GANs 对抗 Web 防火墙(WAF)
前端·网络·人工智能·深度学习·安全·架构
HWL56798 小时前
一个CSS属性will-change: transform
前端·css
Y淑滢潇潇8 小时前
WEB 作业 即时内容发布前端交互案例
前端·javascript·交互
比特森林探险记8 小时前
后端开发者快速入门react
开发语言·前端·javascript
李松桃8 小时前
python第三次作业
java·前端·python
熊猫钓鱼>_>8 小时前
从零到一:打造“抗造” Electron 录屏神器的故事
前端·javascript·ffmpeg·electron·node·录屏·record
晚霞的不甘9 小时前
Flutter for OpenHarmony《智慧字典》 App 主页深度优化解析:从视觉动效到交互体验的全面升级
前端·flutter·microsoft·前端框架·交互
我是伪码农9 小时前
Vue 1.28
前端·javascript·vue.js