基础知识2--css盒模型

题目:谈谈你对css盒模型的认识?

答:

基本概念:padding,margin,border,content
  • 标准盒模型
  • IE怪异盒模型


    TIM图片20171009112830.png
标准盒模型和IE模型的区别

计算宽度和高度不用

  • 标准模型的宽度是:content的宽度,不包含padding和border;
  • IE模型宽和高是计算 border 和 padding 的。
css如何设置这两种模型

box-sizing:content-box;/标准模型(浏览器默认)/
box-sizing:border-box;/IE模型/

JS如何让设置获取盒模型对应的宽高
  • dom.style.width/height//取出内联的宽高,不准确
  • dom.currentStyle.width/height//拿到的是浏览器渲染后的宽高,准确,只有IE支持
  • window.getComputedStyle(dom).width/height//兼容firefox.chrome,通用性更好
  • dom.getBoundingClientRect().width/height//渲染后拿到,适用于计算一个元素的绝对位置,这个绝对位置是根据视窗viewpoint左上角左顶点拿到4个width/height/left/top
实例题(根据盒模型对应的宽高解释边距重叠)

子元素高100px,子元素与父元素上边距10px,求父元素高度

答:如果给父元素加overflow:hidden(相当于给父元素创建BFC),父元素高110px,否则父元素高100px。

BFC
  • BFC基本概念
    Block formatting context 块级格式化上下文,一个独立的渲染区域。
    FC(formatting context 格式化上下文),是页面的一块渲染区域,有一套渲染规则,决定了其子元素如何布局以及其它元素之间的关系和作用。
    常见的FC有BFC,IFC(行级格式化上下文),GFC(网格布局格式化上下文),FFC(自适应格式化上下文)。

  • BFC布局规则(渲染规则、原理)
    1.内部的box会在垂直方向一个接一个的放置。
    2.box垂直方向的距离由margin决定,属于同一个BFC的两个相邻box的margin会发生重叠
    3.每个元素的margin box的左边与包含块border box 的左边相接触
    4.BFC的区域不会与浮动元素的box重叠(用来清除浮动)
    5.BFC是页面上的独立容器,外面的元素不会影响里面的元素,里面的元素也不会影响外面的元素
    6.计算BFC高度时,浮动元素也会参与计算

  • 如何创建BFC
    1.float不为none,css默认为none,只要设置了浮动,当前的元素就创建了BFC
    2.position的值不是static和relative,默认值是static
    3.display:inline-block/table-cell/table-caption/table/flex/inline-flex等
    4.overflow不为visible,auto,hidden
    5.根元素,即html元素

  • BFC作用
    1.自适应两栏布局
    2.阻止元素被u浮动元素覆盖
    3.可以包含浮动元素,清除内部浮动
    4.分属于不同的BFC时,可以阻止margin重叠

  • 解决BFC垂直方向边距重叠

    • BFC垂直方向边距重叠
      子元素边距重叠,2的下边距3的上边距发生重叠,取最大值25
      取消重叠,为其加个父元素,并给父元素创建BFC
    <section id="margin">
    <style type="text/css">
      #margin{
          background: pink;
          overflow: hidden;/*创建BFC*/
      }
      #margin p{
          margin:5px auto 25px;
          background: gray;
      }
    </style>
      <p>1</p>
      <!-- <p>2</p> -->
      <div style="overflow: hidden;"><p>2</p></div>
      <p>3</p>
    </section>
    
  • BFC的区域不会与浮动的box重叠

    <section id="layout">
    <style type="text/css">
      #layout{
          background: #ccc;
      }
      #layout .left{
          width: 100px;
          height: 100px;
          background: red;
          float: left;
      }
      #layout .right{
          height: 110px;
          background: yellow;
          overflow: auto;/*为右侧创建BFC就不会与浮动元素重合*/
    
      }
    </style>
      <div class="left"></div>
      <div class="right">wwwwwwwwwww</div>
    </section>
    
  • 清除浮动

    • 清除浮动原理:触发父div的BFC属性,使下面的子div都处在父div的同一个BFC区域之内,此时已成功清除浮动。
      BFC子元素即使是float,也会参与高度计算
      当把外层的父元素设置成BFC时,子元素的浮动元素也会参与父级元素的高度计算上来

      <style type="text/css">
      #float{
          background: red;
          overflow: auto;/*为父元素创建BFC,那么父元素就有了高度*/
          /*float: left;为父元素创建BFC,那么父元素就有了高度*/
      }
      #float .left{
          float: left;
          font-size: 30px;
      }
      </style>
      <section id="float">
      <div class="left">
          清除浮动原理
      </div>      
      </section>
      
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容

  • 问答题47 /72 常见浏览器兼容性问题与解决方案? 参考答案 (1)浏览器兼容问题一:不同浏览器的标签默认的外补...
    _Yfling阅读 13,629评论 1 92
  • 一,浮动元素有什么特征?对父容器、其他浮动元素、普通元素、文字分别有什么影响? 浮动模型是一种可视化格式模型,浮动...
    DeeJay_Y阅读 808评论 0 4
  • css盒模型 1.题目:谈谈你对css盒模型的认识(从理论转化到应用) 基本概念:标准模型+ IE模型border...
    飞菲fly阅读 931评论 0 1
  • 以下文章是我在网上收集的内容,为了记录自己的学习以及为了以后不到处找而记录下来,如果对你有用,请感谢写这些文章的前...
    DCbryant阅读 895评论 0 2
  • 耽搁数个星期后,在大脑被琐碎繁杂的日常行将俘虏之前,疲于生计的身躯得到了短暂的休憩,没用沐浴露就急急套上印有阿根廷...
    一池深蓝阅读 117评论 0 0