http://liaozj.blog.51cto.com/3618860/673389

浏览器在解析HTML文档时,会把HTML解析为一种称为文档对象模型(Document Object Model)的对象集合,简称DOM。DOM的结构是树状的。
如果学过编程的话,对于“对象”和“树”的概念一定不陌生,不过如果没学过的话,那我还是要好好说说。

对象是一个编程的概念,可以说是把一堆有关联的函数和变量封装起来,称为“类”,变量称为“属性”,函数称为“方法”。属于这个“类”的称为“实例”。
比如我们把“人”这个概念封装为对象,身高、体重这些是属性,走、跳等是方法。老夏是“人”这个类的一个实例,我也是“人”这个类的一个实例。
尽管我和老夏是不同的“人”的实例,各项属性也不一定相同,但是我们都可以实现相同的方法,而不用管这个方法实现上的差异(比如老夏走起来可能一步1米,而我只有0.5米,“步距”也是我们的之间不同的属性,但是走的方法是一样的)。

当然,在HTML中,每个元素都是一个对象实例,这些元素都有不同的属性,有的属性是我们在HTML中可以设定的,有的属性是浏览器解析HTML文档是生成的。属性也可以是另一个对象。
每个元素也都有自己的方法,虽然我们这里不讲,但是学习JavaScript的话就会接触到了。
此外还有一种特殊的称为“事件”的属性,是根据一些状态的改变来触发一些动作的。事件属性在HTML中我们也稍有介绍。

树是一种数据结构,也就是组织数据之间的关系的。树是由一个一个的节点和他们之间有层次的关系组成的。
和现实中的树类似,树都有一个根节点,但是计算机中的树一般是倒着画的,也就是说根是在最上面的。
根节点下面可以有多个子节点,子节点下面也可以有更多的子节点。
没有子节点的节点称为“叶节点”。
上一级的节点称为父节点,一个节点只能有一个父节点。
所有上级的节点(父节点,父节点的父节点,父节点的父节点的父节点……)称为“祖先节点”,所有下级节点(子节点,子节点的子节点,子节点的子节点的子节点……)称为“后代节点”(或“子孙”)。
有同一个父节点的节点称为兄弟节点,父节点是兄弟节点的两个节点称为堂兄弟节点。
每一个节点和他的所有后代节点都是一棵“子树”,同样这个节点就是这棵“子树”的“根”。

想到了什么了?没错,我们的家谱(只考虑父方)就是一棵“树”。
我们的磁盘目录结构也是一棵“树”,所以我们有“磁盘根目录”的说法。每个目录都是一个有子节点的节点,而文件就是叶节点。

那么我们的HTML文档树是怎么样的呢?

html元素就是这个文档的根节点。
html元素的子节点有且只有两个:head元素和body元素。

HTML的元素的父子关系是根据嵌套来区分的。
比如:

复制代码

  1. <div><p><a><b></b></a></p></div>

这是一个四级的嵌套,div的子元素是p,p的子元素是a,a的子元素是b。
当然,同一级的元素就不用多说了吧

复制代码

  1. <div><p><a><b></b></a></p><p><a></a></p><a></a></div>

两个p都是div的子元素,但是第一个a是第一个p的子元素,并且有一个子元素b,第二个a是第二个p的子元素,第三个a是div的子元素,和两个p是兄弟元素。

所以XHTML要求严格的嵌套,因为这是解析文档树的依据。
虽然没有良好的嵌套浏览器也不会报错,但是得到的结果可能并不是我们期望的,所以按照XHTML的格式来书写源代码是一个很好的习惯。

文档树解析出来之后,每个节点都是一个元素对象(比如a元素是Anchor对象,form是一个Form对象),对象又都有各自的属性和方法(我没说过吗?样式也是元素的属性),然后浏览器就把这些节点根据属性的取值显示出来,最后呈现在我们面前的就是一个网页了。

JavaScript操作的对象不是别的,正是DOM,所以我们可以用JS修改各个节点的属性,甚至添加、删除节点,从而表现出丰富多彩的效果。

如果你能理解这篇文章中所讲的内容,那么前面讲到的“后代选择器、直接子代选择器”这些应该是能很好地了解了

