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;
相关推荐
星光一影17 小时前
合成植物大战僵尸 安卓原生APP Cocos游戏 支持Sigmob
android·游戏·php·html5·web app
霍理迪18 小时前
HTML常用行内标签
css·html·html5
旧梦吟2 天前
脚本网页 地球演化
前端·算法·css3·html5·pygame
行走的陀螺仪2 天前
Vue3 项目单元测试全指南:价值、Vitest 落地与提效方案
开发语言·前端·单元测试·html5·vitest
0思必得03 天前
[Web自动化] HTML5常见新增标签
前端·python·自动化·html5·web自动化
默默学前端3 天前
html列表标签及css列表属性
前端·css·html5
武清伯MVP4 天前
深入了解Canvas:HTML5时代的绘图利器(二)
前端·html5·canvas
武清伯MVP4 天前
深入了解Canvas:HTML5时代的绘图利器(一)
前端·html5·canvas
江公望5 天前
HTML5 History 模式 5分钟讲清楚
前端·html·html5
旧梦吟6 天前
脚本 生成图片水印
前端·数据库·算法·golang·html5