主页 > 知识库 > 完美实现浮动元素横排居中显示

完美实现浮动元素横排居中显示

热门标签:检查注册表项 美图手机 呼叫中心市场需求 银行业务 智能手机 服务器配置 铁路电话系统 网站文章发布

经常会遇到这样的页面布局:在一排显示几个不同的区域内容,但它们相对于页面是居中对齐的。注意这些区域内容不只是文字,也许还有图片或者其它元素混合而成。一般这样的布局我们很容易想到要用浮动float,但是怎么样居中对齐而又兼容低端浏览器哪?请接着往下看。

首先看html代码:

div class="webFooter">
  div class="wrap">
    div class="tabs">
      ul>
        li>
          a href="javascript:void(0)">高大上平台/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">关于我们/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">联系我们/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">服务条款/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">人才招聘/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">帮助中心/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">帮助中心/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">帮助中心/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">帮助中心/a>em>|/em>
        /li>
        li>
          a href="javascript:void(0)">客服中心/a>
        /li>
      /ul>
    /div>
  /div>
/div>

有人会说这些item都是文本,其实把ul换成其它元素(比如div)也是可行的。原理就是.wrap相对于页面居中,宽度是1200px,当然也可以是1000px,宽度自由定义,只要大于内容宽度即可。然后.tabs左浮动并且设置position: relative; left: 50%; 然后为其内部元素ul设置float: left; position: relative; left: -50%; 最后要给.wrap加上overflow: hidden; *position: relative;

css代码如下:

style type="text/css">
body, ul, li, ol, dl, dt, dd {padding: 0; margin: 0; list-style: none;}
.webFooter {height: 100px; font-size: 12px; background: #278ed1; font-family: Microsoft YaHei; color: #fff;}
.webFooter a,
.webFooter a:hover {color: #fff;}
.webFooter .wrap {width: 1200px; margin-left: auto; margin-right: auto; background: red; overflow: hidden; *position: relative;}
.webFooter .tabs {float: left; position: relative; left: 50%; margin-top: 25px;}
.webFooter .tabs ul {float: left; position: relative; left: -50%;}
.webFooter .tabs li {float: left; line-height: 17px;}
.webFooter .tabs a {float: left; font-size: 14px;}
.webFooter .tabs em {float: left; width: 20px; height: 15px; *line-height: 15px; text-align: center;}
/style>

解释一下为什么要给.wrap加上overflow: hidden; *position: relative;哪?原因就是内容比较长的话,由于.tabs的left: 50%; 导致其位置超出了.wrap的宽度范围,当显示屏稍小的时候页面会出现横向滚动条,并且ie7比较顽固,要加*position: relative;才行。有兴趣的端友可以去掉overflow: hidden; *position: relative;试一下,或者改变内容的多少再来试一下,相信会有不同的感觉!

最后,把ul改成div class="inner">(为.inner写css:float: left; position: relative; left: -50%;)便可以在.inner里面写你想要的浮动排版了(比如:来一个二维码的图片,再来一个客服电话及图标,然后再来一个微博的链接...等等)。

您可能感兴趣的文章:
  • 文字或图片元素在DIV中垂直居中
  • CSS如何使DIV层居中
  • 让2个DIV居中并排显示
  • Div上下居中
  • 用js 让图片在 div或dl里 居中,底部对齐
  • JS弹出居中的DIV的代码
  • 基于jQuery实现的水平和垂直居中的div窗口
  • jquery div 居中技巧应用介绍
  • Js制作简单弹出层DIV在页面居中 中间显示遮罩的具体方法
  • 浮动的div自适应居中显示的js代码
  • JS实现div居中示例

标签:沧州 沈阳 乐山 新疆 上海 河南 长治 红河

巨人网络通讯声明:本文标题《完美实现浮动元素横排居中显示》,本文关键词  ;如发现本文内容存在版权问题,烦请提供相关信息告之我们,我们将及时沟通与处理。本站内容系统采集于网络,涉及言论、版权与本站无关。
  • 相关文章
  • 收缩
    • 微信客服
    • 微信二维码
    • 电话咨询

    • 400-1100-266