六种实现元素水平居中

六种实现元素水平居中

居中效果在CSS中很是普通的效果,平时大家所看到的居中效果主要分为三大类:水平居中、垂直居中和水平垂直居中。而其中水平居中相对于后两者来说要简单得多。早期总结了一下互联网上有关于水平垂直居中的几种实现方案,比如说《 CSS制作水平垂直居中对齐 》中介绍了八中实现水平垂直的方案,而在《 CSS制作图片水平垂直居中 》一文介绍了四种实现图片垂直居中的方案,并且在《 CSS3实现水平垂直居中 》使用了css3的flexbox的属性轻松实现多行文本水平垂直居中的方法。当然大家有可能认为这些方法对于浏览嘎嘎的兼容性处理太烦了,也有人使用jQuery的方法实现水平垂直居中效果,比如在《 jQuery制作元素在屏幕中水平垂直居中效果 》中介绍的。

回到我们今天的话题,水平居中的实现方案,大家最熟悉的莫过开给元素定一个显示式的宽度,然后加上margin的左右值为auto。如:

[css]  view plain  copy
 print ?
  1. <span class="class">.center</span> <span class="rules">{  
  2.     <span class="rule"><span class="attribute">width</span>:<span class="value"> <span class="number">960</span>px;</span></span>  
  3.     <span class="rule"><span class="attribute">margin-left</span>:<span class="value"auto;</span></span>  
  4.     <span class="rule"><span class="attribute">margin-right</span>:<span class="value"auto;</span></span>  
  5. <span class="rule">}</span></span>    

这种方法给知道了宽度的元素设置居中是最方便不过的了,但有很多情况之下,我们是无法确定元素容器的宽度。换句话说,未有明确宽度的时候,上面的方法无法让我们实现元素水平居中。那要怎么办呢?这也就是我们今天需要讨论的问题。

为了更好的说明问题,我们来看一个制作分页效果的代码:

HTML

[xml]  view plain  copy
 print ?
  1. <span class="tag"><<span class="title">div</span> <span class="attribute">class</span>=<span class="value">"pagination"</span>></span>  
  2.   <span class="tag"><<span class="title">ul</span>></span>  
  3.     <span class="tag"><<span class="title">li</span>></span><span class="tag"><<span class="title">a</span> <span class="attribute">href</span>=<span class="value">"#"</span>></span>Prev<span class="tag"></<span class="title">a</span>></span><span class="tag"></<span class="title">li</span>></span>  
  4.     <span class="tag"><<span class="title">li</span>></span><span class="tag"><<span class="title">a</span> <span class="attribute">href</span>=<span class="value">"#"</span>></span>1<span class="tag"></<span class="title">a</span>></span><span class="tag"></<span class="title">li</span>></span>  
  5.     <span class="tag"><<span class="title">li</span>></span><span class="tag"><<span class="title">a</span> <span class="attribute">href</span>=<span class="value">"#"</span>></span>2<span class="tag"></<span class="title">a</span>></span><span class="tag"></<span class="title">li</span>></span>  
  6.     <span class="tag"><<span class="title">li</span>></span><span class="tag"><<span class="title">a</span> <span class="attribute">href</span>=<span class="value">"#"</span>></span>3<span class="tag"></<span class="title">a</span>></span><span class="tag"></<span class="title">li</span>></span>  
  7.     <span class="tag"><<span class="title">li</span>></span><span class="tag"><<span class="title">a</span> <span class="attribute">href</span>=<span class="value">"#"</span>></span>4<span class="tag"></<span class="title">a</span>></span><span class="tag"></<span class="title">li</span>></span>  
  8.     <span class="tag"><<span class="title">li</span>></span><span class="tag"><<span class="title">a</span> <span class="attribute">href</span>=<span class="value">"#"</span>></span>5<span class="tag"></<span class="title">a</span>></span><span class="tag"></<span class="title">li</span>></span>  
  9.     <span class="tag"><<span class="title">li</span>></span><span class="tag"><<span class="title">a</span> <span class="attribute">href</span>=<span class="value">"#"</span>></span>Next<span class="tag"></<span class="title">a</span>></span><span class="tag"></<span class="title">li</span>></span>  
  10.   <span class="tag"></<span class="title">ul</span>></span>  
  11. <span class="tag"></<span class="title">di  
  12. </span></span>  

