水平居中块级元素较好的实现


 

如上图所示,要做图中黄色区域的到期提醒,要求提醒的内容(提醒的内容是指黄色背景上的图标和文字)居中显示。

我将图中的惊叹号标识做为提醒内容的背景图片处理, 而这就要求内容区有一个高度,所以内容区必须是block-level的。 但block level的元素的宽度默认等于父元素的宽度,这样的话内容将从黄色左边界开始显示. 且设置text-align: center; 只能将文字居中而无法将背景图片居中且显示在文字的左边。

之前想的一个做法:

给内容区 设置一个width, 然后 margin: 0 auto; 然后背景定位在内容的左边再设一个padding-left即可。这种做法的缺点是不灵活,一旦文字有变化或背景图片大小要变就需要改动样式表。

较好的实现:

将内容区display: inline-block, 背景图的设置跟dispaly:block时一样,即background-position: left; padding-left: 50px; 即可。然后黄色区 text-align: center; 完整代码如下:

复制代码
代码如下:

<!-- 使用天数小于等于30天时显示‘即将到期’ -->
<div class="almost-expire-tip">
<div class="almost-expire-tip-content">您的帐户即将到期,为方便您的使用,请尽快与能力天空销售联系。联系电话:4006164080</div>
</div>

在CODE上查看代码片派生到我的代码片

复制代码
代码如下:

.almost-expire-tip { width: 100%; height: 68px; line-height: 68px; background: #FC0; text-align: center; }
.almost-expire-tip-content { display:inline-block; *display:inline; *zoom:1; padding-left: 50px; background: #FC0 url(http://www.ablesky-a.com:8080/ableskystatics/images/organizationAdmin/sprite_ico.png) no-repeat 0 -70px; font-size: 22px; }

背景图片垂直方向的-70px是因为使用了css sprite合并了图片。
« 
» 
快速导航

Copyright © 2016 phpStudy | 豫ICP备2021030365号-3