zoukankan      html  css  js  c++  java
  • 块的垂直居中

    需要固定宽高的垂直居中:

    一,定位

      1.1 之absolute

      写法一:position:absolute;

      .one{            
        position:absolute;      
        width:200px;          
        height:200px;           
        top:50%;           
        left:50%;           
        margin-top:-100px;           
        margin-left:-100px;         
        background:red; 
      }

      写法二:margin:auto这个必须要有

    .two{        
      position:absolute;      
      width:140px;         
      height:140px;         
      top:0;        
      right:0;     
      bottom:0;   
      left:0;    
      margin:auto;   
      background:black;
    
    }

      1.2定位之fixed;

      写法同上。

    二,display:table-cell 属性使内容垂直居中

    .three{        
      display:table-cell;             
      vertical-align:middle;            
      text-align:center;        
      width:120px;            
      height:120px;          
    }

    三,行内元素的垂直居中line-height.

    四,css3

      4.1,css3的 display:-webkit-box 属性,再设置-webkit-box-pack:center/-webkit-box-align:center;

    .one{        
      width:90px;       
      height:90px;   
      display:-webkit-box;      
      -webkit-box-pack:center;        
      -webkit-box-align:center;     
      background:yellow;    
    }

      4.2 ,css3的新属性 transform:translate(x,y) 属性;这个方法可以不需要设定固定的宽高,在移动端用的会比较多,在移动端css3兼容的比较好

    .two{        
      position:absolute;      
      width:80px;         
      height:80px;         
      top:50%;          
      left:50%;       
      transform:translate(-50%,-50%);      
      -webkit-transform:translate(-50%,-50%);       
      -moz-transform:translate(-50%,-50%);      
      -ms-transform:translate(-50%,-50%);       
      background:green; 
    }

    五,:before元素

    .one{           
      position:fixed;   
      display:block; 
      top:0;  
      right:0;   
      bottom:0;     
      left:0;    
      text-align:center; 
      background:rgba(0,0,0,.5);
    }
    .one:before{           
      content:'';           
      display:inline-block;        
      vertical-align:middle;         
      height:100%;
    }
    .one .content{     
      display:inline-block;        
      vertical-align:middle;        
      width:60px;        
      height:60px;            
      line-height:60px;        
      background:yellow;
    }

    六,flex

    parentElement{
        display:flex;/*Flex布局*/
        display: -webkit-flex; /* Safari */
        align-items:center;/*指定垂直居中*/
    }

    不知道高度;

      一,定位和transform;

        1.1 不知道父与子容器的高度;

    parentElement{
      position:relative;
    }
    
    childElement{
      position: absolute;
      top: 50%;
      transform: translateY(-50%);
      -webkit-transform:translate(-50%);       
      -moz-transform:translate(-50%);      
      -ms-transform:translate(-50%);  
    }

        1.2 若父容器下只有一个元素,且父元素设置了高度,则只需要使用相对定位即可;

    parentElement{
      height:xxx;
    }
    
    .childElement {
      position: relative;
      top: 50%;
      transform: translateY(-50%);
      -webkit-transform:translate(-50%);       
      -moz-transform:translate(-50%);      
      -ms-transform:translate(-50%);  
    }

    七,inline-block;

      #box { height: 400px; background: #c00;}
      #content, #actor { display: inline-block; vertical-align: middle;}
      #content { font-size: 12px; color: #fff;}
      #actor {height: 400px; font-size: 0;}
      这里黑体字的比较重要;
    <!DOCTYPE html>
    <html>
        <head>
            <title>nav测试</title>
            <meta charset="UTF-8">
            <meta name="viewport" content="width=device-width, initial-scale=1.0">
            <style>
        #box { height: 400px; background: #c00;}
        #content, #actor { display: inline-block; vertical-align: middle;}
        #content { font-size: 12px; color: #fff;}
        #actor {height: 400px; font-size: 0;}
    </style>
        </head>
        <body>
            <div id="box">
                    <div id="content">
                            我是内容<br />
                            我也是内容
                    </div>
                    <div id="actor">我是演员</div>
            </div>
        </body>
    </html>

    最终显示

      

  • 相关阅读:
    Daily Scrumming 2015.10.20(Day 1)
    Buaaclubs项目介绍
    [转载] Linux创建用户后,切换用户报This account is currently not available
    NetFPGA-1G-CML从零开始环境配置
    Digilent Xilinx USB Jtag cable
    OVS流表table之间的跳转
    Linux换源
    Scapy安装以及简单使用
    Do in SDN
    KMP算法
  • 原文地址:https://www.cnblogs.com/wang715100018066/p/7066879.html
Copyright © 2011-2022 走看看