热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

【前端学习之HTMLCSS进阶篇】CSS第二篇块级格式化上下文与堆叠上下文

【前端学习之HTML&CSS进阶篇】--CSS第二篇–块级格式化上下文与堆叠上下文文章目录【前端学习之HTML&CSS进阶篇】--CSS第二篇--块级格式化上下文与堆叠上下文前言一

【前端学习之HTML&CSS进阶篇】-- CSS第二篇 – 块级格式化上下文与堆叠上下文


文章目录

  • 【前端学习之HTML&CSS进阶篇】-- CSS第二篇 -- 块级格式化上下文与堆叠上下文
  • 前言
    • 一、 块级格式化上下文
      • 1. 概念
      • 2. 常规流块盒布局:
      • 3. BFC渲染区域:
      • 4. 独立:
    • 二、 堆叠上下文
      • 1. 创建堆叠上下文的元素
      • 2. 同一个堆叠上下文中元素在Z轴上的排列
  • 总结



本文具体内容参考了B站渡一教育的课程,原课程链接如下:


渡一教育课程

lc


前言

html与css以及今后我们将会学到的js共同构成了前端技术中最重要的三种语言,在学习过程中,我们首先从html出发,在html的学习过程中深入了解css。在上一节博客中,我们进入了CSS进阶部分的学习,本节的内容则主要专注于对于BFC和stack context的学习。


一、 块级格式化上下文


1. 概念


  • Block Formatting Context简称BFC,是一块独立的渲染区域,规定了在区域中,常规流块盒的布局;

在这里插入图片描述


2. 常规流块盒布局:


  • 视觉格式化模型包含了块级格式化上下文,而块级格式化上下文规定了下述规则:

  1. 常规流块盒在水平方向上,必须撑满包含块;
  2. 常规流块盒在包含块的垂直方向上依次摆放;
  3. 常规流块盒若外边距无缝相邻,外边距合并;
  4. 常规流块盒的自动高度和摆放位置,无视浮动和定位元素;


3. BFC渲染区域:

由某个HTML元素创建,以下元素会在其内部创建BFC区域:


  1. 根元素:HTML元素,该元素创建的BFC区域覆盖了网页中的所有元素;
  2. 浮动和绝对定位元素
  3. overflow不等于visible的块盒【display=table、inline-block的也是】

图示:
在这里插入图片描述


4. 独立:

不同的BFC区域,渲染时互不干扰;
创建了BFC的元素,隔绝了它内部和外部的联系,内部的渲染不会影响到外部,具体规则如下:

在这里插入图片描述


创建BFC的元素,自动高度需要计算浮动元素;


举个例子:当出现高度坍塌时,是因为常规流的块盒不会考虑内部浮动元素的高度,导致认为内部高度为0,实现坍塌,现在我们只要让外部的这个块盒生成BFC,那么就会计算高度了;
例如可以让块盒实现绝对定位或者浮动【不推荐、有副作用】--- 创建BFC即可;
更改overflow属性 --- 推荐,改成hidden等即可;

创建BFC的元素,边框盒不会与浮动元素重叠;