给分页加上样式:

[css]  view plain  copy
 print ?
  1. <span class="class">.pagination</span> <span class="tag">li</span> <span class="rules">{  
  2.   <span class="rule"><span class="attribute">line-height</span>:<span class="value"> <span class="number">25</span>px;</span></span>  
  3. <span class="rule">}</span></span>  
  4. <span class="class">.pagination</span> <span class="tag">a</span> <span class="rules">{  
  5.   <span class="rule"><span class="attribute">display</span>:<span class="value"block;</span></span>  
  6.   <span class="rule"><span class="attribute">color</span>:<span class="value"> <span class="hexcolor">#f2f2f2</span>;</span></span>  
  7.   <span class="rule"><span class="attribute">text-shadow</span>:<span class="value"> <span class="number">1</span>px <span class="number">0</span> <span class="number">0</span> <span class="hexcolor">#101011</span>;</span></span>  
  8.   <span class="rule"><span class="attribute">padding</span>:<span class="value"> <span class="number">0</span> <span class="number">10</span>px;</span></span>  
  9.   <span class="rule"><span class="attribute">border-radius</span>:<span class="value"> <span class="number">2</span>px;</span></span>  
  10.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#5a5b5c</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#080808</span>;</span></span>  
  11.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#<span class="number">434345</span>,#<span class="number">2</span>f3032)</span>;</span></span>  
  12. <span class="rule">}</span></span>  
  13. <span class="class">.pagination</span> <span class="tag">a</span><span class="pseudo">:hover</span> <span class="rules">{  
  14.   <span class="rule"><span class="attribute">text-decoration</span>:<span class="value"none;</span></span>  
  15.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#f9bd71</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#0a0a0a</span>;</span></span>  
  16.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#f48b03,#c87100)</span>;</span></span>  
  17. <span class="rule">}</span></span>    

这是一个极普通的样式代码,初步的效果:

分页导航效果

这很显然不是我们需要的效果,接下来我们分几种方案来制作:

一、margin和width实现水平居中

第一种方法是最古老的实现方案,也是大家最常见的方案,在分页容器上定义一个宽度,然后配合margin的左右值为“auto”实现效果:

[css]  view plain  copy
 print ?
  1. <strong style="color:green"><span class="class">.pagination</span> <span class="rules">{  
  2.   <span class="rule"><span class="attribute">width</span>:<span class="value"> <span class="number">293</span>px;</span></span>  
  3.   <span class="rule"><span class="attribute">margin-left</span>:<span class="value"auto;</span></span>  
  4.   <span class="rule"><span class="attribute">margin-right</span>:<span class="value"auto;</span></span>  
  5. <span class="rule">}</span></span></strong>  
  6. <span class="class">.pagination</span> <span class="tag">li</span> <span class="rules">{  
  7.   <span class="rule"><span class="attribute">line-height</span>:<span class="value"> <span class="number">25</span>px;</span></span>  
  8. <strong style="color:green"><span class="rule"><span class="attribute">display</span>:<span class="value"inline;</span></span>  
  9.   <span class="rule"><span class="attribute">float</span>:<span class="value"left;</span></span>  
  10.   <span class="rule"><span class="attribute">margin</span>:<span class="value"> <span class="number">0</span> <span class="number">5</span>px;</span></span></strong>  
  11. <span class="rule">}</span></span>  
  12. <span class="class">.pagination</span> <span class="tag">a</span> <span class="rules">{  
  13.   <span class="rule"><span class="attribute">display</span>:<span class="value"block;</span></span>  
  14.   <span class="rule"><span class="attribute">color</span>:<span class="value"> <span class="hexcolor">#f2f2f2</span>;</span></span>  
  15.   <span class="rule"><span class="attribute">text-shadow</span>:<span class="value"> <span class="number">1</span>px <span class="number">0</span> <span class="number">0</span> <span class="hexcolor">#101011</span>;</span></span>  
  16.   <span class="rule"><span class="attribute">padding</span>:<span class="value"> <span class="number">0</span> <span class="number">10</span>px;</span></span>  
  17.   <span class="rule"><span class="attribute">border-radius</span>:<span class="value"> <span class="number">2</span>px;</span></span>  
  18.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#5a5b5c</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#080808</span>;</span></span>  
  19.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#<span class="number">434345</span>,#<span class="number">2</span>f3032)</span>;</span></span>  
  20. <span class="rule">}</span></span>  
  21. <span class="class">.pagination</span> <span class="tag">a</span><span class="pseudo">:hover</span> <span class="rules">{  
  22.   <span class="rule"><span class="attribute">text-decoration</span>:<span class="value"none;</span></span>  
  23.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#f9bd71</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#0a0a0a</span>;</span></span>  
  24.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#f48b03,#c87100)</span>;</span></span>  
  25. <span class="rule">}</span></span>    

