百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术文章 > 正文

太强了!字节大佬总结——《你不知道得css原理》!

myzbx 2025-01-06 14:23 51 浏览

BFC、IFC、FFC、GFC粗解

flex容易忽略的属性

  • flex-grow:等比分配剩余空间
  • flex-shrink:等比压缩多余空间
  • flex-basis: 基本格的大小,可以是百分比
  • min/max-winth>flex-basis>width
    flex这三个决定了flex盒模型如何分配空间。

flex:1、flex:0、flex:auto。

  • flex:auto;flex布局默认值,相当于flex: 0 1 auto;相当于flex-grow:0; flex-shrink:1;flex-basis:auto;(如果超出空间则会等比压缩),充分的使用剩余的空间,各自元素按照各自内容进行分配。
  • flex: 1;相当于flex: 1 1 0%;同上,平均瓜分剩余空间,适用于等分布局。
  • flex:0;相当于flex:0 1 0;宽度最小化,内容最小化宽度。
  • flex: none;相当于flex: 0 0 auto;内容最大化宽度(内容多大宽度多大),没有弹性;
  • 分配算法:自身宽度 * 分配数 / 自身宽度 * 分配数之和 * (剩余/压缩空间)
  • 格式上下文

    css中的一种概念:它是页面中的一块渲染区域,并且有一套渲染规则,它决定了其子元素将如何定位,以及和其他元素的关系和相互作用。

    BFC

    BFC(Block Formatting Context)格式化上下文,是Web页面中盒模型布局的CSS渲染模式,指一个独立的渲染区域或者说是一个隔离的独立容器。
    如何形成bfc:

    1. 浮动元素,float 除 none 以外的值;
    2. 定位元素,position(absolute,fixed);
    3. display 为以下其中之一的值 inline-block,table-cell,table-caption;
    4. overflow 除了 visible 以外的值(hidden,auto,scroll);

    bfc的特性:

    • 内部的Box会在垂直方向,一个接一个地放置。
    • Box垂直方向的距离由margin决定。属于同一个BFC的两个相邻Box的margin会发生重叠。
    • 每个盒子(块盒与行盒)的margin box的左边,与包含块border box的左边相接触(对于从左往右的格式化,否则相反)。即使存在浮动也是如此。
    • BFC的区域不会与float box重叠。
    • BFC就是页面上的一个隔离的独立容器,容器里面的子元素不会影响到外面的元素。反之也如此。
    • 计算BFC的高度时,浮动元素也参与计算。


    IFC


    触发IFC: 块级元素中仅包含内联级别元素 形成条件非常简单,需要注意的是当IFC中有块级元素插入时,会产生两个匿名块将父元素分割开来,产生两个IFC。 IFC特性:

    IFC布局规则

  • 在一个IFC内,子元素是水平方向横向排列的,并且垂直方向起点为元素顶部。
  • 子元素只会计算横向样式空间,【padding、border、margin】,垂直方向样式空间不会被计算,【padding、border、margin】。
  • 在垂直方向上,子元素会以不同形式来对齐(vertical-align)
  • 能把在一行上的框都完全包含进去的一个矩形区域,被称为该行的行框(line box)。行框的宽度是由包含块(containing box)和与其中的浮动来决定。
  • IFC中的line box一般左右边贴紧其包含块,但float元素会优先排列。
  • IFC中的line box高度由 CSS 行高计算规则来确定,同个IFC下的多个line box高度可能会不同。
  • 当 inline boxes的总宽度少于包含它们的line box时,其水平渲染规则由 text-align 属性值来决定。
  • 当一个inline box超过父元素的宽度时,它会被分割成多个boxes,这些boxes分布在多个line box中。如果子元素未设置强制换行的情况下,inline box将不可被分割,将会溢出父元素。
  • FFC和GFC


    其实就是flex布局和Grid布局具体规则。 流式布局对ffc的影响

    • float、clear和vertical-align属性在伸缩项目上没有效果
    • 伸缩容器的margin与其内容的margin不会重叠
    • text-align属性在伸缩容器上没有效果,因为其只可应用于块级block容器
    • 另外,columns属性伸缩容器上没有效果


    HTML构成元素和几个重要的标签

    构成元素

    html构成元素可分为三类

    • 行级元素:行内元素不能独占一行,与其他行内元素排成一行。不能设置宽高等
    • 块级元素:块级元素独占一行,当没有设置宽高时,它默认设置为100%。可以设置宽高等
    • 行内块元素:能设置宽高等,可以和其他元素同行 其实除去几个特殊标签,使用div和span就可以实现html大部分页面


    特殊元素


    有几个特殊块级元素只能包含内联元素或者可变元素,不能包含块级元素。这几个特殊标签是 h1~h6、p、dt。

    DOCTYPE(?档类型)

    DOCTYPE是HTML5中一种标准通用标记语言的文档类型声明,它的目的是告诉浏览器(解析器)应该以什么样(html或xhtml)的文档类型定义来解析文档,不同的渲染模式会影响浏览器对 CSS 代码甚? JavaScript 脚本的解析。它必须声明在HTML?档的第??。

    meta元信息

    meta 标签由 name和 content属性定义,用来描述网页文档的属性,比如网页的作者,网页描述,关键词等,除了HTTP标准固定了一些name作为大家使用的共识,开发者还可以自定义name。
    meta 元素定义的元数据的类型包括以下几种:

    • 如果设置了 name属性,meta 元素提供的是文档级别(document-level)的元数据,应用于整个页面。
    • 如果设置了 http-equiv属性,meta 元素则是编译指令,提供的信息与类似命名的HTTP头部相同。
    • 如果设置了 charset属性,meta 元素是一个字符集声明,告诉文档使用哪种字符编码。
    • 如果设置了itemprop 属性,meta 元素提供用户定义的元数据。 其中name=viewport 可用于移动端的适配,其content可配置其类型 其中,content 参数有以下几种:
    ini
    复制代码
    <meta name="viewport" content="width=device-width, initial-scale=1, maximum-scale=1">\
    • width viewport :宽度
    • height viewport :高度
    • initial-scale :初始缩放比例
    • maximum-scale :最大缩放比例
    • minimum-scale :最小缩放比例
    • user-scalable :是否允许用户缩放

    DTD规范

    文档类型定义(DTD)可定义合法的XML文档构建模块。它使用一系列合法的元素来定义文档的结构。 DTD 可被成行地声明于 XML 文档中,也可作为一个外部引用。


    重绘和重排

    重排

    所谓重排,实际上是根据渲染树中每个渲染对象的信息,计算出各自渲染对象的几何信息(DOM对象的位置和尺寸大小),并将其安置在界面中的正确位置。

    重绘

    所谓重绘,就是当页面中元素样式的改变并不影响它在文档流中的位置时,例如更改了字体颜色,浏览器会将新样式赋予给元素并重新绘制的过程。

    浏览器执行过程

    浏览器渲染网页的过程:

    • 构建DOM树:词法分析然后解析成DOM树(dom tree),是由dom元素及属性节点组成,树的根是document对象
    • 构建CSS规则树:生成CSS规则树(CSS Rule Tree)
    • 构建render树:Web浏览器将DOM和CSSOM结合,并构建出渲染树(render tree)
    • 布局(Layout):计算出每个节点在屏幕中的位置
    • 绘制(Painting):即遍历render树,并使用UI后端层绘制每个节点


    CSS解释器和布局

    解释过程

    CSS解释器是指从CSS字符串经过CSS解释器处理后变成渲染引擎的内部规则表示的过程。 由CSSParser类负责收集样式创建结构,最后由引擎将结构设置入stylesrulus规则表。

    在解释网页中自定义的CSS样式之前,实际上Webkit渲染引擎会为每个网页设置一个默认的样式,这决定了网页所没有设置的元素属性及其属性默认值和将要显示的效果。一般来讲,不同的Webkit移植可以设置不同的默认样式。


    样式规则匹配

    样式规则建立完成之后,Webkit保存规则结构在DocumentRuleSets对象中。当DOM的节点建立之后,Webkit会为其中的一些节点(可视节点)选择合适的样式信息。这些工作都是由StyleResolver负责。

    基本的思路是使用StyleResolver来为DOM的元素节点匹配样式。StyleResolver类根据元素的信息,例如Tag Name、Class等,从样式规则中查找最匹配的规则,然后将样式信息保存到新建的RenderStyle中。最后这些RenderStyle对象被RenderObject使用。

    样式的匹配则是由ElementRuleCollector来计算并获得,它根据元素的属性等信息,从之前的DocumentRuleSets中获取规则集合,依次按照ID、Class、Tag等选择器信息逐次匹配获得元素的样式。具体的过程是:

    1. 当Webkit需要为HTML元素创建RenderObject的时候,首先StyleResolver负责获取样式信息,并返回RenderStyle对象,RenderStyle对象包含了匹配完的结果样式信息;
    2. 根据实际需求,每个元素可能需要匹配不同来源的规则,依次是浏览器规则集合、用户规则集合和HTML网页中包含的自定义规则集合。这三个规则的匹配方式是类似的,这里以自定义规则匹配为例;
    3. 对于自定义规则集合,它先查找ID规则,检测有无匹配的规则,之后依次检测类型规则、标签规则等。如果某个规则匹配上该元素,Webkit把这些规则保存到匹配结果中;
    4. 最后,Webkit对这些规则进行排序。对于该元素需要的样式属性,Webkit选择从高优先级规则中选取,并将样式属性返回。


    JavaScript设置样式

    CSSOM定义了JavaScript访问样式的能力和方式。 大致的过程是,JavaScript引擎调用设置属性值的公共处理函数,然后该函数调用属性值解析函数。而后Webkit将解析后的信息设置到元素的style属性的样式webkitTransform中,然后设置标记表明该元素需要重新计算样式,之后重排。


    你不知道的css原理
    原文链接:https://juejin.cn/post/7277490853496012811

    相关推荐

    如何设计一个优秀的电子商务产品详情页

    加入人人都是产品经理【起点学院】产品经理实战训练营,BAT产品总监手把手带你学产品电子商务网站的产品详情页面无疑是设计师和开发人员关注的最重要的网页之一。产品详情页面是客户作出“加入购物车”决定的页面...

    怎么在JS中使用Ajax进行异步请求?

    大家好,今天我来分享一项JavaScript的实战技巧,即如何在JS中使用Ajax进行异步请求,让你的网页速度瞬间提升。Ajax是一种在不刷新整个网页的情况下与服务器进行数据交互的技术,可以实现异步加...

    中小企业如何组建,管理团队_中小企业应当如何开展组织结构设计变革

    前言写了太多关于产品的东西觉得应该换换口味.从码农到架构师,从前端到平面再到UI、UE,最后走向了产品这条不归路,其实以前一直再给你们讲.产品经理跟项目经理区别没有特别大,两个岗位之间有很...

    前端监控 SDK 开发分享_前端监控系统 开源

    一、前言随着前端的发展和被重视,慢慢的行业内对于前端监控系统的重视程度也在增加。这里不对为什么需要监控再做解释。那我们先直接说说需求。对于中小型公司来说,可以直接使用三方的监控,比如自己搭建一套免费的...

    Ajax 会被 fetch 取代吗?Axios 怎么办?

    大家好,很高兴又见面了,我是"高级前端进阶",由我带着大家一起关注前端前沿、深入前端底层技术,大家一起进步,也欢迎大家关注、点赞、收藏、转发!今天给大家带来的主题是ajax、fetch...

    前端面试题《AJAX》_前端面试ajax考点汇总

    1.什么是ajax?ajax作用是什么?AJAX=异步JavaScript和XML。AJAX是一种用于创建快速动态网页的技术。通过在后台与服务器进行少量数据交换,AJAX可以使网页实...

    Ajax 详细介绍_ajax

    1、ajax是什么?asynchronousjavascriptandxml:异步的javascript和xml。ajax是用来改善用户体验的一种技术,其本质是利用浏览器内置的一个特殊的...

    6款可替代dreamweaver的工具_替代powerdesigner的工具

    dreamweaver对一个web前端工作者来说,再熟悉不过了,像我07年接触web前端开发就是用的dreamweaver,一直用到现在,身边的朋友有跟我推荐过各种更好用的可替代dreamweaver...

    我敢保证,全网没有再比这更详细的Java知识点总结了,送你啊

    接下来你看到的将是全网最详细的Java知识点总结,全文分为三大部分:Java基础、Java框架、Java+云数据小编将为大家仔细讲解每大部分里面的详细知识点,别眨眼,从小白到大佬、零基础到精通,你绝...

    福斯《死侍》发布新剧照 &quot;小贱贱&quot;韦德被改造前造型曝光

    时光网讯福斯出品的科幻片《死侍》今天发布新剧照,其中一张是较为罕见的死侍在被改造之前的剧照,其余两张剧照都是死侍在执行任务中的状态。据外媒推测,片方此时发布剧照,预计是为了给不久之后影片发布首款正式预...

    2021年超详细的java学习路线总结—纯干货分享

    本文整理了java开发的学习路线和相关的学习资源,非常适合零基础入门java的同学,希望大家在学习的时候,能够节省时间。纯干货,良心推荐!第一阶段:Java基础重点知识点:数据类型、核心语法、面向对象...

    不用海淘,真黑五来到你身边:亚马逊15件热卖爆款推荐!

    Fujifilm富士instaxMini8小黄人拍立得相机(黄色/蓝色)扫二维码进入购物页面黑五是入手一个轻巧可爱的拍立得相机的好时机,此款是mini8的小黄人特别版,除了颜色涂装成小黄人...

    2025 年 Python 爬虫四大前沿技术:从异步到 AI

    作为互联网大厂的后端Python爬虫开发,你是否也曾遇到过这些痛点:面对海量目标URL,单线程爬虫爬取一周还没完成任务;动态渲染的SPA页面,requests库返回的全是空白代码;好不容易...

    最贱超级英雄《死侍》来了!_死侍超燃

    死侍Deadpool(2016)导演:蒂姆·米勒编剧:略特·里斯/保罗·沃尼克主演:瑞恩·雷诺兹/莫蕾娜·巴卡林/吉娜·卡拉诺/艾德·斯克林/T·J·米勒类型:动作/...

    停止javascript的ajax请求,取消axios请求,取消reactfetch请求

    一、Ajax原生里可以通过XMLHttpRequest对象上的abort方法来中断ajax。注意abort方法不能阻止向服务器发送请求,只能停止当前ajax请求。停止javascript的ajax请求...