ICode9

精准搜索请尝试: 精确搜索
首页 > 其他分享> 文章详细

CSS盒模型面试知识点

2019-10-01 15:01:03  阅读:257  来源: 互联网

标签:知识点 重叠 模型 元素 content 面试 外边 margin CSS


一、基本概念

1、基本概念:标准盒模型+怪异盒模型(IE模型)

基本组成:由margin、padding、content组成。

 

2、标准盒模型和IE模型的区别

标准盒模型width指的是内容区域content的宽度;height指的是内容区域content的高度。

标准盒模型下盒子的大小  = content + border + padding + margin

怪异盒模型中的width指的是内容、边框、内边距总的宽度(content + border + padding);height指的是内容、边框、内边距总的高度

怪异盒模型下盒子的大小=width(content + border + padding) + margin

 

3、CSS如何设置标准模型和IE模型

如果doctype协议缺失,会由浏览器自己界定,在IE浏览器中IE9以下(IE6.IE7.IE8)的版本触发怪异模式,其他浏览器中会默认为W3c标准模式。

box-sizing: content-box  标准盒模型

box-sizing: border-box  IE盒模型

 

二、盒模型 垂直外边距重叠问题

1、根据盒模型解释边距重叠问题

(1)什么是外边距重叠

垂直方向上的相邻外边距会发生外边距重叠。(a必须是相邻的;b必须是垂直方向上的)

两个或是多个盒子(可能相邻也可能嵌套)的相邻边界(中间没有任何内容、补白、边框)重合在一起而形成的一个单一边界。

边距重叠发生场景:

1、父元素与子元素之间,父元素的上下外边距和子元素的上下外边距之间重叠,选择最大值去渲染。

2、空元素,如果设置了margin-top和margin-bottom,则会在两者之间取一个最大值作为最终外边距。

3、兄弟元素,兄弟元素之间的相邻外边距会取外边距的最大值而不是外边距之和。

 

Ⅰ父元素边界重叠

<style>
    .parent{background: #e7a1c5;}
    .child{background: #ff6875;height:100px;margin-top:10px;}
    </style>
</head>
<body>
    <div class="parent">
        <div class="child"></div>
    </div>    
</body>

预想中效果是:

 实际上是:

 父元素高度并不是110px,而是100px,父元素发生了高度坍塌。

原因:如果块元素的margin-top 与它的第一个子元素的margin-top之间没有border、padding、inline content、clearance来分隔;

或者块元素的margin-bottom和它最后一个子元素margin-bottom之间没有border、padding、inline content、height、min-height、max-height分隔。那么外边距就会重叠,父元素高度塌陷。

子元素多余的外边距会被父元素的外边距截取。

 

Ⅱ 兄弟元素的边界重叠

<head>
    <meta charset="UTF-8">
    <title>Document</title>
    <style>
    .parent{overflow:hidden;width:300px;
        background: #8fdbdb;}
    .parent>p{background: #ff6875;margin:20px auto 30px;}
    </style>

</head>
<body>
    <div class="parent">
        <p>1</p><p>2</p><p>3</p>
    </div>    
</body>

 可以看到盒子1和2,盒子2和3之间的间距不是50px。兄弟元素垂直外边距重叠选取外边距最大值30px。

 

Ⅲ 空元素边距重叠

假设有一个空元素,它有外边距,但是没有边框或填充内容。在这种情况下,上外边距与下外边距就碰到了一起,外边距就会合并。

注意:给子元素设置了上外边距100px,子元素和父元素保持相对位置一起下移了100px(如果父子元素的垂直外边距相邻了,那么子元素的外边距会传递给父元素。

 

三、BFC解决高度坍塌

(1)什么是BFC

Block Formatting Context)简称BFC,块级格式化环境

开启BFC的元素会有以下特征:

1.父元素的垂直外边距不会和子元素重叠。

2.开启BFC的元素不会被浮动元素覆盖。

3.开启BFC的元素可以包含浮动的子元素。

 

(2)如何创建BFC

1、overflow不为visible

2、float不为none

3、position不为static或relative时

4、display为inline-block、table-cell、table、table-caption时

 

(3)BFC使用场景

详细内容:https://www.cnblogs.com/nyw1983/p/11374405.html

 

标签:知识点,重叠,模型,元素,content,面试,外边,margin,CSS
来源: https://www.cnblogs.com/nyw1983/p/11604607.html

本站声明: 1. iCode9 技术分享网(下文简称本站)提供的所有内容,仅供技术学习、探讨和分享;
2. 关于本站的所有留言、评论、转载及引用,纯属内容发起人的个人观点,与本站观点和立场无关;
3. 关于本站的所有言论和文字,纯属内容发起人的个人观点,与本站观点和立场无关;
4. 本站文章均是网友提供,不完全保证技术分享内容的完整性、准确性、时效性、风险性和版权归属;如您发现该文章侵犯了您的权益,可联系我们第一时间进行删除;
5. 本站为非盈利性的个人网站,所有内容不会用来进行牟利,也不会利用任何形式的广告来间接获益,纯粹是为了广大技术爱好者提供技术内容和技术思想的分享性交流网站。

专注分享技术,共同学习,共同进步。侵权联系[81616952@qq.com]

Copyright (C)ICode9.com, All Rights Reserved.

ICode9版权所有