.float{float: left;width: 200px;height: 200px;margin: 20px;background-color: red;}.container{height: 500px;background-color: #008c8c;/* BFC */overflow: hidden;}

<div class&#61;"float">div><div class&#61;"container">div>

  • 常规流盒子不创建BFC&#xff1a;
    在这里插入图片描述

  • 创建BFC&#xff1a;自动避让浮动元素&#xff0c;在不设置宽度时&#xff0c;就会出现自适应的效果&#xff0c;此时右边盒子的margin-left无用&#xff0c;想要间隔拉大&#xff0c;需要增加左边浮动盒子的margin-right&#xff1a;

在这里插入图片描述


创建BFC的元素&#xff0c;不会与子元素进行外边距合并//处在不同BFC区域的元素&#xff0c;外边距不合并&#xff1a;


.container{background-color: #008c8c;height: 500px;margin-top: 30px;/* BFC */overflow: hidden;}.child{height: 100px;margin: 50px;background-color: red;}

<div class&#61;"container"><div class&#61;"child">div>div>

  • 当子元素和外部元素在同BFC区域内&#xff0c;外边距合并&#xff0c;如图所示上方黄色区域50px证明边距合并&#xff0c;选取更大值50px作为标准&#xff1a;
    在这里插入图片描述

  • 当子元素处于父元素创造的BFC中&#xff0c;而父元素处于根元素的BFC中&#xff0c;故边距不合并&#xff0c;如图&#xff1a;
    在这里插入图片描述


二、 堆叠上下文

栈/堆叠/层叠上下文&#xff08;stack context):

在这里插入图片描述


  • 概念&#xff1a;它是一块区域&#xff0c;这块区域由某个元素创建&#xff0c;它规定了该区域中的内容在Z轴上的排列先后顺序&#xff1b;
    【z轴&#xff1a;从屏幕穿向人】

1. 创建堆叠上下文的元素


  1. html元素(根元素)
  2. 设置了z-index数值【非auto】的定位元素(position)

&#xff08;类似于块级格式化上下文&#xff09;
注意&#xff1a;设置了z-index的元素仍然处于根元素或上一级设置的元素的上下文中&#xff0c;只是它的内部子元素在他自己本身创造的堆叠上下文中&#xff1b;


2. 同一个堆叠上下文中元素在Z轴上的排列

从后到前的排列顺序

在这里插入图片描述


  1. 创建堆叠上下文的元素的背景和边框(远离用户)

  • HTML的背景永远最远离用户&#xff0c;即在最底层&#xff1b;
  • 即创建了堆叠上下文的元素考虑时比z-index等规则优先级高&#xff1b;


  1. 堆叠级别为负值的堆叠上下文

  • 即比较z-index
  • 情况相同&#xff1a;源次序后边的覆盖前面的


  1. 常规流非定位的块盒

  2. 非定位的浮动盒子

  3. 常规流非定位的行盒

  4. 任何z-index是auto的定位子元素&#xff0c;以及z-index是0的堆叠上下文

  5. 堆叠级别为正值的堆叠上下文


每个堆叠上下文&#xff0c;独立于其他堆叠上下文&#xff0c;他们之间不能相互穿插&#xff1b;
也就是说先比较整体堆叠上下文&#xff0c;在利用内部规则对比&#xff1b;



总结

本节内容主要是块级格式化上下文的生成和计算规则以及堆叠上下文的应用&#xff0c;对于BFC区域原理的掌握是实现自己想要样式的必备之课&#xff0c;而Z-index的内容也是十分重要的关键样式之一。

在这里插入图片描述


推荐阅读
  • 一个登陆界面
    预览截图html部分123456789101112用户登入1314邮箱名称邮箱为空15密码密码为空16登 ... [详细]
  • Spring Boot 中静态资源映射详解
    本文深入探讨了 Spring Boot 如何简化 Web 应用中的静态资源管理,包括默认的静态资源映射规则、WebJars 的使用以及静态首页的处理方法。通过本文,您将了解如何高效地管理和引用静态资源。 ... [详细]
  • 本文详细介绍了如何使用 HTML 和 CSS 对文件上传按钮进行样式美化,使用户界面更加友好和美观。 ... [详细]
  • ListView简单使用
    先上效果:主要实现了Listview的绑定和点击事件。项目资源结构如下:先创建一个动物类,用来装载数据:Animal类如下:packagecom.example.simplelis ... [详细]
  • 本文详细介绍了 Android 开发中 layout_gravity 属性的使用方法及其在不同布局下的效果,旨在帮助开发者更好地理解和利用这一属性来精确控制视图的布局。 ... [详细]
  • 本文介绍了如何通过在数据库表中增加一个字段来记录文章的访问次数,并提供了一个示例方法用于更新该字段值。 ... [详细]
  • 本文探讨了C++编程中理解代码执行期间复杂度的挑战,特别是编译器在程序运行时生成额外指令以确保对象构造、内存管理、类型转换及临时对象创建的安全性。 ... [详细]
  • 本文探讨了如何利用HTML5和JavaScript在浏览器中进行本地文件的读取和写入操作,并介绍了获取本地文件路径的方法。HTML5提供了一系列API,使得这些操作变得更加简便和安全。 ... [详细]
  • 本文详细介绍了get和set方法的作用及其在编程中的实现方式,同时探讨了点语法的使用场景。通过具体示例,解释了属性声明与合成存取方法的概念,并补充了相关操作的最佳实践。 ... [详细]
  • 深入剖析JVM垃圾回收机制
    本文详细探讨了Java虚拟机(JVM)中的垃圾回收机制,包括其意义、对象判定方法、引用类型、常见垃圾收集算法以及各种垃圾收集器的特点和工作原理。通过理解这些内容,开发人员可以更好地优化内存管理和程序性能。 ... [详细]
  • 编写css让div2在div1的右下角? ... [详细]
  • 当unique验证运到图片上传时
    2019独角兽企业重金招聘Python工程师标准model:public$imageFile;publicfunctionrules(){return[[[na ... [详细]
  • 解决Spring Boot项目创建失败的问题
    在尝试创建新的Spring Boot项目时遇到了一些问题,具体表现为在项目创建过程中的两个关键步骤出现错误。本文将详细探讨这些问题及其解决方案。 ... [详细]
  • springMVC JRS303验证 ... [详细]
  • CentOS 系统管理基础
    本文介绍了如何在 CentOS 中查询系统版本、内核版本、位数以及磁盘分区的相关知识。通过这些命令,用户可以快速了解系统的配置和磁盘结构。 ... [详细]
author-avatar
花神
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有