css高度居中

1.已知元素高度

// 子盒子
#div1{
    width:200px;
    height:200px;
    position: absolute;        //父元素需要相对定位
    top: 50%;
    left: 50%;
    margin-top:-100px ;   //二分之一的height,width
    margin-left: -100px;
    }

2.未知父元素高度

//子盒子
  #div1{
    width: 200px;
    height: 200px;
    margin:auto;
    position: absolute;        //父元素需要相对定位
    left: 0;
    top: 0;
    right: 0;
    bottom: 0;
    background: red;
   }

3.flex使盒子居中

// 父盒子
    .da{
        width: 500px;
        height: 500px;
        background: green;
        display: flex; // 使用flex
        align-items: center; // 上下居中
        justify-content: center; // 左右居中
    }

4.transform实现盒子居中

.da{
        /*父盒子*/
        width: 500px;
        height: 500px;
        background: green;
        position: relative;
    }
      #er{
        /*我是子盒子我要居中*/
        width: 200px;
        height: 200px;
        background: red;
        position: absolute;
        top: 50%;
        left: 50%;
        transform: translate(-50%,-50%);
       }

5.

利用css3的新增属性table-cell, vertical-align:middle;

    .da{
        /*父盒子*/
        width: 500px;
        height: 500px;
        background: green;
        display: table-cell;
        vertical-align: middle; 
    }
      #er{
        /*我是子盒子我要居中*/
        width: 200px;
        height: 200px;
        background: red;
        margin: auto;
       }

 

转载于:https://www.cnblogs.com/ll15888/p/11400139.html

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
CSS垂直居中是网页布局中常见的需求,尤其当元素的高度固定时,我们希望使其在父容器内水平和垂直方向都保持居中。对于高度为74px的元素,有几种方法可以实现垂直居中: 1. **使用Flexbox**: 如果父容器是弹性布局(flex),可以这样设置: ```css .parent { display: flex; align-items: center; justify-content: center; } .child { height: 74px; } ``` 2. **使用Grid布局**: 如果是网格布局,也需要设置`align-items`: ```css .parent { display: grid; place-items: center; } .child { height: 74px; } ``` 3. **使用绝对定位** (结合`position: relative`): ```css .parent { position: relative; } .child { position: absolute; top: 50%; transform: translateY(-50%); height: 74px; } ``` 4. **使用`vertical-align`属性** (应用于行内元素或表格单元格): ```css .parent { display: table-cell; vertical-align: middle; } .child { height: 74px; } ``` 或者 ```css .parent { display: inline-block; } .child { vertical-align: middle; display: inline-block; height: 74px; } ``` 5. **利用CSS Grid的`min-height`和`align-self`**: 如果父元素有最小高度,且使用Grid布局,可以这样设置: ```css .parent { min-height: 74px; /* 或者一个较大的值 */ display: grid; align-items: center; } .child { align-self: center; } ``` 每种方法都有其适用的场景,选择哪种取决于具体的布局结构和兼容性需求。如果你需要进一步了解某一种方法的细节或有其他相关问题,请告诉我。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值