当前位置: 首页 > article >正文

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

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

一.水平居中

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

<!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;

<!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的方法

<!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

<!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弹性盒子方法

<!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

<!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的方法

<!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方法

<!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

<!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>

在这里插入图片描述
感谢大家的阅读,如有什么不对的地方,可以向我提出,感谢大家!


http://www.kler.cn/a/146209.html

相关文章:

  • TiDB 和 MySQL 的关系:这两者到底有什么不同和联系?
  • 基于微信小程序的电子点菜系统设计与实现(KLW+源码+讲解)
  • PCL 新增自定义点类型【2025最新版】
  • 一些常见的Java面试题及其答案
  • C语言的数据库交互
  • 语音合成的预训练模型
  • 【K8s 网络】Linux网络虚拟化与TCP/IP网络
  • Facebook的特点优势
  • Oracle 中的操作符
  • C++基础 -3- 匿名空间,命名空间跨文件使用
  • 格雷希尔针对J2044燃油管测试专用快速接头都有哪些及各自的应用场合
  • Vatee万腾的科技冒险:Vatee独特探索力量的数字化征程
  • coreelec与安卓 双系统共存-默认CoreElec引导后10秒计时进入android插件
  • Java游戏制作——王者荣耀
  • 【React】Memo
  • 【活动回顾】ABeam 德硕| 艾宾信息技术开发(西安)西北高校行——与西北三所高校签订校企合作协议
  • python opencv -模板匹配
  • IM通信技术快速入门:短轮询、长轮询、SSE、WebSocket
  • python类和对象
  • Rust语言入门教程(九) - 结构体
  • 交流回馈负载的主要工作方式
  • laravel实现发送邮件功能
  • Python语言学习笔记之三(字符编码)
  • 基于C#实现块状链表
  • 制造业工厂如何选择生产管理MES系统?
  • iOS移动应用程序的备案与SHA-1值查看