zoukankan      html  css  js  c++  java
  • div水平居中 垂直居中

    1.div 自己水平居中  margin: 0 auto;

    2.子代 水平居中:父元素:text-align:center,子元素:inline/inline-block;

    3. 定位,子代水平垂直居中(方法少用;会出现兼容性问题,或者无法自适应响应式布局)

    <div class='father'>
    <div class='child'></div>
    </div>
    .father{
      margin: 0 auto;
       500px;
      height:500px;
      background-color: aqua;
      position: relative;
     
    }
    .child{
      position: absolute;
      top:50%;
      left: 50%;
      margin-left:-150px;
      margin-top:-150px;
       300px;
      height:300px;
      background-color: brown;
    }
    或者
    .father{
      margin: 0 auto;
       500px;
      height:500px;
      background-color: aqua;
      position: relative;
     
    }
    .child{
      margin:auto;
      position: absolute;
      top:0;
      left:0;
      bottom:0;
      right:0;
       300px;
      height:300px;
      background-color: brown;
    }
     
    默认情况下html和body的高度是由内容撑起来的高度
    body.html{
      width:100%;
      height:100%;
      margin:0;
      padding:0;
     
    }
    垂直居中:我们先要设置div元素的祖先元素html和body的高度为100%(因为他们默认是为0的/内容撑起来的高度)并且清除默认样式,即把margin和padding设置为0(如果不清除默认样式的话,浏览器就会出现滚动条,聪明的亲,自己想想问什么)。
    由于position的值为static(静止的、不可以移动的),元素在文档流里是从上往下、从左到右紧密的布局的,我们不可以直接通过top、left等属性改变它的偏移。所以,想要移动元素的位置,就要把position设置为不是static的其他值,如relative,absolute,fixed等。然后,就可以通过top、bottom、right、left等属性使它在文档中发生位置偏移(注意,relative是不会使元素脱离文档流的,absolute和fixed则会!也就是说,relative会占据着移动之前的位置,但是absolute和fixed就不会)。
    用自己的话说:页面默认,流式布局,从上到下,从左到右,position默认是static的静止状态,也就是说,偏移属性top ,right,,left,buttom,只有在定位的时候才能用得上,知道具体高可以用像素px, 不知道可以用百分比定位%;vh,wh
    通过设置div的transform: translateX(-50%),意思是使得div向左平移(translate)自身高度的一半(50%)。
     
     垂直居中:
    1.【单行文本】垂直居中 【子元素行高=父元素】
     
     line-height具有继承性,只对line 或者  line-block  起作用  对块级元素不起作用
     作用对象:对于inline和inline-block元素作用于元素自身,对于block元素,子元素通过继承被作用
    #child {
    line-height: 200px;
    }
     2.【图片】垂直居中 【设置自己】
      vertical-align 只能设置自己,属性设置行内元素的垂直对齐方式。
      vertical-align:作用于行内块的话,可以用在自己身上,让自己处于垂直居中的位置。
      vertical-align: middle;
     img {
       vertical-align: middle;
     }
    vertical-align:text-top;/vertical-align:text-button
    3.通用垂直居中 【表格方式】
    <div id="parent">
      <div id="child">Content here</div>
    </div>
    #parent {display: table;}
    #child {
    display: table-cell;
    vertical-align: middle;
    }
     
    4.【定位】垂直居中 (IE7以下不兼容)
    定位垂直居中两句代码{
          position:relative;
          top:50%;
          transform:translateY(50%)
          }
     
    5.【浮动】
     
     
        
      
     
     
  • 相关阅读:
    Atlas
    MHA高可用
    Mycat 读写分离
    数据库 基于GTID主从复制
    DHCP服务
    python垃圾回收机制
    深拷贝、浅拷贝、引用(总结)
    python内存管理机制
    web安全-横向越权与纵向越权
    登录功能SQL注入
  • 原文地址:https://www.cnblogs.com/maibao666/p/11327147.html
Copyright © 2011-2022 走看看