HTML5 扩展了 HTMLDocument 类型

HTMLDocument 扩展

​ HTML5 扩展了 HTMLDocument 类型,增加了更多功能。与其他 HTML5 定义的 DOM 扩展一样, 这些变化同样基于所有浏览器事实上都已经支持的专有扩展。为此,即使这些扩展的标准化相对较晚, 很多浏览器也早就实现了相应的功能。

readyState 属性

​ readyState 是 IE4 最早添加到 document 对象上的属性,后来其他浏览器也都依葫芦画瓢地支持这个属性。最终,HTML5 将这个属性写进了标准。document.readyState 属性有两个可能的值:

  • loading,表示文档正在加载;
  • complete,表示文档加载完成。

​ 实际开发中,最好是把 document.readState 当成一个指示器,以判断文档是否加载完毕。在这个属性得到广泛支持以前,通常要依赖 onload 事件处理程序设置一个标记,表示文档加载完了。这个属性的基本用法如下:

js 复制代码
if (document.readyState == "complete"){ 
    // 执行操作
} 

compatMode 属性

​ 自从 IE6 提供了以标准或混杂模式渲染页面的能力之后,检测页面渲染模式 成为一个必要的需求。 IE 为 document 添加了 compatMode 属性,这个属性唯一的任务是指示浏览器当前处于什么渲染模式。 如下面的例子所示,标准模式下 document.compatMode 的值是"CSS1Compat",而在混杂模式下, document.compatMode 的值是"BackCompat":

js 复制代码
if (document.compatMode == "CSS1Compat"){ 
    console.log("Standards mode"); // 标准模式
} else {
    console.log("Quirks mode");  // 混杂模式
} 

​ HTML5 最终也把 compatMode 属性的实现标准化了。

head 属性

​ 作为对 document.body(指向文档的元素)的补充,HTML5 增加了 document.head 属性,指向文档的元素。可以像下面这样直接取得元素:

js 复制代码
let head = document.head;
相关推荐
Micro麦可乐1 天前
前端拖拽排序实现详解:从原理到实践 - 附完整代码
前端·javascript·html5·拖拽排序·drop api·拖拽api
小白阿龙2 天前
如何实现缓存音频功能(App端详解)
前端·css·html5
smile boy2 天前
个人财务记录应用
前端·javascript·css·css3·html5
LilyCoder2 天前
HTML5武汉旅游网站源码
前端·javascript·html5·旅游
Arwen3033 天前
常见 SSL 证书问题解答:从报错到维护全涵盖
服务器·网络·网络协议·http·https·ssl·html5
陌路玥3 天前
第三章 浏览器 【1. 文档对象模型(DOM)】
开发语言·前端·javascript·html5
SY师弟4 天前
HTML5 网页游戏设计开发——1、HTML基础
游戏·html·html5
超龄超能程序猿5 天前
(5)从零开发 Chrome 插件:Vue3 Chrome 插件待办事项应用
javascript·vue.js·前端框架·json·html5
张晓~183399481215 天前
如果通过源码技术实现矩阵系统分部门管理?
jvm·数据库·线性代数·算法·microsoft·矩阵·html5
合作小小程序员小小店7 天前
web网页开发,在线%微博,舆情%系统,基于python,pycharm,django,nlp,内容推荐,余弦,线性,TF-IDF,mysql
自然语言处理·django·nlp·html5·tf-idf