Gahing's blog Gahing's blog
首页
知识体系
  • 前端基础
  • 应用框架
  • 工程能力
  • 应用基础
  • 专业领域
  • 业务场景
  • 前端晋升 (opens new window)
  • Git
  • 网络基础
  • 算法
  • 数据结构
  • 编程范式
  • 编解码
  • Linux
  • AIGC
  • 其他领域

    • 客户端
    • 服务端
    • 产品设计
软素质
  • 面试经验
  • 人生总结
  • 个人简历
  • 知识卡片
  • 灵感记录
  • 实用技巧
  • 知识科普
  • 友情链接
  • 美食推荐 (opens new window)
  • 收藏夹

    • 优质前端信息源 (opens new window)
关于
  • 分类
  • 标签
  • 归档
GitHub (opens new window)

Gahing / francecil

To be best
首页
知识体系
  • 前端基础
  • 应用框架
  • 工程能力
  • 应用基础
  • 专业领域
  • 业务场景
  • 前端晋升 (opens new window)
  • Git
  • 网络基础
  • 算法
  • 数据结构
  • 编程范式
  • 编解码
  • Linux
  • AIGC
  • 其他领域

    • 客户端
    • 服务端
    • 产品设计
软素质
  • 面试经验
  • 人生总结
  • 个人简历
  • 知识卡片
  • 灵感记录
  • 实用技巧
  • 知识科普
  • 友情链接
  • 美食推荐 (opens new window)
  • 收藏夹

    • 优质前端信息源 (opens new window)
关于
  • 分类
  • 标签
  • 归档
GitHub (opens new window)
  • 前端基础

    • 编程语言

      • CSS

      • HTML

        • LearningHTML
        • htmlparser实现
        • inline-block 文本宽度溢出问题
        • svg笔记
        • css与js的阻塞关系
        • document-write重写
        • getElementsByClassName遍历时出现的问题
        • 前端小知识-格式化标签
        • 前端监听资源加载错误
        • 浅谈 View Transitions API
        • 通读 HTML Standard
      • JavaScript

      • Rust

      • TypeScript

      • WebAssembly

    • 开发工具

    • 前端调试

    • 浏览器原理

    • 浏览器生态

  • 应用框架

  • 工程能力

  • 应用基础

  • 专业领域

  • 业务场景

  • 大前端
  • 前端基础
  • 编程语言
  • HTML
gahing
2018-07-12

前端小知识-格式化标签

常见的html格式化标签:a, b, big, code, em, font, i, nobr, s, small, strike, strong, tt, and u.

对于以下代码

<!DOCTYPE html>
<html>
<head></head>
<body>
  <div>
    <p><b>666</p>
  </div>
  <div>aaa</div>
</body>
</html>
1
2
3
4
5
6
7
8
9
10

渲染引擎会将其解析成

<html>
<head></head>
<body>
  <div>
    <p><b>666</b></p>
    <b></b>
  </div>
  <b>
    <div>aaa</div>
  </b>
</body>
</html>
1
2
3
4
5
6
7
8
9
10
11
12

即浏览器认为格式化标签的开闭标签可能是会跨节点的(非同一级)

后续查找没有找到闭标签会在原节点基础上添加格式化标签为父节点

因为 b 等带有格式化的标签会特殊处理,遇到一个开标签时会它们放到一个列表里面:

m_activeFormattingElements.append(currentElementRecord()->stackItem());
1

遇到一个闭标签时,又会从这个列表里面删掉。每处理一个新标签时就会进行检查和这个列表和栈里的开标签是否对应,如果不对应则会 reconstruct :重新插入一个开标签。因此 b 就不断地被重新插入,直到遇到下一个b的闭标签为止。

参考 从Chrome源码看浏览器如何构建DOM树

编辑 (opens new window)
上次更新: 2024/09/01, 23:56:56
getElementsByClassName遍历时出现的问题
前端监听资源加载错误

← getElementsByClassName遍历时出现的问题 前端监听资源加载错误→

最近更新
01
浅谈代码质量与量化指标
08-27
02
快速理解 JS 装饰器
08-26
03
Vue 项目中的 data-v-xxx 是怎么生成的
09-19
更多文章>
Theme by Vdoing | Copyright © 2016-2024 Gahing | 闽ICP备19024221号-1
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式