一个盒子不给宽度和高度如何实现水平垂直居中?

实现水平垂直居中的方式很多:flex布局、定位+transform、.grid布局(网格布局)、定位+margin(需要给宽度)、table布局、文本元素 line-height等。

<div class="container">

    <div class="box">水平垂直居中</div>

  </div>

方式一:flex布局

.container{

      width: 300px;

      height: 200px;

      margin: 0 auto;  // 可有可无

      border: 5px solid pink;

      display: flex;

      justify-content: center;

      align-items: center;

    }

    .box {

      background-color: red;

      color: #fff;

    }

d14c526009b44482b8606768593b689e.png

方式二:定位(position)+ transform

 .container{

      width: 300px;

      height: 200px;

      margin: 0 auto;

      border: 5px solid pink;

      position: relative;

    }

    .box {

      background-color: red;

      position: absolute;

      top: 50%;

      left: 50%;

      transform: translate(-50%, -50%);

    }

5e2590ca3cbd403295bc0a756a4d7e9a.png

方式三:Grid布局

.container {

      width: 300px;

      height: 200px;

      margin: 0 auto;

      border: 5px solid pink;

      display: grid;

      place-items: center;

    }

    .box {

      background-color: red;

      color: #fff;

    }

aed8c57f04b94f0b8acfb56761cced54.png

方式四:table布局

.container {

      width: 300px;

      height: 200px;

      /* margin: 0 auto; 不起作用 */

      border: 5px solid pink;

      display: table-cell;

      vertical-align: middle;

      text-align: center;

    }

    .boxx {

      display: inline-block;

      background-color: red;

      color: #fff;

    }

2e28bee717914fc69eef570b17922637.png

方式五:文本元素居中

.container {

      width: 300px;

      height: 200px;

      border: 5px solid pink;

      text-align: center;

      line-height: 200px;

 }

a338946e602c4d59a1e22c213210d0be.png

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值