zoukankan      html  css  js  c++  java
  • 你的元素居中对齐了吗?——关于 'text-align:center' 的问题

    转自:http://bbs.csdn.net/topics/340170231

     昨天在论坛里溜达的时候,发现有同学遇到了居中的问题,页面在 IE 里居中对齐好好的,为什么在其他浏览器里面就不灵了呢?
        我曾经也在写一个 JS 日历的时候也被居中弄的焦头烂额,苦不堪言。想必不少人都遇到过这个问题吧。
        我大致看了一下,发现是 “text-align:center” 的兼容性引起的。下面就这个问题跟大家分享一点我的经验。
        先来看看 W3C 标准中是怎么说的。
        在W3C CSS2.1规范第16.2节 对text-align 有详细地描述: ------------------------------------------ 值: left | right | center | justify | inherit 初始值:匿名值,由'direction'的值而定,如果'direction'为'ltr'则为'left',如果'direction'为'rtl'则为'right'。 应用于: 块级元素,表格单元格,行内块元素 继承性: 是 计算后的值:初始值或指定值 ------------------------------------------
        这个特性描述了如何使一个块元素的行内内容对齐。
        注意一点,标准里说这个属性是用来对齐行内内容的,所以,应该对块级内容起作用。
        解释一下,行内内容是说由行内元素组成的内容,行内元素大家都知道吧,比如 SPAN 元素,IFRAME元素和元素样式的 ‘display : inline’ 的都是行内元素;块级内容跟则是由块级元素构成,DIV 是最常用的块级元素。块级元素和行内元素的区别是,块级元素会占一行显示,而行内元素可以在一行并排显示。
        这样,我们对这个特性的认识应该就清楚了。但是,问题来了,虽然标准里这么规定,那么是不是所有浏览器都遵守呢?答案是否定的。猜猜是哪个浏览器这么特立独行啊? IE!!
        IE6/7及IE8混杂模式中,text- align:center可以使块级元素也居中对齐。其他浏览器中,text-align:center仅作用于行内内容上。
        解决这个问题比较好的方式,就是为所有需要相对父容器居中对齐的块级元素设置“margin-left:auto; margin-right:auto”。但这个方式 IE6/IE7/IE8的混杂模式中不支持,所以还要设置父容器的 "text-align:center;"。
        若居中对齐的子元素内的行内内容不需要居中对齐,则还需要为其设置“text-align:left”:

    XML/HTML code
     
    ?
    1
    2
    3
    4
    5
    6
    7
    8
    9
    10
    <style>
       * { font-family:Consolas,Verdana,Arial; font-size:12px; }
       div, center { border:3px solid dimgray; padding:2px; }
       span { background:lightgrey; }
    </style>
    <div style="200px; text-align:center;">
       <div style="100px; margin:0 auto; text-align:left;">
           <span>text</span>
       </div>
    </div>
  • 相关阅读:
    Linux使用locate命令定位文件
    LINUX常用命令
    linux性能问题(CPU,内存,磁盘I/O,网络)
    Linux下常用的shell命令记录
    Linux下的进程管理
    Linux常用性能检测命令解释
    CentOS查看系统信息-CentOS查看命令
    linux系统中如何查看日志 (常用命令)
    美团HD(4)-二级联动效果
    美团HD(3)-加载分类导航数据
  • 原文地址:https://www.cnblogs.com/mawenying/p/5363844.html
Copyright © 2011-2022 走看看