Home  >  Article  >  Web Front-end  >  CSS tutorial: N ways to vertically center div_html/css_WEB-ITnose

CSS tutorial: N ways to vertically center div_html/css_WEB-ITnose

WBOY
WBOYOriginal
2016-06-24 12:30:00895browse

在说到这个问题的时候,也许有人会问CSS中不是有vertical-align属性来设置垂直居中的吗?即使是某些浏览器不支持我只需做少许的CSS

Hack技术就可以啊!所以在这里我还要?嗦两句,CSS中的确是有vertical-align属性,但是它只对(X)HTML元素中拥有valign特性的元素才生

效,例如表格元素中的、、等,而像

这样的元素是没有valign特性的,因此使用vertical-align对它们不起

作用。 

    相关教程:div水平居中的N种方法

    一、单行垂直居中

    如果一个容器中只有一行文字,对它实现居中相对比较简单,我们只需要设置它的实际高度height和所在行的高度line-height相等即可。

如: 

div {  
        height:25px;  
        line-height:25px;  
        overflow:hidden;  
 }  
    这段代码很简,后面使用overflow:hidden的设置是为了防止内容超出容器或者产生自动换行,这样就达不到垂直居中效果了。更多CSS教

程。 



 
  单行文字实现垂直居中
 
 
 
 
 

现在我们要使这段文字垂直居中显示!

 

二、多行未知高度文字的垂直居中

    如果一段内容,它的高度是可变的那么我们就可以使用上一节讲到的实现水平居中时使用到的最后一种方法,就是设定Padding,使上下的

padding值相同即可。同样的,这也是一种“看起来”的垂直居中方式,它只不过是使文字把

完全填充的一种访求而已。可以使用类似下

面的代码: 

div {  
 padding:25px;  
}  
    这种方法的优点就是它可以在任何浏览器上运行,并且代码很简单,只不过这种方法应用的前提就是容器的高度必须是可伸缩的。 



 
  多行文字实现垂直居中
 
 
 
 
 

现在我们要使这段文字垂直居中显示!<br>    div {<br>   padding:25px;<br>   border:1px solid #FF0099;<br>   background-color:#FFCCFF;<br>  }<br> 


 

三、多行文本固定高度的居中

    在本文的一开始,我们已经说过CSS中的vertical-align属性只会对拥有valign特性的(X)HTML标签起作用,但是在CSS中还有一个display

属性能够模拟

,所以我们可以使用这个属性来让
模拟
就可以使用vertical-align了。注意,display:table和

display:table-cell的使用方法,前者必须设置在父元素上,后者必须设置在子元素上,因此我们要为需要定位的文本再增加一个

元素:

 

div#wrap {  
    height:400px;  
 display:table;  
}  
div#content {  
  vertical-align:middle;  
    display:table-cell;  
   border:1px solid #FF0099;  
 background-color:#FFCCFF;  
 width:760px;  
}  



 
  多行文字实现垂直居中
 
 
 
 
 


 
现在我们要使这段文字垂直居中显示! Webjx.Com <br>  div#wrap {<br>   height:400px;<br>   display:table;<br>  }<br>  div#content {<br>   vertical-align:middle;<br>   display:table-cell;<br>   border:1px solid #FF0099;<br>   background-color:#FFCCFF;<br>   width:760px;<br>  }<br> 


 

    这个方法应该是很理想了,但是不幸的是Internet Explorer 6 并不能正确地理解display:table和display:table-cell,因此这种方法在

Internet Explorer 6及以下的版本中是无效的。嗯,这让人很郁闷!不过我们还其它的办法
 四、在Internet Explorer中的解决方案

    在Internet Explorer 6及以下版本中,在高度的计算上存在着缺陷的。在Internet Explorer 6中对父元素进行定位后,如果再对子元素

进行百分比计算时,计算的基础似乎是有继承性的(如果定位的数值是绝对数值没有这个问题,但是使用百分比计算的基础将不再是该元素的

高度,而从父元素继承来的定位高度)。例如,我们有下面这样一个(X)HTML代码段: 

 
 
 
  
 
 
 


    如果我们对subwrap进行了绝对定位,那么content也会继承了这个这个属性,虽然它不会在页面中马上显示出来,但是如果再对content进

