热门标签 | 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的内容也是十分重要的关键样式之一。

在这里插入图片描述


推荐阅读
  • 开发笔记:前端之前端初识
    开发笔记:前端之前端初识 ... [详细]
  • SvpplyTable: 实现可扩展和可折叠的菜单动画
    SvpplyTable 是一个示例项目,旨在实现类似 Svpply 应用程序中的可扩展和可折叠的菜单动画效果。该项目托管在 GitHub 上,地址为 https://github.com/liuminqian/SvpplyTable。 ... [详细]
  • 本文介绍了编程语言的基本分类,包括机器语言、汇编语言和高级语言的特点及其优缺点。随后详细讲解了Python解释器的安装与配置方法,并探讨了Python变量的定义、使用及内存管理机制。 ... [详细]
  • 本文介绍了如何使用 Gesture Detector 和 overridePendingTransition 方法来实现滑动界面和过渡动画。 ... [详细]
  • 驱动程序的基本结构1、Windows驱动程序中重要的数据结构1.1、驱动对象(DRIVER_OBJECT)每个驱动程序会有唯一的驱动对象与之对应,并且这个驱动对象是在驱 ... [详细]
  • 解决网页乱码问题的实用方法
    网页乱码问题在开发中较为常见,主要由文件编码、程序字符集设置和数据库连接字符集设置不当引起。本文将详细介绍如何逐一排查并解决这些问题。 ... [详细]
  • 本文通过一个示例展示了如何使用HTML和CSS美化并实现响应式的按钮组。 ... [详细]
  • 在移动端开发中,多点触控手势是提升用户体验的重要手段。然而,目前只有iOS浏览器原生支持手势事件,其他设备需要通过touchstart、touchmove和touchend等基础事件进行自定义实现。本文将详细介绍如何在Vue项目中实现多点触控手势。 ... [详细]
  • 申请地址:https://developer.apple.com/appstore/contact/?topic=expedite 常见申请理由:1. 我们即将发布新产品,这是一个媒体活动,我们无法承担任何风险,因此在多个方面努力提升应用质量。 ... [详细]
  • 使用 Mui.js 获取复选框值的方法
    本文介绍如何使用 Mui.js 框架来获取复选框的值,并通过数组进行处理和展示。 ... [详细]
  • 本文介绍了如何使用线段树实现区间加法和区间查询操作,包括详细的代码实现和解释。 ... [详细]
  • 说明Python教程正在编写中,欢迎大家加微信sinbam提供意见、建议、纠错、催更。drymail是一个邮件发送库,封装了Python的smtplib ... [详细]
  • vue引入echarts地图的四种方式
    一、vue中引入echart1、安装echarts:npminstallecharts--save2、在main.js文件中引入echarts实例:  Vue.prototype.$echartsecharts3、在需要用到echart图形的vue文件中引入:   importechartsfrom&amp;quot;echarts&amp;quot;;4、如果用到map(地图),还 ... [详细]
  • 使用HTML和JavaScript实现视频截图功能
    本文介绍了如何利用HTML和JavaScript实现从远程MP4、本地摄像头及本地上传的MP4文件中截取视频帧,并展示了具体的实现步骤和示例代码。 ... [详细]
  • 本文详细介绍了 Spark 中的弹性分布式数据集(RDD)及其常见的操作方法,包括 union、intersection、cartesian、subtract、join、cogroup 等转换操作,以及 count、collect、reduce、take、foreach、first、saveAsTextFile 等行动操作。 ... [详细]
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社区 版权所有