深切了然CSS中的margin美学原理

1.css margin得以改变容器的尺码
  元素尺寸
  可视尺寸–标准盒子模型中盒子的肥瘦是不包括margin值的,clientWidth
  占据尺寸–包括margin的增幅
outWidth不在标准之中,jquery中有相对应的办法

  margin与可视尺寸
    1.1利用分外与从不设定width/height的普通block水平元素
    2.2只适用于水平方向尺寸
    <body style=”background-color:#1a2b3c”>
      <div style=”border:4px 6px; background-color:blue”>
        文字<br />
        文字<br />
      </div>
    </body>
    当改变margin值时盒子的肥瘦会转移。

    应用 :实现一侧定宽的自适应布局
      <img width=”150px” style=”float:left;”>
      <p style=”margin-left:170px”>图片左浮动</p>

    margin与占用尺寸
    1.block/inline-block水准元素均适用
    2.与没有设定width/height值无关
    3.适用于水平方向和垂直方向
    例
      <body style=”background-color:#1a2b3c”>
        <img style=”marign-bototm:-50″>
      </body>
    可以看来容器占据的尺码变小了。
    利用这一特点
    滚动容器内上下留白
      <div style=”height:100px; padding:50px 0;”>
        <img height=”300″>
      </div>
    里面盒子撑开外面盒子呈现滚动条,当然这在非chrome浏览器中是从未有过留白效果的(上边有上面没有)。
    正确的做法是
    <div style=”height:100px; “>
美学原理,      <img height=”300″ style=”marign:50px 0″>
    </div>

第二话:css margin与比例单位——通晓margin百分比单位
      水平方向百分比/垂直方向百分比
      普通元素百分比/绝对元素百分比

      百分比margin的统计规则
        img{margin :10%;with:600px;heigth:200px;}
      普通元素的百分比margin都是相对于容器的增长率总括的!所以这边的margin:10%;—->top:60px,left:60px;都是相对与容器的宽度来计量的。

      相对定位元素的百分比margin
        img{margin:10%; position:absolute;}
      相对元素的百分比margin是相持与第一个稳定元素的祖辈元素具有(relative/absolute/fixed)的涨幅总结的。普通元素的是对峙与父元素的来测算的。
        <div style=”width:1024px;height:200px;
position:relative;”>
          <div style=”width:600px; height:200px”>
           <img style=”margin:10%;position:absolute;”
/>

          </div>
        </div>
      利用特色
        宽高2:1自适应矩形
          .box{background-color:olive; overflow:hidden;}
          .box > div{margin:50%}
        那里还提到一个只是点就是margin重叠。这里安装overflow
也是因为避免margin重叠

