CSS主流布局--垂直居中布局

CSS主流布局–垂直居中布局

垂直居中布局

是使得父级元素容器中的子元素保持垂直居中布局的方式

常见两种垂直居中布局的方式

-table-cell+vertical-align属性配合使用
-absolute+transform属性配合使用

table-cell+vertical-align属性配合使用

HTML

<!--父级元素-->
<div class="parent">
<!--    子级元素-->
    <div class="child"></div>
</div>

css

 .parent{
            width: 200px;
            height: 600px;
            background-color: skyblue;
            vertical-align: middle;
            display: table-cell;
          }
  .child {
            width: 200px;
            height: 200px;
            background-color: lightsalmon;
        }

在这里插入图片描述
vertical-align属性用于使文本垂直对齐的方式,常见的属性值有top,middle,bottom
display属性的table属性值相当与<table>元素的布局,table-cell相当于<td>元素的布局。

第一种解决方案的优点与缺点

优点

浏览器的兼容性好,因为属性都兼容老版本的浏览器。

缺点

vertical-align与text-align属性一样都具有继承性,在父级元素中添加文本也会显示出垂直居中的效果。
HTML

<!--父级元素-->
<div class="parent">
<!--    子级元素-->
    文本布局
    <div class="child"></div>
</div>

CSS代码不变。
在这里插入图片描述

absolute+transform属性配合使用

HTML

<!--父级元素-->
<div class="parent">
<!--    子级元素-->
    <div class="child"></div>
</div>

CSS

 .parent{
            width: 200px;
            height: 600px;
            background-color: skyblue;
            position: absolute;
          }
        .child {
            width: 200px;
            height: 200px;
            background-color: lightsalmon;
            position: absolute;
            top:50%;
            transform:tanslateY(-50%);
        }

如果子级元素开启定位父级元素没有开启定位,子级元素相对于页面进行定位;
如果子级元素开启定位,父级元素也开启定位,子级元素相对于父级元素进行定位。

transform:translateY(-100px),子级元素向上平移-100px,一般使用-50%更好
在这里插入图片描述

第二种解决方案的优缺点

优点

父级元素是否脱离文档流,都不会影响子级元素垂直居中的效果

缺点

transform是CSS3中的属性因此对浏览器的兼容性支持并不友好。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值