• css中auto的用法


    —什么是auto?

       +auto是自适应的意思,auto是很多尺寸值的默认值,也就是由浏览器自动计算。

       +块级元素中margin、border、padding以及content宽度之和构成父元素width。

          使用auto属性后,父元素宽度发生变化,该元素的宽度也会随之变化。

         下图中   auto 的值就是margin、border、padding以及content宽度之和

          

       +但是当该元素被设为浮动时,该元素的width就变成了内容的宽度了,由内容撑开,也就是所谓的有了包裹性

          overflow |   position:absolute | float:left/right都可以产生包裹性,替换元素也同样具有包裹性。

          *|position:relavtive|相对定位      占原来的位置,不能实现模式的转化,即不具有包裹性。

            所以在具有包裹性的元素上不可以利用width : auto;来让元素宽度自适应浏览器宽。如下图所示

           

      —有时设置margin:0 auto;不起作用?

         +maigin: 0 auto; 指元素的上下边距为0,左右边距根据于父元素(body)宽度自适应,即左右水平居中。如果该设置不起作用大致下面两种原因。

         +(1)没有为DIV设置宽度,如果DIV么有宽度,就无法参考父元素的宽度来进行自身的auto。

         +(2)DIV具有包裹性,即脱离标准流,就好比父对象所在的标准流比喻成地表,那包裹性元素就已经上天了。没有了可供参考的父元素宽度进行auto。

      —以上纯属个人见解,欢迎大神补充纠正!!

  • 相关阅读:
    hdu 5532 Almost Sorted Array(模拟)
    hdu 2612 Find a way(bfs)
    hdu 2660 Accepted Necklace(dfs)
    reactjs学习一(环境搭配react+es6+webpack热部署)
    途牛banner自动轮播
    web app开发技巧总结
    20个为前端开发者准备的文档和指南
    Github上最受关注的前端大牛 快来膜拜把!
    怎么才能成为优秀的前端开发工程师?
    Web前端知识技能大汇总
  • 原文地址:https://www.cnblogs.com/wyan20/p/5472355.html
Copyright © 2020-2023  润新知