css - 扩大元素的点击区域_个人文章 - SegmentFault 思否
问题背景有时候我们在做移动端业务的开发时,会遇到这样的问题:我们按照UI设计稿画好了页面,但是在验收功能时,发现在小屏幕手机上有些按钮不好点击,可是UI同学又不希望我们调整按钮的大小,破坏了他的设计。
顺晟科技
2021-09-01 12:05:51
221
案例是这样的,一个外层div,高宽是固定的,但是里面内容不是固定的。很多朋友的做法是头部加一个padding或者margin,这样,里面内容显得貌似是居中了,但是假如内容变化,这样头部的固定padding或者margin,始终不变。造成了垂直方向不会居中!
我们知道,假如下面一个div
<div class="outer"><div class="inner">haorooms内部内容</div></div>
样式是这样的
.outer{text-align:center;vertical-align: middle;width:200px;height:350px;}
vertical-align:middle是不管用的,很多朋友就在.inner上面做文章了,和我上面说的,加margin等等!那对于这种情况,有没有更好的解决方案呢?
思路:加一个cssHack,设置cssHack的line-height等于外层div的高度,就可以使用vertical-align:middle了!
div如下:
<div class="outer">
<div class="inner">haorooms内部内容</div><div class="v">cssHack</div>
</div>
样式如下:
* {
margin: 0;
padding: 0;
}
.outer {
background-color: #ccc;
font-size: 24px;
height: 350px;
text-align: center;
overflow: hidden;
width: 280px;
}
.outer .inner,
.outer .v {
display: inline-block;
zoom: 1;*display: inline; /* 用于触发支持IE67 inline-block */
}
.outer .inner {
line-height: 1.8;
padding: 0 4px 0 5px;
vertical-align: middle;
width: 262px;
}
.outer .v {
line-height: 350px;
text-indent:-9999px;
width: 1px;
}
这样就实现了div内部的垂直居中了!
31
2022-10
19
2022-10
15
2022-10
05
2022-10
15
2022-09
15
2022-09