一篇文章带你了解CSS对齐方式

一、居中

1. 居中对齐元素

将块元素水平居中对齐(像

) , 使用 margin: auto;设置元素的宽度将阻止它伸展到容器的边缘。

然后元素将占用指定的宽度,剩下的空间将平分在两个边距之间:

这个div是居中的。

 
 
 
 
  1. .center { 
  2.     margin: auto; 
  3.     width: 50%; 
  4.     border: 3px solid green; 
  5.     padding: 10px; 

注意:如果没有设置宽度属性,则居中对齐没有效果 (或者设置到100%).

2. 居中对齐文本

将元素内部的文本居中, 使用text-align: center;

这些文本是居中的。

 
 
 
 
  1. .center { 
  2.     text-align: center; 
  3.     border: 3px solid green; 

3. 居中图片

居中图片, 使用 margin: auto; 并且设置为块级元素:

 
 
 
 
  1. img { 
  2.     display: block; 
  3.     margin: auto; 
  4.     width: 40%; 

二、左右

HTML代码:

 
 
 
 
  1.  
  2.  
  3.    
  4.   编程字典 
  5.  
  6.  
  7.  
  8.  
  9.   

    右对齐

     
  10.   

    如何正确定位元素与位置属性的一个例子:

     
  11.  
  12.    
  13.     

    在我年轻而脆弱的岁月里,父亲给了我一些我一直以来一直在思考的建议.

     
  14.   
 
  •  
  •  
  •  
  • 1. 左右对齐 - 使用 position

    对齐元素的一种方法是使用 position: absolute;

    在我年轻而脆弱的岁月里,父亲给了我一些我一直以来一直在思考的建议。

     
     
     
     
    1. .right { 
    2.     position: absolute; 
    3.     right: 0px; 
    4.     width: 300px; 
    5.     border: 3px solid #73AD21; 
    6.     padding: 10px; 

    注意:

    绝对定位元素从正常流中移除,并且可以重叠元素。

    当使用 position对齐元素时, 总是定义 margin 和 padding 为 元素. 这是为了避免不同浏览器的视觉差异。

    还有IE8和早期版本有一些问题, 当使用 position. 如果容器元素有一个指定的宽度 (例如:

    ) , 并且没有设置!DOCTYPE, IE8 和早期版本将添加 17px 外边距到右边. 这似乎是一条为滚动条预留空间. 因此,总是声明 !DOCTYPE 当使用 position时:

      
     
     
     
    1. body { 
    2.     margin: 0; 
    3.     padding: 0; 
    4.  
    5. .container { 
    6.     position: relative; 
    7.     width: 100%; 
    8.  
    9. .right { 
    10.     position: absolute; 
    11.     right: 0px; 
    12.     width: 300px; 
    13.     background-color: #b0e0e6; 

    2. 左右对齐 - 使用 float

    对齐元素的另一种方法是使用 float 属性:

      
     
     
     
    1. .right { 
    2.     float: right; 
    3.     width: 300px; 
    4.     border: 3px solid #73AD21; 
    5.     padding: 10px; 

    提示:

    当将元素使用浮动对齐时,总是为body元素定义边距和填充。这是为了避免不同浏览器的视觉差异。

      
     
     
     
    1. body { 
    2.     margin: 0; 
    3.     padding: 0; 
    4.  
    5. .right { 
    6.     float: right; 
    7.     width: 300px; 
    8.     background-color: #b0e0e6; 

    效果图:

    三、垂直居中,水平居中

    HTML代码:

      
     
     
     
    1.  
    2.  
    3.    
    4.   编程字典 
    5.  
    6.  
    7.  
    8.  
    9.   

      居中

       
    10.   

      在这个实例中, 

    11.      我们使用定位和transform属性实现元素的水平和垂直居中:

       
    12.  
    13.    
    14.      
    15.     

      我水平垂直居中.

       
    16.      
    17.   
     
  •  
  •   

    注意: transform属性不支持IE8和更早的版本.

     
  •  
  •  
  •  
  • 1. 使用 padding

    有许多方法来中心垂直CSS元素. 一个简单的解决方案是使用顶部和底部 padding:

      
     
     
     
    1. .center { 
    2.     padding: 70px 0; 
    3.     border: 3px solid green; 

    水平和垂直居中, 使用 padding 和 text-align: center:

    垂直居中

      
     
     
     
    1. .center { 
    2.     padding: 70px 0; 
    3.     border: 3px solid green; 
    4.     text-align: center; 

    2. 使用 line-height

    另一个技巧是使用 line-height 属性值等于 height 属性值.

      
     
     
     
    1. .center { 
    2.     line-height: 200px; 
    3.     height: 200px; 
    4.     border: 3px solid green; 
    5.     text-align: center; 
    6.  
    7. /* If the text has multiple lines, add the following: */ 
    8. .center p { 
    9.     line-height: 1.5; 
    10.     display: inline-block; 
    11.     vertical-align: middle; 

    3. 使用 position & transform

    如果padding和line-height不可选,第三种解决方案是使用定位和变换属性:

      
     
     
     
    1. .center { 
    2.     height: 200px; 
    3.     position: relative; 
    4.     border: 3px solid green; 
    5.  
    6. .center p { 
    7.     margin: 0; 
    8.     position: absolute; 
    9.     top: 50%; 
    10.     left: 50%; 
    11.     transform: translate(-50%, -50%); 

    四、总结

    本文基于Html基础,主要介绍了Html中对齐的方式,对于对齐中的标签做了详细的讲解,用丰富的案例 ,代码效果图的展示,帮助大家更好理解 。

    最后,希望可以帮助大家更好的学习CSS3。

    分享标题:一篇文章带你了解CSS对齐方式
    当前URL:http://www.mswzjz.cn/qtweb/news23/392173.html

    攀枝花网站建设、攀枝花网站运维推广公司-贝锐智能,是专注品牌与效果的网络营销公司;服务项目有等

    广告

    声明:本网站发布的内容(图片、视频和文字)以用户投稿、用户转载内容为主,如果涉及侵权请尽快告知,我们将会在第一时间删除。文章观点不代表本网站立场,如需处理请联系客服。电话:028-86922220;邮箱:631063699@qq.com。内容未经允许不得转载,或转载时需注明来源: 贝锐智能