代码中绿色部分是为了实现分页居中效果而添加的代码。(下文中没有特殊声明,绿色部分代码表示新增加的代码。),先来看看效果:

分页导航效果

效果是让我们实现了,但其扩展性那就不一定强了。示例中只显示了五页和向前向后的七个显项,但往往我们很多情况下是不知道会有多少个分页项显示出来,而且也无法确定每个分页选项的宽度是多少,也就无法确认容器的宽度。

优点:实现方法简单易懂,浏览器兼容性强;

缺点:扩展性差,无法自适应未知项情况。

二、inline-block实现水平居中方法

这个方法早期在《如何解决inline-block元素的空白间距》和《CSS3制作的分页导航》中都有涉及到,但未单独提取出来。此次,将这种方法拿出来说。

仅inline-block属性是无法让元素水平居中,他的关键之处要在元素的父容器中设置text-align的属性为“center”,这样才能达到效果:

[css]  view plain  copy
 print ?
  1. <strong style="color:green"><span class="class">.pagination</span> <span class="rules">{  
  2.   <span class="rule"><span class="attribute">text-align</span>:<span class="value"center;</span></span>  
  3.   <span class="rule"><span class="attribute">font-size</span>:<span class="value"> <span class="number">0</span>;</span></span>  
  4.   <span class="rule"><span class="attribute">letter-spacing</span>:<span class="value"> -<span class="number">4</span>px;</span></span>  
  5.   <span class="rule"><span class="attribute">word-spacing</span>:<span class="value"> -<span class="number">4</span>px;</span></span>  
  6. <span class="rule">}</span></span></strong>  
  7. <span class="class">.pagination</span> <span class="tag">li</span> <span class="rules">{  
  8.   <span class="rule"><span class="attribute">line-height</span>:<span class="value"> <span class="number">25</span>px;</span></span>  
  9.   <span class="rule"><span class="attribute">margin</span>:<span class="value"> <span class="number">0</span> <span class="number">5</span>px;</span></span>  
  10. <strong style="color:green"><span class="rule"><span class="attribute">display</span>:<span class="value"> inline-block;</span></span>  
  11.   <span class="rule">*<span class="attribute">display</span>:<span class="value"inline;</span></span>  
  12.   <span class="rule"><span class="attribute">zoom</span>:<span class="value"><span class="number">1</span>;</span></span>  
  13.   <span class="rule"><span class="attribute">letter-spacing</span>:<span class="value"normal;</span></span>    
  14.   <span class="rule"><span class="attribute">word-spacing</span>:<span class="value"normal;</span></span>  
  15.   <span class="rule"><span class="attribute">font-size</span>:<span class="value"> <span class="number">12</span>px;</span></span></strong>  
  16. <span class="rule">}</span></span>  
  17. <span class="class">.pagination</span> <span class="tag">a</span> <span class="rules">{  
  18.   <span class="rule"><span class="attribute">display</span>:<span class="value"block;</span></span>  
  19.   <span class="rule"><span class="attribute">color</span>:<span class="value"> <span class="hexcolor">#f2f2f2</span>;</span></span>  
  20.   <span class="rule"><span class="attribute">text-shadow</span>:<span class="value"> <span class="number">1</span>px <span class="number">0</span> <span class="number">0</span> <span class="hexcolor">#101011</span>;</span></span>  
  21.   <span class="rule"><span class="attribute">padding</span>:<span class="value"> <span class="number">0</span> <span class="number">10</span>px;</span></span>  
  22.   <span class="rule"><span class="attribute">border-radius</span>:<span class="value"> <span class="number">2</span>px;</span></span>  
  23.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#5a5b5c</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#080808</span>;</span></span>  
  24.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#<span class="number">434345</span>,#<span class="number">2</span>f3032)</span>;</span></span>  
  25. <span class="rule">}</span></span>  
  26. <span class="class">.pagination</span> <span class="tag">a</span><span class="pseudo">:hover</span> <span class="rules">{  
  27.   <span class="rule"><span class="attribute">text-decoration</span>:<span class="value"none;</span></span>  
  28.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#f9bd71</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#0a0a0a</span>;</span></span>  
  29.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#f48b03,#c87100)</span>;</span></span>  
  30. <span class="rule">}</span></span>    

