html中div标签下的内容居中表示,div中内容上下居中小结

虽然div中内容上下居中的问题已经是一个比较古老的话题,但是最近发现还是有很多前端开发者在询问如何实现。其实网络上已经有很多资料和案例了,我这里再总结一下几个比较常见的处理方式。

情形一:div限高,内容长度限一行

复制代码代码如下:

.v-align {

margin: 0 auto;

width: 200px;

height: 80px;

text-align: center;

line-height: 80px;

border: 1px solid #ddd;

}

我的内容只能有一行。

30f5a4c169e87ee35eb41191ec3cd989.png

情形二:div限高,内容不限

复制代码代码如下:

.v-mult {

margin: 0 auto;

width: 200px;

height: 100px;

border: 1px solid #ddd;

overflow: hidden;

}

.v-mult .empty,

.v-mult .text {

display: inline-block;

*display: inline;

*zoom: 1;

vertical-align: middle;

}

.v-mult .empty {

height: 100%;

}

我的内容不限,多高都行

换行照常

013c111f01553b6c937da26a586c90ef.png

情形三:div高度不定,内容高度一定

复制代码代码如下:

.v-auto {

position: relative;

margin: 0 auto;

width: 200px;

border: 1px solid #ddd;

}

.v-auto .text {

position: absolute;

top: 50%;

margin-top: -50px;

height: 100px;

border: 1px dashed #ddd;

}

我的高度是固定的,只有100px高,但是我的父及高度不定,我怎么垂直居中呢?

f5e039c4c95f0a76ea11c72486c1188e.png

情形四:div高度不定,内容高度不定

复制代码代码如下:

.v-auto-out {

position: relative;

margin: 0 auto;

width: 200px;

border: 1px solid #ddd;

}

.v-auto-out .auto-in {

position: absolute;

top: 50%;

border: 1px dashed #ddd;

/* 这里有兼容性问题 */

-webkit-transform: translateY(-50%);

-ms-transform: translateY(-50%);

-o-transform: translateY(-50%);

transform: translateY(-50%);

}

我的高度不定,我的父及高度也不定,这下要上下居中,该如何是好?我们一起来瞧瞧吧。

6f2c8d922c0b8585fec6ce89d39e079f.png

好了,知道这四种方式,我相信足以应对日常工作中的各种垂直居中问题。代码很简单,不再做多余阐述。总之一句话,CSS的各个属性样式,就好像人肢体的各个器官,了解了各个器官的功能,才能相互配合完成各种任务。相反,个体的能力是有限的。

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

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值