【基础巩固📔】- 带你搞懂CSS盒模型

简介: 它其实就是我们这篇文章的主角-盒模型。由这张图可以看出,盒模型包含了`margin`、`border`、`padding`、`content`这四个部分。>所有HTML元素都可以看作盒子,而我们平时就是盒子的搬运工。## 介绍标准模型和IE模型,以及他们的区别🍈它俩的**区别就一个,计算宽度(高度)的方式不一样。**
大家好,我是Ned👀,一个刚刚入门前端未满两年的大三小学生🌹

未来路还长🎉, 一起努力加油吧❤~

最近在准备春招了,复习一些基础的知识点,整合成一个专栏发出来,希望可以帮助到更多的小伙伴们~🥰

盒模型📦

先用一张图来说明一下我会怎么来介绍盒模型:
image.png

什么是盒模型🍇

其实我们大家都能经常看见它,尤其是我们前端的小伙伴们,在浏览器中打开f12就能看见这样一个动态变化的图。

image.png
它其实就是我们这篇文章的主角-盒模型。由这张图可以看出,盒模型包含了marginborderpaddingcontent这四个部分。

所有HTML元素都可以看作盒子,而我们平时就是盒子的搬运工。

介绍标准模型和IE模型,以及他们的区别🍈

它俩的区别就一个,计算宽度(高度)的方式不一样。

  • 标准盒模型

image.png
width = content

总宽度 = width + margin + border padding

margin包含mrgin-left与margin-right 其他同理
  • IE盒模型

image.png
width = content + border + padding

总宽度 = width + margin

CSS如何设置盒模型,以及计算对应的宽和高🍉

css中有一个属性:box-sizing,我们可以通过这个属性去设置标准盒模型(content-box)或者是IE盒模型(border-box),默认为标准盒模型。
详细参数可以去W3c去看一下,此处不做说明: box-sizing

如何去计算元素的宽(高)? 我们在得知它是哪种盒模型之后就可以依据我们上文的公式去计算了,可以打开F12,滑到图那里,去查阅该元素四部分(marginborderpaddingcontent)的值是多少,完后进行计算即可。

js如何设置获取盒模型对应的宽和高🍍

  • dom.style.width/height

这个方法只能获取写在行内样式中的宽度,写在style标签中和使用link外链都是获取不到的,我们下面来看一下:

<div id="div">这是一个div</div>
div{
    width:300px;
    margin-left:50px;
    border:25px;
    padding-right:60px;
    background-color:pink;
}
let divWidth = document.getElementById("div").style.width;
console.log(divWidth);

我将样式写在了style标签内,看看他是否能打印出来div的宽度。

image.png
是打不出来的,那在行内写一个宽度为100px再试试。

image.png
成功将宽度打印了出来。

如此之外还有三个api可以使用:

  • dom.currentStyle.width/height 取到的是最终渲染后的宽和高,只有IE支持此属性。
  • window.getComputedStyle(dom).width/height 同上一个但是多浏览器支持,IE9以上支持
  • dom.getBoundingClientRect().width/height 也是得到渲染后的宽和高,大多浏览器支持。IE9以上支持,除此外还可以取到相对于视窗的上下左右的距离。

根据盒模型解释边距重叠🍓

当两个外边距相遇时,他们将形成一个外边距,合并后的外边距高度等于两个发生合并的外边距的高度中的较大者。

注意:只有普通文档流中块框的垂直外边距才会发生外边距合并,行内框、浮动框或绝对定位之间的外边距不会合并。

再用一个demo来说明一下:

<div class="div1">这是一个div</div>
<div class="div2">这是一个div</div>
    .div1{
        width:300px;
        margin:70px;
        border:25px;
        padding-right:60px;
        background-color:pink;
    }
    .div1{
        width:300px;
        margin:50px;
        border:25px;
        padding-right:60px;
        background-color:pink;
    }

一个外边距是70px一个外边距是50px没有做其他布局的情况下这两个盒子应该是上下状堆在一起的,我们看一下他们两个间距到底是多少。

image.png
根据这两个箭头所指,我们可以看到上方橙色全部都是第一个divmargin,下方浏览器清晰的写出了margin值为70px,也就是说,产生了边距重叠,并且确实合并成了较大的那个

image.png

图画的是不是有点不忍直视emm,下次努力!!!

BFC(边距重叠解决方案,还有IFC)解决边距重叠🍋

有些时候我们不希望他发生边距重叠,我们采用BFC和IFC来解决。

先普及一下概念,FC就是Fomatting Context。它是页面中的一块渲染区域。而且有一套渲染规则,它决定了其子元素将怎样定位。以及和其它元素的关系和相互作用.BFC和IFC都是常见的FC。
分别叫做Block Fomatting Context 和Inline Formatting Context。

我是这样理解的:他指定了一块环境,在这块环境内部的元素布局与外界不产生相互影响

以BFC为例,来介绍一下它的渲染规则:

  • 内部盒子垂直排列,间距由margin决定
  • 在同一BFC下,相邻两个盒子会发生边距重叠现象
  • 计算BFC高度的时候,浮动元素也会参与计算
  • BFC的区域不会与浮动的区域重叠

介绍完规则再来介绍一下如何创建BFC:

  • overflow不为visible;
  • float的值不为none;
  • position的值为absolute或fixed;
  • display属性为inline-blocks,table,table-cell,table-caption,flex,inline-flex;