效果如下:

分页导航效果

这个方法相对来说也是简单易懂,但使用了inline-block解决了水平居中的问题,却又产生了一个新的问题,就是分页项与分页项由回车符带来的空白间距,那么不知情的同学就会不知道如何解决?(而且这个间距并不是所有浏览器都有),所以需要解决下inline-block带来的间距,详细的解决方法可以阅读《如何解决inline-block元素的空白间距》一文。

做点:简单易懂,扩展性强;

缺点:需要额外处理inline-block的浏览器兼容性。

三、浮动实现水平居中的方法

刚看到标题,大家可能会感到很意外,元素都浮动了,他还能水平居中?大家都知道,浮动要么靠左、要么靠右,还真少见有居中的。其实略加处理就有了。

[css]  view plain  copy
 print ?
  1. <strong style="color:green"><span class="class">.pagination</span> <span class="rules">{  
  2.   <span class="rule"><span class="attribute">float</span>:<span class="value"left;</span></span>  
  3.   <span class="rule"><span class="attribute">width</span>:<span class="value"> <span class="number">100</span>%;</span></span>  
  4.   <span class="rule"><span class="attribute">overflow</span>:<span class="value"hidden;</span></span>  
  5.   <span class="rule"><span class="attribute">position</span>:<span class="value"relative;</span></span>  
  6. <span class="rule">}</span></span>  
  7. <span class="class">.pagination</span> <span class="tag">ul</span> <span class="rules">{  
  8.   <span class="rule"><span class="attribute">clear</span>:<span class="value"left;</span></span>  
  9.   <span class="rule"><span class="attribute">float</span>:<span class="value"left;</span></span>  
  10.   <span class="rule"><span class="attribute">position</span>:<span class="value"relative;</span></span>  
  11.   <span class="rule"><span class="attribute">left</span>:<span class="value"> <span class="number">50</span>%;</span></span><span class="comment">/*整个分页向右边移动宽度的50%*/</span>  
  12.   <span class="rule"><span class="attribute">text-align</span>:<span class="value"center;</span></span>  
  13. <span class="rule">}</span></span></strong>  
  14. <span class="class">.pagination</span> <span class="tag">li</span> <span class="rules">{  
  15.   <span class="rule"><span class="attribute">line-height</span>:<span class="value"> <span class="number">25</span>px;</span></span>  
  16.   <span class="rule"><span class="attribute">margin</span>:<span class="value"> <span class="number">0</span> <span class="number">5</span>px;</span></span>  
  17. <strong style="color:green"><span class="rule"><span class="attribute">display</span>:<span class="value"block;</span></span>  
  18.   <span class="rule"><span class="attribute">float</span>:<span class="value"left;</span></span>  
  19.   <span class="rule"><span class="attribute">position</span>:<span class="value"relative;</span></span>  
  20.   <span class="rule"><span class="attribute">right</span>:<span class="value"> <span class="number">50</span>%;</span></span><span class="comment">/*将每个分页项向左边移动宽度的50%*/</span></strong>  
  21. <span class="rule">}</span></span>  
  22. <span class="class">.pagination</span> <span class="tag">a</span> <span class="rules">{  
  23.   <span class="rule"><span class="attribute">display</span>:<span class="value"block;</span></span>  
  24.   <span class="rule"><span class="attribute">color</span>:<span class="value"> <span class="hexcolor">#f2f2f2</span>;</span></span>  
  25.   <span class="rule"><span class="attribute">text-shadow</span>:<span class="value"> <span class="number">1</span>px <span class="number">0</span> <span class="number">0</span> <span class="hexcolor">#101011</span>;</span></span>  
  26.   <span class="rule"><span class="attribute">padding</span>:<span class="value"> <span class="number">0</span> <span class="number">10</span>px;</span></span>  
  27.   <span class="rule"><span class="attribute">border-radius</span>:<span class="value"> <span class="number">2</span>px;</span></span>  
  28.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#5a5b5c</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#080808</span>;</span></span>  
  29.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#<span class="number">434345</span>,#<span class="number">2</span>f3032)</span>;</span></span>  
  30. <span class="rule">}</span></span>  
  31. <span class="class">.pagination</span> <span class="tag">a</span><span class="pseudo">:hover</span> <span class="rules">{  
  32.   <span class="rule"><span class="attribute">text-decoration</span>:<span class="value"none;</span></span>  
  33.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#f9bd71</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#0a0a0a</span>;</span></span>  
  34.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#f48b03,#c87100)</span>;</span></span>  
  35. <span class="rule">}</span></span>    