其三话 margin重叠日常特性
  1.block程度元素(不包括float和absolute元素)
  2.不考虑writing-mode(文字书写方向是从上到下的),只暴发在笔直方向的(margin-top/margin-bottom)

  margin重叠3种情境
    1.相邻的小兄弟元素
      p{line-height:2em;margin:1em 0;background:#f0f3f9;}
        <p>第一行</p>
        <p>第二行</p>
      这里就会时有爆发margin重叠了
    2.父级和第一个/最后一个子元素
      .father{background:#f0f3f9}
      <div class=”father”>
        <div class=”son”
style=”margin-top:80px;”>son</div>
      </div>
      给子第一个或最终一个子元素设置margin等同于给父元素设置同一的margin值,子元素相同margin,子元素和父元素一样的margin值
    3.空的block元素
      .father{background:#f0f3f9}
      <div class=”father”>
        <div class=”son”></div>
      </div>
      这里son的中度唯有1em,不是2em
      空block元素margin重叠其他条件
        1.元素并未border设置
        2.元素没有padding值
        3.中间没有inline元素
        4.没有height,或者min-height

      margin-top重叠
        1.1父元素非块状格式化上下文元素
        1.2父元素没有border-top设置
        1.3父元素没有padding-top值
        1.4父元素和率先个子元素之间没有inline元素分隔

      margin-bottom重叠
        1.1父元素非块状格式化上下文元素
        1.2父元素没有border-bottom设置
        1.3父元素没有padding-bottom值
        1.4父元素和尾声一个子元素之间从未inline元素分隔
        1.5父元素没有height,min-height,max-height限制
      干掉margin-top重叠
        .father{background:#f0f3f9}
        <div class=”father”>
          <div class=”son”
style=”margin-top:80px;”>son</div>
        </div>
      1.父元素非块状格式化上下文元素 .father:overflow:hidden;
      2.父元素没有border-top设置
        .father:border:4px solid #ccc;
      3.父元素没有padding-top值
      4.父元素和率先个子元素之间从未inline元素分隔
        <div class=”father”> 
          <div class=”son”
style=”margin-top:80px;”>son</div>
        </div>
        干掉margin-bottom重叠
        前边五个和margin-top一样,
          <div class=”father”
style=”height:100px”> 
            <div class=”son”
style=”margin-top:80px;”>son</div>
          </div>

    margin重叠的测算规则
      1.正正取大值
        .a{margin-bottom:50px;}
        .b{margin-top:20px;}
        <div class=”a”></div>
        <div class=”b”></div>

          .father{margin-top:20px;}
          .son{margin-top:50px;}
      <div class=”father”>
        <div class=”son”></div>
      </div>

      .a{margin-top:20px;margin-bottom:50px}
      <div class=”a”></div>

      下面的结果都是margin:50px;
    2.正负值相加
      .a{margin-bottom:50px;}
      .b{margin-top:-20px;}
      <div class=”a”></div>
      <div class=”b”></div>

      .father{margin-top:-20px;}
      .son{margin-top:50px;}
      <div class=”father”>
        <div class=”son”></div>
      </div>

      .a{margin-top:-20px;margin-bottom:50px}
      <div class=”a”></div>
      上边的结果都是30px
  3.负负最负值
    .a{margin-bottom:-50px;}
    .b{margin-top:-20px;}
    <div class=”a”></div>
    <div class=”b”></div>

    .father{margin-top:-20px;}
    .son{margin-top:-50px;}
    <div class=”father”>
      <div class=”son”></div>
    </div>

    .a{margin-top:-20px;margin-bottom:-50px}
    <div class=”a”></div>
    下面的结果都是-50px
    margin重叠的含义是?
    网页诞生之初…………只是排版文字布局用,没有今日这样复杂。
      1.接连段落或列表之类,即使没有margin重叠首尾项间距会和其他兄弟标签1:2关乎,排版不自然;
      2.web中其它地方嵌套或间接放入任何裸div都不会潜移默化原本的布局
      3.不见的空人一个p元素,不要影响原本的阅读排版

    实践:
      善用margin重叠
        .list{margin-top:15px;}
      更好贯彻
        .list{
          margin-top:15px;
          margin-bottom:15px;
         }
      更拥有健壮性,最终一个要素移除或岗位交流,均不会破坏原来的布局。
第4话:理解CSS中的margin:auto
    margin:auto 的机制
    元素有时候,尽管没有安装width或height,也会自行填写
      div{background:#f0f3f9}

    如果设置width或height,自动填写特性就会被遮盖
      div{width:500px;background:#f0f3f9;}
      此时的margin值是0px
    假使设置值width或height,自动填写特性就会被遮住。

    原来应该填充的尺寸被width/height强制变更,而margin:auto就是为着填充这个改变的尺码设置的;
      div{width:500px;marign-right:100px;margin-left:auto;}

    假诺一侧定值,一侧auto,auto为结余空间尺寸,假设两侧均是auto,则平均剩余空间

    为啥图片img{width:200px;marign:0 auto}不居中
    因为图片是inline水平的,固然没有width,也不会占用整个容器。
    设置img{display:block;width:200px;marign:0 auto;}
    因为这时候图片是block水平的,尽管没有width,也会占用整个容器无法在一行呈现。

    为啥明明容器定高,元素定高margin:auto 0 不可以垂直居中

    .father{height:200px;background:#f0f3f9;}
    .son{height:100px; width:500px;margin:auto;}
    水平居中了,垂直不居中。

    解释:假使.son没有安装height:100px;低度会自动200px高啊?——NO
所以margin谈不上电动填充,强制安装宽度低度, 所以是不会自行填写的。
    注意:水平方向上倘诺实大于父,统计结果为负值的时候也是不居中的。

    实现垂直方向margin居中
      更改流为垂直方向,实现垂直方向的margin:auto
      writing-mode与垂直居中(css3)
      .father{height:200px; width:100%;
wiriting-mode:vertical-lr;}
      .son{height:100px;width:500px;margin:auto;}
    absolute与margin居中
      .father{height:200px;position:relative;}
      .son{position:absolute; top:0px right:0px
bottom:0px;left:0px}
      .son没有width/height,absolute元素自动填满了容器。

    当设置了width和惊人
      .father{height:200px;position:relative;}
      .son{position:absolute; top:0px right:0px
bottom:0px;left:0px;width:500px;height:100px;}
    原来拉伸铺满现在缩回来了。
      被拉伸的长空设置margin:auto;平均分配就会落实程度垂直居中了
      .father{height:200px;position:relative;}
      .son{position:absolute; top:0px right:0px
bottom:0px;left:0px;width:500px;height:100px;margin:auto;}

    IE8+以上辅助!
第五话:css margin负值定位
    1.margin负值下的两边对齐(margin改变元素尺寸)
    例子
      .box{
        width:1200px; margin:auto;background:orange;
        .ul{overflow:hidden;}
        .li{
          width:380px;height:300px;
          margin-right:20px;
          background:green;
          float:left;
        }
      }
    实现的列表最终一个留有间隙。
      而通过margin负值来改变容器的分寸,让容器变宽。能到家解决这多少个题目
    .box{
      width:1200px; margin:auto;background:orange;
    .ul{overflow:hidden;margin-right:-20px;}
    .li{
      width:386.66px;height:300px;
      margin-right:20px;
      background:green;
      float:left;
     }
    }
    2.margin负值下的等高布局 margin改变元素占据空间
    margin与上下留白
    <div style=”height:200px;”>
      <img height=”300px” style=”margin:50px 0;” />
    </div>
    .box{overflow:hidden;resize:vertical;}
    .child-orange,
    .child-green{margin-bottom:-600px;padding-bottom:600px;}
    .child-orange{float:left;background:orange;}
    .child-green{float:left;background:green;}

    通过设置很大的margin-bottom负值,和很大的padding-bottom填充缺失的半空中,实现等高布局。原理:内容块状元素可以在padding中显示.只要没有安装    

    background:clip,box-sizing:content
    3.margin负值下的两栏自适应布局,元素占据空间跟随margin移动

    <div style=”float:left;width:100%”>
      <p style=”margin-right:170px;”>图片右浮动</p>
    </div>
    <img width=”150px;”
style=”float:left;margin-left:-150px;”/>

第六话 css marign无效情况解析
  1.inline水准元素的垂直margin无效
  2个前提 1.非轮换元素,例如不是img元素;2.正常书写格局
  例
    <span style=”margin:0px”>marign:0px</span>
    给span设置margin233px;
    水平上有效的,垂直方向是没用的。
    2.margin重叠
    3.display:table-cell
      display:table-cell/display:tab-row等声明margin无效!

      例外的更迭元素img,button

    4.position与margin
      绝对定位元素非定点方向的margin值“无效”
      相对定位的margin值一贯有效,不只是像一般元素这样。
    5.鞭长莫及的margin失效
      bfc内容块中假设前方有变化元素这下一个因素的margin是争持与外层的div统计的。
    6.内联导致的margin失效
      div[style=”height:200px;background-color:#f0f3f9;”]>img[style=”marign-top:30;”]
      当margin-top充分大的时候失效了。
      解释:内联元素要实现和基线对齐,在图纸后加x可以看来,无论margin-top有多少距离,他都不会脱离容器外面。

第七话margin-start和margin-end
    margin-start
    img{
      margin-left:100px;
      -webkit-margin-start:100px;
      -moz-margin-start:100px;
      margin-sart:100px;
    }
    1.健康的流向,margin-sart等同于margin-left,两者重叠不增长;
    2.假使水平没有从右往左,margin-start等同与margin-right;direction:ltr(rtl)
    3.在笔直流下(writring-mode:vertical-lr),margin-sart等同于margin-top
    webkit下的任何margin相关属性
      margin-before
        img{-webkit-margin-before:100px;}
默认流向的意况下,等同于marign-top
      margin-after
        img{-webkit-marign-after:100px;}
默认流向的事态下,等同于margin-bottom;
      margin-collapse 外边框重叠
        -webkit-margin-collapse: collapse|discard|separate
         控制margin重叠
         collapse默认-重叠
         discard 取消
         separate 分隔 没有重叠