行相对定位的时候,你使用的100%分比将不再是content原有的高度。例如,我们设定了subwrap的position为40%,我们如果想使content的上

边缘和wrap重合的话就必须设置top:-80%;那么,如果我们设定subwrap的top:50%的话,我们必须使用100%才能使content回到原来的位置上去

,但是如果我们把content也设置50%呢?那么它就正好垂直居中了。所以我们可以使用这中方法来实现Internet Explorer 6中的垂直居中: 

div#wrap {  
    border:1px solid #FF0099;  
 background-color:#FFCCFF;  
 width:760px;  
  height:400px;  
 position:relative;  
}  
div#subwrap {  
  position:absolute;  
    border:1px solid #000;  
    top:50%;  
}  
div#content {  
    border:1px solid #000;  
    position:relative;  
    top:-50%;  
}  
    当然,这段代码只能在Internet Exlporer 6等计算存在问题的浏览器中才会有作用。(不过我不解,我查阅了很多文章,不知道是因为出

处相同还是什么原因,似乎很多人都不愿意去解释Internet Exlporer 6中这这个Bug的原理,我也只是了解了一点皮毛,还要再研究) 



 
  多行文字实现垂直居中
 
 
 
 
 


 

  
现在我们要使这段文字垂直居中显示!<br>  div#wrap {<br>   border:1px solid #FF0099;<br>   background-color:#FFCCFF;<br>   width:760px;<br>   height:500px;<br>   position:relative;<br>  }<br>  div#subwrap {<br>   position:absolute;<br>   border:1px solid #000;<br>   top:50%;<br>  }<br>  div#content {<br>   border:1px solid #000;<br>   position:relative;<br>   top:-50%;<br>  }

 

 




5. The perfect solution

Then we can get a perfect solution by combining the above two methods, but this Knowledge of CSS hacks is required. If you use CSS Hack to distinguish browsers, you can

refer to this article "Simple CSS hack: distinguish IE6, IE7, IE8, Firefox, Opera":

div#wrap {
display:table;
border:1px solid #FF0099;
background-color:#FFCCFF;
width:760px;
height:400px;
_position:relative;
overflow:hidden;
}
div#subwrap {
vertical-align:middle;
display:table-cell;
_position:absolute; > }
div#content {
_position:relative;
_top:-50%;
}
At this point, a perfect centering solution is created.