浏览器如何解析HTML文档相关推荐

  1. 火狐浏览器 xml 解析错误:文档元素后存有无效内容_五分钟了解浏览器工作原理...

    作者简介: 李中凯 八年多工作经验 前端负责人, 擅长JavaScript/Vue. 掘金文章专栏:KaysonLi 的个人主页 - 专栏 - 掘金 Web 浏览器无疑是用户访问互联网最常见的入口.浏 ...

  2. 细节:解析XML文档和XML字符串

    总代码如下: var XMLHttp = null; if (window.XMLHttpRequest) { //现代浏览器XMLHttp = new XMLHttpRequest(); } els ...

  3. Dom4j 解析Xml文档及XPath查询 学习笔记

    本文查阅方法:     1.查阅目录 -- 查阅本文目录,确定想要查阅的目录标题     2.快捷"查找" -- 在当前浏览器页面,按键 "Ctrl+F" 按键 ...

  4. java 检索编号输出信息_java,_java 如何解析txt文档,输入检索信息,然后输出,java - phpStudy...

    java 如何解析txt文档,输入检索信息,然后输出 请输入代码需求: 请解析config.txt,文件格式包括段落名称.字段名称和字段值.段落名称的值为:"segment:"右边 ...

  5. Dom4j 解析Xml文档及 XPath查询 学习笔记

    2019独角兽企业重金招聘Python工程师标准>>> 本文查阅方法:     1.查阅目录 -- 查阅本文目录,确定想要查阅的目录标题     2.快捷"查找" ...

  6. XML 解析XML文档 XML约束

    XML 什么是XML Extensible Markup Language(可扩展的标记语言) 他是一个语言,有自己的语法,和Java以及其他的编程无关 "标记" 在文件中包含类似 ...

  7. 【学习笔记】关于DOM4J:使用DOM4J解析XML文档

    一.概述 DOM4J是一个易用的.开源的库,用于XML.XPath和XSLT中.采用了Java集合框架并完全支持DOM.SAX.和JAXP. DOM4J最大的特色是使用大量的接口,主要接口都在org. ...

  8. 用Python提取解析pdf文档中内容

    用Python提取解析pdf文档中内容 文章目录: 参考: 1.https://blog.csdn.net/tmaczt/article/details/82876018 # Tika库 2.http ...

  9. DOM4J解析XML文档、Document对象、节点对象节点对象属性、将文档写入XML文件(详细)...

    Dom4j是一个简单.灵活的开放源代码的库.Dom4j是由早期开发JDOM开发的.与JDOM不同的是,dom4j使用接口和抽象的人分离出来而后独立基类,虽然Dom4j的API相对要复杂一些,但它提供了 ...

最新文章

  1. Python的Crypto模块使用:自动输入Shell中的密码
  2. mysql 导出select语句结果到excel文件等
  3. 如何做一个姿势正确的2B产品经理
  4. Navigation bar - remove recent object
  5. 按关键字截取linux日志,linux awk截取数据,如何根据第二部分数据的关键字‘aaaaa’获取整串数据...
  6. LeetCode 1290 二进制链表转整数
  7. 不同DPI下窗体的自适应的有关注意点(转)
  8. playframework文档未提及,但你能做的事
  9. postgreSQL除法保留小数
  10. 快速查找文件的工具Everything
  11. Vue将echarts数据导出成excel文件
  12. OpenBSD 清理 OpenSSL 代码 一周递交数百补丁
  13. python爬虫英文翻译_python爬虫学习---爬取微软必应翻译(中英互译)
  14. 小米手机一键刷入bl锁重锁_OPPO手机完美安装Kingroot实现一键root
  15. aardio - 【库】内存画板 paint
  16. 我的保研之路-哈工大计算机,中科院信工所,复旦大数据学院
  17. 从一个例子看ASCII点阵字库的应用原理
  18. 可能是最详细的Win10+黑苹果双系统安装教程(For Dell 7580)
  19. ubuntu14.04自定义系统默认xp字体
  20. python爬取58同城租房信息_分页爬取58同城租房信息.py

热门文章

  1. WLAN 无线网络 02 - 频率、信道、编码、调制
  2. 解决IE6中PNG图出现灰色背景问题
  3. Ubuntu新版发布周期
  4. Postgresql 9.3外部数据封装的新功能
  5. 证券行业日志审计需求分析,产品选型和实施建议
  6. 智能指针(一):STL auto_ptr实现原理
  7. tp5自定义一个函数php,tp5 如何模块自定义函数!
  8. MapReduce 学习指南
  9. 数据治理需要注意什么问题
  10. 大屏数据可视化效果如何提升