热门标签 | 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、CSS和JavaScript代码的实现,并附有详细的说明和效果图。 ... [详细]
  • 技术分享:从动态网站提取站点密钥的解决方案
    本文探讨了如何从动态网站中提取站点密钥,特别是针对验证码(reCAPTCHA)的处理方法。通过结合Selenium和requests库,提供了详细的代码示例和优化建议。 ... [详细]
  • 深入理解Tornado模板系统
    本文详细介绍了Tornado框架中模板系统的使用方法。Tornado自带的轻量级、高效且灵活的模板语言位于tornado.template模块,支持嵌入Python代码片段,帮助开发者快速构建动态网页。 ... [详细]
  • 前言--页数多了以后需要指定到某一页(只做了功能,样式没有细调)html ... [详细]
  • QUIC协议:快速UDP互联网连接
    QUIC(Quick UDP Internet Connections)是谷歌开发的一种旨在提高网络性能和安全性的传输层协议。它基于UDP,并结合了TLS级别的安全性,提供了更高效、更可靠的互联网通信方式。 ... [详细]
  • 深入理解OAuth认证机制
    本文介绍了OAuth认证协议的核心概念及其工作原理。OAuth是一种开放标准,旨在为第三方应用提供安全的用户资源访问授权,同时确保用户的账户信息(如用户名和密码)不会暴露给第三方。 ... [详细]
  • 本文将介绍如何编写一些有趣的VBScript脚本,这些脚本可以在朋友之间进行无害的恶作剧。通过简单的代码示例,帮助您了解VBScript的基本语法和功能。 ... [详细]
  • CSS 布局:液态三栏混合宽度布局
    本文介绍了如何使用 CSS 实现液态的三栏布局,其中各栏具有不同的宽度设置。通过调整容器和内容区域的属性,可以实现灵活且响应式的网页设计。 ... [详细]
  • 本文介绍了如何利用JavaScript或jQuery来判断网页中的文本框是否处于焦点状态,以及如何检测鼠标是否悬停在指定的HTML元素上。 ... [详细]
  • 深入理解Cookie与Session会话管理
    本文详细介绍了如何通过HTTP响应和请求处理浏览器的Cookie信息,以及如何创建、设置和管理Cookie。同时探讨了会话跟踪技术中的Session机制,解释其原理及应用场景。 ... [详细]
  • 本文介绍了如何使用JQuery实现省市二级联动和表单验证。首先,通过change事件监听用户选择的省份,并动态加载对应的城市列表。其次,详细讲解了使用Validation插件进行表单验证的方法,包括内置规则、自定义规则及实时验证功能。 ... [详细]
  • 本文介绍了一款用于自动化部署 Linux 服务的 Bash 脚本。该脚本不仅涵盖了基本的文件复制和目录创建,还处理了系统服务的配置和启动,确保在多种 Linux 发行版上都能顺利运行。 ... [详细]
  • 程序员妻子吐槽:丈夫北漂8年终薪3万,存款情况令人意外
    一位程序员的妻子在网上分享了她丈夫在北京工作八年的经历,月薪仅3万元,存款情况却出乎意料。本文探讨了高学历人才在大城市的职场现状及生活压力。 ... [详细]
  • 国内BI工具迎战国际巨头Tableau,稳步崛起
    尽管商业智能(BI)工具在中国的普及程度尚不及国际市场,但近年来,随着本土企业的持续创新和市场推广,国内主流BI工具正逐渐崭露头角。面对国际品牌如Tableau的强大竞争,国内BI工具通过不断优化产品和技术,赢得了越来越多用户的认可。 ... [详细]
  • 在计算机技术的学习道路上,51CTO学院以其专业性和专注度给我留下了深刻印象。从2012年接触计算机到2014年开始系统学习网络技术和安全领域,51CTO学院始终是我信赖的学习平台。 ... [详细]
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社区 版权所有