效果如下所示:

分页导航效果

这种方法实现和前面的与众不同,使用了浮动配合position定位实现。下面简单的介绍了一下这种方法实现原理,详细的可以阅读Matthew James Taylor写的《Horizontally Centered Menus with no CSS hacks》一文。

没有浮动的div:大家都知道div是一个块元素,其默认的宽度就是100%,如图所示:

分页导航效果

如果div设置了浮动之后,他的内容有多宽度就会撑开有多大的容器(除显式设置元素宽度值之外),这也是我们实现让分页导航居中的关键所在:

分页导航效果

接下来使用传统的制作方法,我们会让导航浮动到左边,而且每个分页项也进行浮动,就如下图所示一样:

分页导航效果

现在要想的办法是让分页导航居中的效果了,在这里是通过“position:relative”属性实现,首先在列表项“ul”上向右移动50%(left:50%;),看到如下图所示:

分页导航效果

如上图所示一样,整个分页向右移动了50%的距离,紧接着我们在“li”上也定义“position:relative”属性,但其移动的方向和列表“ul”移动的方向刚好是反方向,而其移动的值保持一致:

分页导航效果

这样一来就实现了float浮动居中的效果。

特别声明:方法三思想来源于Matthew James Taylor写的《Horizontally Centered Menus with no CSS hacks》一文,并且引用其文中演示的示意图。

优点:兼容性强,扩展性强;

缺点:实现原理较复杂。

四、绝对定位实现水平居中

绝对定位实现水平居中,我想大家也非常的熟悉了,并且用得一定不少,早期是这样使用的:

[css]  view plain  copy
 print ?
  1. <span class="class">.ele</span> <span class="rules">{  
  2.     <span class="rule"><span class="attribute">position</span>:<span class="value"absolute;</span></span>  
  3.     <span class="rule"><span class="attribute">width</span>:<span class="value"> 宽度值;</span></span>  
  4.     <span class="rule"><span class="attribute">left</span>:<span class="value"> <span class="number">50</span>%;</span></span>  
  5.     <span class="rule"><span class="attribute">margin-left</span>:<span class="value"> -(宽度值/<span class="number">2</span>);</span></span>  
  6. <span class="rule">}</span></span>    

但这种实现我们有一个难题,我并不知道元素的宽度是多少,这样也就存在如方法一所说的难题,但我们可以借助方法三做一点变通:

[css]  view plain  copy
 print ?
  1. <strong style="color:green"><span class="class">.pagination</span> <span class="rules">{  
  2.   <span class="rule"><span class="attribute">position</span>:<span class="value"relative;</span></span>  
  3. <span class="rule">}</span></span>  
  4. <span class="class">.pagination</span> <span class="tag">ul</span> <span class="rules">{  
  5.   <span class="rule"><span class="attribute">position</span>:<span class="value"absolute;</span></span>  
  6.   <span class="rule"><span class="attribute">left</span>:<span class="value"> <span class="number">50</span>%;</span></span>  
  7. <span class="rule">}</span></span></strong>  
  8. <span class="class">.pagination</span> <span class="tag">li</span> <span class="rules">{  
  9.   <span class="rule"><span class="attribute">line-height</span>:<span class="value"> <span class="number">25</span>px;</span></span>  
  10.   <span class="rule"><span class="attribute">margin</span>:<span class="value"> <span class="number">0</span> <span class="number">5</span>px;</span></span>  
  11.  <strong style="color:green"><span class="rule"><span class="attribute">float</span>:<span class="value"left;</span></span>  
  12.   <span class="rule"><span class="attribute">position</span>:<span class="value"relative;</span></span><span class="comment">/*注意,这里不能是absolute,大家懂的*/</span>  
  13.   <span class="rule"><span class="attribute">right</span>:<span class="value"> <span class="number">50</span>%;</span></span></strong>  
  14. <span class="rule">}</span></span>  
  15. <span class="class">.pagination</span> <span class="tag">a</span> <span class="rules">{  
  16.   <span class="rule"><span class="attribute">display</span>:<span class="value"block;</span></span>  
  17.   <span class="rule"><span class="attribute">color</span>:<span class="value"> <span class="hexcolor">#f2f2f2</span>;</span></span>  
  18.   <span class="rule"><span class="attribute">text-shadow</span>:<span class="value"> <span class="number">1</span>px <span class="number">0</span> <span class="number">0</span> <span class="hexcolor">#101011</span>;</span></span>  
  19.   <span class="rule"><span class="attribute">padding</span>:<span class="value"> <span class="number">0</span> <span class="number">10</span>px;</span></span>  
  20.   <span class="rule"><span class="attribute">border-radius</span>:<span class="value"> <span class="number">2</span>px;</span></span>  
  21.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#5a5b5c</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#080808</span>;</span></span>  
  22.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#<span class="number">434345</span>,#<span class="number">2</span>f3032)</span>;</span></span>  
  23. <span class="rule">}</span></span>  
  24. <span class="class">.pagination</span> <span class="tag">a</span><span class="pseudo">:hover</span> <span class="rules">{  
  25.   <span class="rule"><span class="attribute">text-decoration</span>:<span class="value"none;</span></span>  
  26.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#f9bd71</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#0a0a0a</span>;</span></span>  
  27.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#f48b03,#c87100)</span>;</span></span>  
  28. <span class="rule">}</span></span>    

效果如下所示:

分页导航效果

优点:扩展性强,兼容性强;

缺点:理解性难。

五、CSS3的flex实现水平居中方法

CSS3的flex是一个很强大的功能,她能让我们的布局变得更加灵活与方便,唯一的就是目前浏览器的兼容性较差。那么第五种方法,我们就使用flex来实现,其实这种方法早在《CSS3实现水平垂直居中》一文有介绍,我们把水平居中的部分代码取出来:

[css]  view plain  copy
 print ?
  1. <strong style="color:green"><span class="class">.pagination</span> <span class="rules">{  
  2.   <span class="rule"><span class="attribute">display</span>:<span class="value"> -webkit-box;</span></span>  
  3.   <span class="rule"><span class="attribute">-webkit-box-orient</span>:<span class="value"> horizontal;</span></span>  
  4.   <span class="rule"><span class="attribute">-webkit-box-pack</span>:<span class="value"center;</span></span>  
  5.   <span class="rule"><span class="attribute">display</span>:<span class="value"> -moz-box;</span></span>  
  6.   <span class="rule"><span class="attribute">-moz-box-orient</span>:<span class="value"> horizontal;</span></span>  
  7.   <span class="rule"><span class="attribute">-moz-box-pack</span>:<span class="value"center;</span></span>  
  8.   <span class="rule"><span class="attribute">display</span>:<span class="value"> -o-box;</span></span>  
  9.   <span class="rule"><span class="attribute">-o-box-orient</span>:<span class="value"> horizontal;</span></span>  
  10.   <span class="rule"><span class="attribute">-o-box-pack</span>:<span class="value"center;</span></span>  
  11.   <span class="rule"><span class="attribute">display</span>:<span class="value"> -ms-box;</span></span>  
  12.   <span class="rule"><span class="attribute">-ms-box-orient</span>:<span class="value"> horizontal;</span></span>  
  13.   <span class="rule"><span class="attribute">-ms-box-pack</span>:<span class="value"center;</span></span>  
  14.   <span class="rule"><span class="attribute">display</span>:<span class="value"> box;</span></span>  
  15.   <span class="rule"><span class="attribute">box-orient</span>:<span class="value"> horizontal;</span></span>  
  16.   <span class="rule"><span class="attribute">box-pack</span>:<span class="value"center;</span></span>  
  17. <span class="rule">}</span></span></strong>  
  18. <span class="class">.pagination</span> <span class="tag">li</span> <span class="rules">{  
  19.   <span class="rule"><span class="attribute">line-height</span>:<span class="value"> <span class="number">25</span>px;</span></span>  
  20.   <span class="rule"><span class="attribute">margin</span>:<span class="value"> <span class="number">0</span> <span class="number">5</span>px;</span></span>  
  21. <strong style="color:green"><span class="rule"><span class="attribute">float</span>:<span class="value"left;</span></span></strong>  
  22. <span class="rule">}</span></span>  
  23. <span class="class">.pagination</span> <span class="tag">a</span> <span class="rules">{  
  24.   <span class="rule"><span class="attribute">display</span>:<span class="value"block;</span></span>  
  25.   <span class="rule"><span class="attribute">color</span>:<span class="value"> <span class="hexcolor">#f2f2f2</span>;</span></span>  
  26.   <span class="rule"><span class="attribute">text-shadow</span>:<span class="value"> <span class="number">1</span>px <span class="number">0</span> <span class="number">0</span> <span class="hexcolor">#101011</span>;</span></span>  
  27.   <span class="rule"><span class="attribute">padding</span>:<span class="value"> <span class="number">0</span> <span class="number">10</span>px;</span></span>  
  28.   <span class="rule"><span class="attribute">border-radius</span>:<span class="value"> <span class="number">2</span>px;</span></span>  
  29.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#5a5b5c</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#080808</span>;</span></span>  
  30.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#<span class="number">434345</span>,#<span class="number">2</span>f3032)</span>;</span></span>  
  31. <span class="rule">}</span></span>  
  32. <span class="class">.pagination</span> <span class="tag">a</span><span class="pseudo">:hover</span> <span class="rules">{  
  33.   <span class="rule"><span class="attribute">text-decoration</span>:<span class="value"none;</span></span>  
  34.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#f9bd71</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#0a0a0a</span>;</span></span>  
  35.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#f48b03,#c87100)</span>;</span></span>  
  36. <span class="rule">}</span></span>    