规则太多,我挑个举例子吧:

    <div class="left"></div>
    <div class="right"></div>
    div {
        width:300px;
    }
    .left {
        width: 100px;
        height: 150px;
        float: left;
        background: black;
    }
    .right {
        height:200px;
        background-color:red;
    }

image.png
可以看到浮动的地方与另一块内容重叠了,这个时候我们在红色区域创建一个BFC,使其不重叠。

.right {
  overflow:hidden;
  height:200px;
  background-color:red;
}

image.png

他们两个成功被分开了,证明我们的BFC区域创建成功了。

其余的规则如果也想验证一下可以自己尝试一下~

在证明一下BFC能够解决边距重叠问题:

    <div id="margin">
        <p>1</p>
        <div style="overflow: hidden">
            <p>2</p>
        </div>
        <p>3</p>
        <p>4</p>
    </div>
    * {
        padding: 0;
        margin: 0;
    }
    #margin {
        background: #000;
        overflow: hidden;
    }
    p {
        margin-top: 15px;
        margin-bottom: 25px;
        background: red;
    }

image.png
我们看2,它与1、3都没有边距重叠,这是因为它的父元素中具有overflow:hidden,这就创建了一个BFC使其不受外界环境影响。我们再看3、4。

image.png
可以看到3的下边距与4是发生了重叠的,这是因为它不具有BFC,就如同之前一样,边距会发生重叠最终合并成较大的那一个。

结束啦🎉

对于CSS来讲,最主要还是布局,在布局之中盒子模型有有着很重要的地位,所以先弄懂它,我们一步步来🏃~

梳理好每一个知识点,稳扎稳打,才不会被面试官问倒😰~

如果文章有误欢迎在评论区指出,感谢指正🔔

这是我面试专栏的第一篇文章,后续会陆陆续续继续整理的,欢迎大家关注📢

👉专栏地址:Ned的面试加油站👈

如果您觉得以上的内容还不错,不妨点个赞支持一下哦~~😇

我们下期再见👋

相关文章
|
8月前
|
前端开发
CSS语言的盒模型
CSS语言的盒模型
|
8月前
|
前端开发 JavaScript Java
【面试题】面试官:说说你对 CSS 盒模型的理解
【面试题】面试官:说说你对 CSS 盒模型的理解
|
3月前
|
前端开发 UED
CSS 盒模型
CSS盒模型是网页设计中一个重要的概念,它定义了HTML元素如何在页面上呈现及其相互关系。每个HTML元素都被视为一个矩形框,此模型涉及内容区、内边距、边框和外边距四个部分,通过控制这些部分的样式和布局,设计师可以实现多样化的页面效果。
|
5月前
|
前端开发 容器
【CSS Flexbox 探秘】弹性盒模型:揭秘网页布局的终极神器!
【8月更文挑战第25天】Flexbox 是 CSS3 中的关键特性,为网页设计提供了强大的布局能力。本文通过问答形式全面解析 Flexbox 的核心概念与属性,包括容器与项目属性,并通过示例演示如何使用 Flexbox 实现水平与垂直居中、等间距布局及响应式设计。相较于传统布局方法,Flexbox 更加灵活且简化了样式设置,同时在现代浏览器中拥有良好的支持度。掌握 Flexbox 对于提升网页布局效率至关重要。
95 1
|
5月前
|
容器 C# 开发者
XAML语言大揭秘:WPF标记的魅力所在,让你轻松实现界面与逻辑分离,告别复杂代码!
【8月更文挑战第31天】XAML提供了一种直观且易于维护的界面设计方式,使得开发者可以专注于逻辑和业务代码的编写,而无需关心界面细节。通过数据绑定、布局管理和动画效果等特性,XAML可以实现丰富的界面交互和视觉效果。在实际开发过程中,开发者应根据具体需求选择合适的技术方案,以确保应用程序能够满足用户的需求。希望本文的内容能够帮助您在WPF应用程序开发中更好地利用XAML语言。
54 0
|
5月前
|
前端开发
CSS盒模型揭秘:打造精美网页的不二法门
CSS盒模型揭秘:打造精美网页的不二法门
|
6月前
|
前端开发 C++
CSS【详解】 标准盒模型 VS IE 盒模型
CSS【详解】 标准盒模型 VS IE 盒模型
72 0
|
7月前
|
Web App开发 前端开发 编译器
CSS3私有前缀+新增盒模型相关属性(如果想知道CSS3私有前缀、新增盒模型相关属性的知识点,那么只看这一篇就足够了!)
CSS3私有前缀+新增盒模型相关属性(如果想知道CSS3私有前缀、新增盒模型相关属性的知识点,那么只看这一篇就足够了!)
|
7月前
|
前端开发
CSS基础-盒模型:边框、内边距、外边距
【6月更文挑战第8天】Web设计中的盒模型由内容区域、内边距、边框和外边距组成,是理解页面布局的关键。内容区域包含实际内容,内边距提供间隔,边框定义元素边界,外边距控制元素间距。常见易错点包括边框宽度计算、外边距折叠和盒模型理解不透彻。通过实践和媒体查询可解决响应式设计挑战,`border-radius`可能导致圆角问题。理解盒模型并灵活应用能创建多样化布局。
121 6
|
8月前
|
前端开发 开发者
CSS盒模型
【5月更文挑战第24天】CSS盒模型
55 3