`
jdhh_hcm
  • 浏览: 11169 次
  • 性别: Icon_minigender_1
  • 来自: 杭州
社区版块
存档分类
最新评论

你的元素居中对齐了吗?——关于 'text-align:center' 的问题(转载)

 
阅读更多

原文地址:http://topic.csdn.net/u/20100702/15/e0087252-0975-424b-8b9b-ce6c6cb3699d.html

向作者致敬!

 

昨天在论坛里溜达的时候,发现有同学遇到了居中的问题,页面在 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”:

HTML code
<!-- Code highlighting produced by Actipro CodeHighlighter (freeware) http://www.CodeHighlighter.com/ --> <style> * { font-family:Consolas,Verdana,Arial; font-size:12px; } div, center { border:3px solid dimgray; padding:2px; } span { background:lightgrey; } </style> <div style="width:200px; text-align:center;"> <div style="width:100px; margin:0 auto; text-align:left;"> <span>text</span> </div> </div>
分享到:
评论

相关推荐

    CSS教程:水平对齐(text-align)

    水平对齐(text-align),用以设定元素内文本的水平对齐方式。 1.语法 text-align具体参数如下: 语法:text-align:left|right|center|justify 说明:设定元素内文本的水平对齐方式。 参数:left:左对齐;right:右...

    vue组件实现文字居中对齐的方法

    上图为公司自营的一个微信商城的某一部分截图,可以看到红框内部分的文字多行与单行是居中对齐的,我们现在要做的就是使用Vue把里边的文字模块制作成一个可以复用的组件。 首先我们先把css部分拿下来  css: .word-...

    实例方式学CSS text-align怎么用

    水平对齐(text-align),用以设定元素内文本的水平对齐方式。 水平对齐(text-align),用以设定元素内文本的水平对齐方式。 1.语法 text-align具体参数如下: 语法:text-align : left | right | center | justify...

    ansi-align:使用ANSI对CLI的对齐文本

    ansi-align 使用ANSI对CLI的对齐文本 轻松地使文本块居中或右对齐,而忽略ANSI转义码。 例如,将其转为: 变成这个: 安装 npm install --save ansi-... 使用'center'表示居中对齐,使用'right'表示右对齐,或者使

    css实现文本和div居中对齐详细讲解示例

    .1 实现文字水平居中(使用text-align) 对div.parentDiv设置text-align: center;来实现。CSS代码如下: 复制代码代码如下:[css] &lt;p&gt;.parentDiv {width:200px;height:100px;border: 1px solid #ececec;text-align:...

    weixin-develop:微信开发相关

    三列布局 内容居中外层containerdisplay: flex;...// flex-start flex-end center center strech baseline2 单行排列(容器为flex-direction: row)单行排列的元素高度可能不同 在垂直方向的对齐方式align-items: fl

    div中子div在firefox ie 水平居中对齐

    比如: &lt;div&gt; &lt;div&gt; &lt;/div&gt; &lt;/div&gt; 想让子div在父div中水平居中对齐,如果在css中写 div { text-align: center; }的话在ie中浏览没有问题,但在firefox中依然左对齐。 所以必须再加一个样式 div div { margin-left:...

    web前端基础——CSS入门

    web前端基础——CSS入门 1.css的引入方式 内部样式: 直接在style里面写 内联样式: ...这个段落居中对齐。 p.center { text-align:center; } 类名的第一个字符不能使用数字!它无法在 Mozilla 或 Fi

    静态页练习

    text-align: center;/*文字对齐方式*/ background: #FFF;/*背景颜色*/ } a:link, a:visited { font-size: 12px;/*字体大小*/ text-decoration: none;/*文字修饰*/ } a:hover { } /*页面层容器*/ #container { ...

    网页制作 css让页面居中对齐

    总结一下css让页面居中对齐的方法1.我们常用的margin:0 auto;方法这个方法是大家用的最多的方法,使用的时候必须为容器制定宽度!例子: #main {width:960px;margin:0 auto;} 这个在大部分浏览器里面都可以很好的...

    matlab说话代码-cv:一个包含我的履历作为Jupyter笔记本的回购

    text-align: center; } &lt;/style&gt; """ )) &lt;style&gt; .output {display:flex; align-items:居中; 文本对齐:居中; } &lt;/ style&gt; 个人信息 def load_map_frame (): with open ( 'map_frame.html' ) as

    Web前端与移动发开之css的文本属性

    2.text-align:center/right/left 让盒子内的文本水平对齐 3.text-decoration 装饰文本 一般用来取消下划线 上划线 删除线 none/underline下划线/overline上划线/line-through删除线 4.text-indent 文本首行缩进 ...

    center-aligning-jumbotron:React-bootstrap Jumbotron 将儿童水平和垂直居中

    居中对齐超大屏幕 这是一个 react-bootstrap Jumbotron,它的子项在水平和垂直方向上居中对齐。 使用 Flexbox 实现垂直对齐 使用text-align实现水平text-align 这种样式是使用内联style属性实现的 import ...

    动画演示flex属性 - 可点击切换属性

    动画演示flex布局,包括flex父容器属性以及flex布局子元素...flex-start:侧轴开始 flex-end:侧轴结束 center:居中 stretch:拉伸(默认值) 四. justify-content 子盒子主轴方向上的对齐方式 等,字数不够,无法一一列举

    CSS3中的注音对齐属性ruby-align用法指南

    对于Latin文本以center值对齐left : 根据基本宽度左对齐center : 根据基本宽度居中对齐。如果基本宽度小于ruby文本的宽度,那么在ruby文本的宽度中居中基本宽度right : 根据基本宽度右对齐distribute-letter : 如果...

    file-Users-sekishuuichirou-Desktop-john-20mayer_lesson-index.html-

    text-align: center;} 。一种 { background-color: rgb(174, 135, 211);} i:悬停{颜色:黑色; } 一世 { padding-right: 40px;font-size: 23px;} .official:hover {颜色:黑色;; } .main-logo {字体大小:190px; ...

    CSS 垂直水平居中的5种最佳解决方案

    CSS 居中对齐 代码中均省略了浏览器前缀 以下例子以我的个人的标准排序 当然也有更多的居中处理方法 但我觉得只有这5种方法是最完善的解决方案 flex 居中 优点:可对未知高度进行居中处理 &lt;style&gt; .wrap{...

    DIV和SPAN垂直居中对齐的实现方法

    水平居中很简单,设置text-align:center就可以了,但是垂直居中一直都不得其解! 以前总是尝试着调padding-top,但是有的时候好使,更多的时候不行,今天同样,当height值不大时,增加padding-top就会增加了整个DIV...

    Flutter:Center(居中布局),Padding(填充布局),Align(对齐布局)

    文章目录Center (居中布局)Padding (填充布局)Align (对齐布局) Center (居中布局) 在Center布局中,子元素处于水平和垂直方向的中间位置。代码如下: void main() =&gt; runApp(MyApp()); class MyApp extends...

Global site tag (gtag.js) - Google Analytics