水平垂直居中方案与flexbox布局

水平垂直居中方案与flexbox布局水平垂直居中方案与 flexbox 布局

行内元素的水平居中    



要实现行内元素(等)的水平居中,只需把行内元素包裹在块级父层元素(

 
   
   垂直居中Demo 
    
   
#center

并且适用于文字,链接,及其inline或者inline-block、inline-table和inline-flex。
图片






块状元素的水平居中    

要实现块状元素(display:block)的水平居中,我们只需要将它的左右外边距margin-left和margin-right设置为auto,即可实现块状元素的居中,要水平居中的块状元素CSS设置如下:

 
    
    垂直居中Demo 
     
    
#center
图片



多个块状元素的水平居中    

要实现多个水平排列的块状元素的水平居中,传统的方法是将要水平排列的块状元素设为display:inline-block,然后在父级元素上设置text-align:center,达到与上面的行内元素的水平居中一样的效果。

 
   
   垂直居中Demo 
    
   
#center
#center
#center

图片 

 
 
 

已知高度宽度元素的水平垂直居中    

法一.

绝对定位与负边距实现。

利用绝对定位,将元素的top和left属性都设为50%,再利用margin边距,将元素回拉它本身高宽的一半,实现垂直居中。


         垂直居中Demo          
#center

图片 


法二.

绝对定位与margin。

这种方法也是利用绝对定位与margin,但是无需知道被垂直居中元素的高和宽。


         垂直居中Demo          
#center #center #center #center

未知高度和宽度元素的水平垂直居中    

法一.  当要被居中的元素是inline或者inline-block元素

当要被居中的元素是inline或者inline-block的时候,可以巧妙的将父级容器设置为display:table-cell,配合text-align:center和vertical-align:middle即可以实现水平垂直居中。 


 
     
     垂直居中Demo 
      
     
#center

图片 




 法二. Css3显威力


利用Css3的transform,可以轻松的在未知元素的高宽的情况下实现元素的垂直居中。 


 
     
     垂直居中Demo 
      
     
#center

图片 




法三. flex布局轻松解决

使用flex布局,无需绝对定位等改变布局的操作,可以轻松实现元素的水平垂直居中。

核心代码如下: 


           垂直居中Demo            
#center

图片


CSS3的transform和flex固然好用,但在项目的实际运用中必须考虑兼容问题,大量的hack代码可能会导致得不偿失。

某些浏览器仍需使用前缀写法:


.flexboxtest{

  display: flex;

  display: -webkit-flex; //Safari仍旧需要使用特定的浏览器前缀

} 




版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/220983.html原文链接:https://javaforall.net

(0)
上一篇 2026年3月17日 下午7:11
下一篇 2026年3月17日 下午7:12


相关推荐

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号