`
ssxxjjii
  • 浏览: 938230 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

CSS中元素水平居中显示的方法

    博客分类:
  • css
 
阅读更多

http://www.downcodes.com/info/2009/06/12/20090612-3634.html

用CSS让元素居中显示并不是件很简单的事情。同样的CSS居中设置在不同浏览器中的表现也各有千秋。本文就介绍了在CSS中常见的几种让元素水平居中显示的方法。

  1.使用自动外边距实现居中

  CSS中首选的让元素水平居中的方法就是使用margin属性—将元素的margin-left和margin-right属性设置为auto即可。在实际使用中,我们可以为这些需要居中的元素创建一个起容器作用的div。需要特别注意的一点就是,必须为该容器指定宽度:

  CSS中对齐

  在大多数主流浏览器中,这种方法都非常有效,即使是Windows平台上的IE6,在其标准兼容模式(compliance mode)下也能够正常显示。但不幸的是,在更低版本的IE中,这种设置却并不能实现居中效果。所以若想在实际项目中使用这种方法,那么就要确保用户的IE浏览器版本不低于6.0。

  尽管在支持上不尽如人意,但大多数设计师都建议尽可能地使用这种方法。该方法也被认为是在各种用CSS实现元素水平居中方法中最正确、最合理的一种。

  2.使用text-align实现居中

  另一种实现元素居中的方法是使用text-align属性,将该属性值设置为center并应用到body元素上即可。这种做法是彻头彻尾的hack,但它却能兼容大多数浏览器,所以在某些情况下也自然必不可少。

  之所以说它是hack,是因为这种方法并没有将文本属性应用到文本上,而是应用到了作为容器的元素上。这也给我们带来了额外的工作。在创建好布局必须的div之后,我们要按照如下代码为body应用text-align属性:

  CSS中对齐

  之后会出现什么问题吗?body的所有子孙元素都会被居中显示。

  因此,我们就需要用再写一条规则,让其中的文本回到默认的居左对齐:

  CSS中对齐

  可以想象这条附加的规则将带来一些不便。另外,真正完全遵循标准的浏览器并不会改变容器的位置,而只会让其中的文字居中显示。

  3.组合使用自动外边距和文本对齐

  因为文本对齐居中方式有着良好的向下兼容性,且自动外边距方式也被大多数当代浏览器支持,所以很多设计师将二者组合起来使用,以期让居中效果得到最大限度的跨浏览器支持:

  CSS中对齐

  可是这始终是个hack,无论如何也算不上完美。我们还是需要为居中容器中的文本编写附加的规则,但至少在各个浏览器中看起来都不错。

  4.负外边距解决方案

  负外边距解决方案远不是仅仅为元素添加负外边距这么简单。这种方法需要同时使用绝对定位和负外边距两种技巧。

  下面是该方案的具体实现方法。首先,创建一个包含居中元素的容器,然后将其绝对定位于相对页面左边边缘50%的位置。这样,该容器的左外边距将从页面50%宽度的位置开始算起。

  然后,将容器的左外边距值设置为负的容器宽度的一半。这样即可将该容器固定在页面水平方向的中点。

  CSS中对齐

  虽然这并不是首选的解决方案,但也是个不错的方法,且适用性极广。

分享到:
评论

相关推荐

    CSS中元素水平居中显示的方法.pdf

    以下是对标题“CSS中元素水平居中显示的方法.pdf”和部分描述的详细解释: 1. **使用自动外边距实现居中** 这是最推荐的一种方式,通过设置`margin-left`和`margin-right`为`auto`,元素会自动在容器内水平居中。...

    CSS中元素水平居中显示的方法.docx

    在CSS中,元素的水平居中显示是一个常见的需求,但却涉及到多种不同的方法,每种方法在不同的浏览器环境下的兼容性和效果都有所差异。以下是一些常见的CSS居中技术的详细解释: 1. **使用自动外边距实现居中** 这...

    CSS常见的让元素水平居中显示方法.pdf

    在CSS布局设计中,使元素水平居中是一项常见的需求。以下是一些常用的方法: 1. **使用自动外边距实现居中**: 这种方法适用于块级元素,通过设置`margin-left`和`margin-right`为`auto`来实现居中。例如: ```...

    CSS常见的让元素水平居中显示方法.docx

    在CSS布局设计中,使元素水平居中是一项常见的需求。以下是一些常用的方法: 1. **使用自动外边距实现居中**: 这种方法适用于块级元素,通过设置`margin-left`和`margin-right`为`auto`来实现居中。例如: ```...

    css水平居中4种方式

    在CSS布局设计中,将元素水平居中对齐是一项常见的需求。无论是图片、宽度和高度固定的元素,还是自适应的动态元素,都有多种方法可以实现水平居中。以下是标题所提及的“css水平居中4种方式”的详细解析: 1. **...

    div+css垂直居中和水平居中

    3. **块级元素水平居中**: 可以通过设置`margin: auto;`实现块级元素的水平居中。确保元素宽度是固定的: ```css .element { width: 200px; margin: auto; } ``` 4. **行内元素水平居中**: 使用`display:...

    CSS常见的让元素水平居中显示的方法

    让我们先来看一下CSS中常见的几种让元素水平居中显示的方法。 用CSS让元素居中显示并不是件很简单的事情—同样的合法CSS居中设置在不同浏览器中的表现行为却各有千秋。让我们先来看一下CSS中常见的几种让元素水平...

    css3块元素居中

    `,内联元素(如`<span>`、`<a>`等)就会在其父元素中水平居中显示。 接下来,我们讨论定宽块元素的居中。如果块级元素(如`<div>`)具有固定宽度,可以通过设置`margin`属性实现居中。例如,若块元素的宽度为`200...

    CSS2.1如何让块元素垂直水平居中.rar

    在网页设计中,让元素在页面上垂直和水平居中是一项常见的需求,特别是在CSS2.1规范中。本文将深入探讨如何使用CSS2.1来实现这一目标,无论是对于已知宽高还是未知宽高的块级元素(div)。首先,我们需要理解CSS布局...

    CSS网页布局DIV水平居中的各种方法

    CSS 网页布局 DIV 水平居中的各种方法 在现代浏览器中,实现 DIV 的水平居中是一件非常简单的事情。下面我们将详细介绍几种常见的方法。 方法一:使用 margin:auto 这种方法是最简单的,直接将 DIV 的 margin ...

    CSS 图片水平垂直居中于DIV

    在网页设计中,将图片水平垂直居中于一个DIV元素是常见的需求,这涉及到CSS布局技术的运用。本文将深入探讨如何实现这个效果,并提供相关的源码示例。 首先,我们要明白CSS中的定位机制,包括静态定位、相对定位、...

    css如何让浮动元素水平居中

    对于定宽的非浮动元素我们可以在CSS中用 margin:0 auto 进行水平居中,对于不定宽的浮动元素我们也有一个常用的技巧解决它的水平居中问题。解决水平居中问题有很多种方法,下面先给大家分享一下三种方法,希望能帮助...

    DIV+CSS水平垂直居中

    DIV+CSS 水平垂直居中是Web开发中一个常见的问题,如何将DIV元素水平垂直居中是一个非常重要的知识点。本文将详细介绍DIV+CSS水平垂直居中的方法和实现原理。 一、使用position:absolute实现水平垂直居中 使用...

    css控制div中元素居中的示例.pdf

    本文将讨论 CSS 中常见的让元素水平居中显示的方法。这些方法可以让开发者更好地控制 div 中元素的布局,以实现更好的用户体验。 1. 使用自动外边距实现居中 CSS 中首选的让元素水平居中的方法就是使用 margin ...

    CSS实现完美垂直居中 - 蓝色理想

    CSS Grid布局允许更精细的控制,使用`align-items: center`和`justify-items: center`,或者`grid-template-areas`配合特定的占位符,可以实现元素的垂直和水平居中。 7. **使用伪元素进行居中**: 有时可以通过...

    css 未知高度元素绝对居中

    `,可以实现未知高度元素的垂直和水平居中。例如: ```css .parent { display: grid; place-items: center; } ``` 3. **绝对定位与transform** 对于不支持新布局模型的浏览器,可以使用绝对定位配合`...

    DIV+CSS 图片垂直居中效果

    /* 水平居中 */ align-items: center; /* 垂直居中 */ } ``` 4. **Grid布局** CSS Grid布局提供了一种二维的布局方式,可以同时处理行和列。对于图片垂直居中: ```css .container { display: grid; place...

Global site tag (gtag.js) - Google Analytics