面试题 前端(一)DOCTYPE作用 标准模式与混杂模式区分

一、DOCTYPE作用

Document Type(Declaration)的缩写,是一种标记语言的文档类型声明,必须在HTML文档的第一行,位于HTML标签之前。

作用是告诉浏览器使用哪个版本的HTML规范来渲染文档。

如果不存在或者不正确会导致文档以混杂模式呈现。

html 复制代码
<!DOCTYPE html>

二、标准模式与混杂模式区分

1. 概念

标准模式(Standard Mode):以浏览器支持的最高标准运行。

混杂模式(Quirks Mode):以一种比较宽松的向后兼容的方式显示。

2. 判断

javascript 复制代码
if (document.compatMode === "CSS1Compat") {
  console.log("标准模式");    
} else {
  console.log("混杂模式");   //混杂模式为BackCompat
}

3. 区分

1. 盒模型

标准模式按标准盒模型解析(宽度 = content)

混杂模式按IE盒模型解析(宽度 = content + padding + border)

2. 字体继承

标准模式严格遵循CSS继承规则,子元素会继承父元素的字体样式,除非被明确覆盖。

混杂模式可能会忽略或不完全继承父元素的字体样式。

3. 行内元素

标准模型下内联元素(inline)默认不接受 width 和 height 设置,若想控制内联元素大小,可将其display属性设为 inline-block 或 block 。

混杂模式下给 inline 元素设置宽高有效。

4. 溢出(overflow)

标准模式溢出时内容不会让元素大小自动增大,可能会被裁切。

混杂模式下元素的内容超出尺寸,元素大小自动调整以适应内容。

三、HTML5为什么只需要写<!DOCTYPE html>

HTML5 不基于 SGML(Standard Generalized Markup Language,标准通用标记语言),不需要引用 DTD(Document Type Definition,文档类型定义)文件。

基于 SGML 的需要通过 DOCTYPE 引用一个 DTD 文件来定义规则:

html 复制代码
<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">

告诉浏览器使用 HTML 4.01 Transitional 这个DTD,以及这个文件在哪里(后面的url)。

HTML5 只需要告诉浏览器"以标准模式渲染"。

四、SGML、HTML、XML和XHTML区别

SGML :标准通用标记语言,是定义其他标记语言的元语言,用于各种文档标记,可自定义标签和结构,与HTML、XML不兼容。

HTML :超文本标记语言,用于网页设计,标签固定,与XML不兼容。

XML :可扩展标记语言,用于数据存储与传输,例如配置文件,可自定义标签,与HTML不兼容。

XHTML :用于网页设计 ,标签严格,必须小写,标签必须闭合,属性必须小写,属性必须加引号等。

总结:SGML更复杂且灵活,HTML和XHTML专注于网页结构化,XML专注数据交换。

补充:XHTML是HTML用XML语法重写的版本,目标是让 HTML 更严谨、更可扩展,现在基本不用。

相关推荐
代码搬运媛4 小时前
Jest 测试框架详解与实现指南
前端
counterxing5 小时前
我把 Codex 里的 Skills 做成了一个 MCP,还支持分享
前端·agent·ai编程
wangqiaowq5 小时前
windows下nginx的安装
linux·服务器·前端
之歆5 小时前
DAY_12JavaScript DOM 完全指南(二):实战与性能篇
开发语言·前端·javascript·ecmascript
发现一只大呆瓜5 小时前
Vite凭什么这么快?3分钟带你彻底搞懂 Vite 热更新的幕后黑手
前端·面试·vite
Maimai108085 小时前
React如何用 @microsoft/fetch-event-source 落地 SSE:比原生 EventSource 更灵活的实时推送方案
前端·javascript·react.js·microsoft·前端框架·reactjs·webassembly
kyriewen7 小时前
产品经理把PRD写成“天书”,我用AI半小时重写了一遍,他当场愣住
前端·ai编程·cursor
humcomm8 小时前
元框架的工作原理详解
前端·前端框架
canonical_entropy8 小时前
Attractor Before Harness: AI 大规模开发的方法论
前端·aigc·ai编程
zhangxingchao8 小时前
多 Agent 架构到底怎么选?从 Claude Agent Teams、Cognition/Devin 到工程落地原则
前端·人工智能·后端