Vertical centering of multi-line text</ title><br> <meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><br> <style type="text/css"><br> body { font-size:12px;font-family:tahoma;}<br> div#wrap {<br> display:table;<br> border:1px solid #FF0099;<br> background-color:#FFCCFF; <br> width:760px;<br> height:400px;<br> _position:relative;<br> overflow:hidden;<br> }<br> div#subwrap {<br> vertical-align:middle;<br> display:table-cell;<br> _position:absolute;<br> _top:50%;<br> }<br> div#content { <br> _position:relative;<br> _top:-50%;<br> }<br> </style><br> </head><br> <body><br> <div id="wrap"><br> <div id="subwrap" ><br> <div id="content"><pre class="brush:php;toolbar:false">Now we want to center this text vertically! <br> div#wrap {<br> border:1px solid #FF0099;<br> background-color:#FFCCFF;<br> width:760px;<br> height:500px;<br> position:relative;<br> }<br> div#subwrap {<br> position:absolute;<br> border:1px solid #000;<br> top:50%;<br> }<br> div#content {<br> border: 1px solid #000;<br> position:relative;<br> top:-50%;<br> }</pre><br> </div><br> </div><br> < ;/div><br> </body><br> </html><br> p.s. The value of vertical-align is middle, while the value of align for horizontal centering is center. Although they are both centered, the keyword Different <br> <br> </p></div><div class="nphpQianMsg"><div class="clear"></div></div><div class="nphpQianSheng"><span>Statement:</span><div>The content of this article is voluntarily contributed by netizens, and the copyright belongs to the original author. This site does not assume corresponding legal responsibility. If you find any content suspected of plagiarism or infringement, please contact admin@php.cn</div></div></div><div class="nphpSytBox"><span>Previous article:<a class="dBlack" title="CSS tutorial: N ways to vertically center divs [transfer]_html/css_WEB-ITnose" href="https://m.php.cn/faq/283511.html">CSS tutorial: N ways to vertically center divs [transfer]_html/css_WEB-ITnose</a></span><span>Next article:<a class="dBlack" title="CSS tutorial: N ways to vertically center divs [transfer]_html/css_WEB-ITnose" href="https://m.php.cn/faq/283514.html">CSS tutorial: N ways to vertically center divs [transfer]_html/css_WEB-ITnose</a></span></div><div class="nphpSytBox2"><div class="nphpZbktTitle"><h2>Related articles</h2><em><a href="https://m.php.cn/article.html" class="bBlack"><i>See more</i><b></b></a></em><div class="clear"></div></div><ul class="nphpXgwzList"><li><b></b><a href="https://m.php.cn/faq/348757.html" title="Summary of Html knowledge" class="aBlack">Summary of Html knowledge</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/faq/348804.html" title="How to learn HTML quickly" class="aBlack">How to learn HTML quickly</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/faq/348873.html" title="The difference between html xhtml xml" class="aBlack">The difference between html xhtml xml</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/faq/348884.html" title="The difference between src and href attributes" class="aBlack">The difference between src and href attributes</a><div class="clear"></div></li><li><b></b><a href="https://m.php.cn/faq/348902.html" title="About HTML5 and CSS replacement use" class="aBlack">About HTML5 and CSS replacement use</a><div class="clear"></div></li></ul></div></div><footer><div class="footer"><div class="footertop"><img src="/static/imghwm/logo.png" alt=""><p>Public welfare online PHP training,Help PHP learners grow quickly!</p></div><div class="footermid"><a href="https://m.php.cn/about/us.html">About us</a><a href="https://m.php.cn/about/disclaimer.html">Disclaimer</a><a href="https://m.php.cn/update/article_0_1.html">Sitemap</a></div><div class="footerbottom"><p> © php.cn All rights reserved </p></div></div></footer><script>isLogin = 0;</script><script type="text/javascript" src="/static/layui/layui.js"></script><script type="text/javascript" src="/static/js/global.js?4.9.47"></script></div><script src="https://vdse.bdstatic.com//search-video.v1.min.js"></script><link rel='stylesheet' id='_main-css' href='/static/css/viewer.min.css' type='text/css' media='all'/><script type='text/javascript' src='/static/js/viewer.min.js?1'></script><script type='text/javascript' src='/static/js/jquery-viewer.min.js'></script><script>jQuery.fn.wait = function (func, times, interval) { var _times = times || -1, //100次 _interval = interval || 20, //20毫秒每次 _self = this, _selector = this.selector, //选择器 _iIntervalID; //定时器id if( this.length ){ //如果已经获取到了,就直接执行函数 func && func.call(this); } else { _iIntervalID = setInterval(function() { if(!_times) { //是0就退出 clearInterval(_iIntervalID); } _times <= 0 || _times--; //如果是正数就 -- _self = $(_selector); //再次选择 if( _self.length ) { //判断是否取到 func && func.call(_self); clearInterval(_iIntervalID); } }, _interval); } return this; } $("table.syntaxhighlighter").wait(function() { $('table.syntaxhighlighter').append("<p class='cnblogs_code_footer'><span class='cnblogs_code_footer_icon'></span></p>"); }); $(document).on("click", ".cnblogs_code_footer",function(){ $(this).parents('table.syntaxhighlighter').css('display','inline-table');$(this).hide(); }); $('.nphpQianCont').viewer({navbar:true,title:false,toolbar:false,movable:false,viewed:function(){$('img').click(function(){$('.viewer-close').trigger('click');});}}); </script></body></html>