翻译:http://blog.csdn.net/freshlover/article/details/11579669 原文:http://coding.smashingmagazine.com/2013/08/09/absolute-horizontal-vertical-centering-css/…
前言 我们都知道,固定高宽的div在网页中垂直居中很简单,相信大家也很容易的写出来,但是不是固定高宽的div如何垂直居中呢?我们在网页布局,特别是手机等web端网页经常是不固定高宽的div,那么这些div如何垂直居中呢?这篇文章,我总结一下. 固定高宽div垂直居中 如上图,固定高宽的很简单,写法如下: position: absolute; left: 50%; top: 50%; width:200px; height:100px; margin-left:-100px; margin-to…
设置要水平垂直居中的div的position为absolute,left:50%;margin-left为负的这个元素宽度的一半,同理,top:50%;margin-top为负的这个元素的高度的一半. 由此,便可以实现子元素的上下左右居中的效果,快去试试把 div{ width:300px; height:200px; position:absolute; left:50%; margin-left:-150px; top:50%; margin-top:-100px; }…
1. 宽高固定 设置要水平垂直居中的 div 的 position 为 absolute,left:50%; margin-left为负的这个元素宽度的一半,同理,top:50%;margin-top为负的这个元素的高度的一半. #child { width:300px; height:200px; position:absolute; left:50%; margin-left:-150px; top:50%; margin-top:-100px; } 2. 宽高不固定 由 1 可演变,既然…
css中元素的垂直水平居中是比较常见及较常使用的,在这里向大家介绍一下几种方式. 1.水平居中 margin: 0 auto; 效果图: 而文字的垂直水平居中也比较简单,加上line-height: 200px;与text-align: center;即可. #test{ width: 200px; height: 200px; line-height: 200px; background: red; margin: 0 auto; text-align: center; } 效果图: 2.元素…
最开始,我想说,这个体系有点大,我写的并不好.就当作是一个思路吧,虽然这个思路有点乱.几乎每一个实现方案的背后都是该属性及其组合的原理,每一个都要剖析其规范细节的话,这篇文章绝不会是这样的篇幅,所以每当需要说更多的时候我都简单阐述后一笔带过,然后附上参考资料.后面若是写css系列的时候再详细讲吧. 其实这道面试题,真的考察很多东西,个人理解它属于开放类型的问题,没有指定范围的答案,所以它就可以涉及到很大范围的知识概念,并且以此判断开发者对技术理解的深度和宽度.那么要解决这个问题,最大的难点在于分…
在CSS中对元素进行水平居中是非常简单的:如果它是一个行内元素,就对它的父元素应用 text-align: center ;如果它是一个块级元素,就对它自身应用 margin: auto.然而如果要对一个元素进行垂直居中,可能光是想想就令人头皮发麻了. 多年以来,垂直居中已经成为了CSS领域的圣杯,它同样也是前端开发圈内广为流传的笑话.原因在于它同时具备以下几条特征: 1)它是极其常见的需求. 2)从理论上来看,它似乎极其简单. 3)在实践中,它往往难如登天,当涉及尺寸不固定的元素时尤其如此.…
这里不讨论行内元素的居中!! 盒子垂直居中+水平居中的需求时经常遇到的,看到的较多实现逻辑是固定content-box的宽度,通过让margin-left和margin-top等于宽或高的负一半来实现,抑或不固定宽度,通过JS调整margin-left和margin-top的值,这俩种方法原理都一样. 而我接下来要讲的是content不定宽的情况下,CSS的源生实现. 利用table实现垂直水平居中 主要利用td的vertical-align: middle;属性实现垂直居中,当然你可以用dis…
在布局的时候经常能用到居中,在此总结一下 html结构: <div class="wrap"> <div class="content"></div> </div> 1.水平居中:margin:auto; .wrap{ width: 400px; height: 400px; background-color: lightblue; } .content{ width: 200px; height: 200px; ba…
实现css水平垂直居中的方法有很多,在这里我简单的说下四种比较常用的方法: 1.使用CSS3中的Flex布局 对于flex,我们要了解的是它是一个display的属性,而且必须要给他的父元素设置flex属性(flex必须配合绝对定位使用!!!!!),除了设置display:flex之外,还有另外两个属性需要设置,分别是justify-content和align-items,他们的意思分别是水平居中和垂直居中.HTML+CSS代码如下: body { position: absolute; wid…