效果如下:

分页导航效果

优点:实现便捷,扩展性强

缺点:兼容性差。

六、CSS3的fit-content实现水平居中方法

今天看《Horizontal centering using CSS fit-content value》一文,让我体验了一下"fit-content"制作水平居中的方法。我也将这种方法收进来。

“fit-content”是CSS中给“width”属性新加的一个属性值,他配合margin可以让我轻松的实现水平居中的效果:

[css]  view plain  copy
 print ?
  1. <strong style="color:green"><span class="class">.pagination</span> <span class="tag">ul</span> <span class="rules">{  
  2.   <span class="rule"><span class="attribute">width</span>:<span class="value"> -moz-fit-content;</span></span>  
  3.   <span class="rule"><span class="attribute">width</span>:<span class="value">-webkit-fit-content;</span></span>  
  4.   <span class="rule"><span class="attribute">width</span>:<span class="value"> fit-content;</span></span>  
  5.   <span class="rule"><span class="attribute">margin-left</span>:<span class="value"auto;</span></span>  
  6.   <span class="rule"><span class="attribute">margin-right</span>:<span class="value"auto;</span></span>  
  7. <span class="rule">}</span></span></strong>  
  8. <span class="class">.pagination</span> <span class="tag">li</span> <span class="rules">{  
  9.   <span class="rule"><span class="attribute">line-height</span>:<span class="value"> <span class="number">25</span>px;</span></span>  
  10.   <span class="rule"><span class="attribute">margin</span>:<span class="value"> <span class="number">0</span> <span class="number">5</span>px;</span></span>  
  11. <strong style="color:green"><span class="rule"><span class="attribute">float</span>:<span class="value"left;</span></span></strong>  
  12. <span class="rule">}</span></span>  
  13. <span class="class">.pagination</span> <span class="tag">a</span> <span class="rules">{  
  14.   <span class="rule"><span class="attribute">display</span>:<span class="value"block;</span></span>  
  15.   <span class="rule"><span class="attribute">color</span>:<span class="value"> <span class="hexcolor">#f2f2f2</span>;</span></span>  
  16.   <span class="rule"><span class="attribute">text-shadow</span>:<span class="value"> <span class="number">1</span>px <span class="number">0</span> <span class="number">0</span> <span class="hexcolor">#101011</span>;</span></span>  
  17.   <span class="rule"><span class="attribute">padding</span>:<span class="value"> <span class="number">0</span> <span class="number">10</span>px;</span></span>  
  18.   <span class="rule"><span class="attribute">border-radius</span>:<span class="value"> <span class="number">2</span>px;</span></span>  
  19.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#5a5b5c</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#080808</span>;</span></span>  
  20.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#<span class="number">434345</span>,#<span class="number">2</span>f3032)</span>;</span></span>  
  21. <span class="rule">}</span></span>  
  22. <span class="class">.pagination</span> <span class="tag">a</span><span class="pseudo">:hover</span> <span class="rules">{  
  23.   <span class="rule"><span class="attribute">text-decoration</span>:<span class="value"none;</span></span>  
  24.   <span class="rule"><span class="attribute">box-shadow</span>:<span class="value"> <span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#f9bd71</span> inset,<span class="number">0</span> <span class="number">1</span>px <span class="number">0</span> <span class="hexcolor">#0a0a0a</span>;</span></span>  
  25.   <span class="rule"><span class="attribute">background</span>:<span class="value"> linear-<span class="function">gradient(top,#f48b03,#c87100)</span>;</span></span>  
  26. <span class="rule">}</span></span>    

效果如下:

分页导航效果

优点:简单易懂,扩展性强;

缺点:浏览器兼容性差

上面总共为大家整理了六种实现水平居中的方法,希望对大家有所帮助。如果您有更好的建议,希望能与我们一起分享。



出处:http://www.w3cplus.com/css/elements-horizontally-center-with-css.html

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值