面试题 前端(一)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 更严谨、更可扩展,现在基本不用。

相关推荐
码路飞9 分钟前
玩了一圈 AI 编程工具,Background Agent 才是让我真正震撼的东西
前端·javascript
UCloud_TShare11 分钟前
优刻得发布云搜索服务CSS:面向AI时代的企业级搜索基础设施
前端·css·人工智能
木斯佳25 分钟前
前端八股文面经大全:字节暑期前端一面(2026-04-21)·面经深度解析
前端·面试·校招·面经·实习
Jolyne_1 小时前
前端从0开始的LangChain学习(一)
前端·langchain
掘金一周1 小时前
掘友们,一人说一个你买过夯到爆的东西 | 沸点周刊 4.23
前端·人工智能·后端
Developer_Niuge1 小时前
告别翻不动的 1000+ 书签:开源 Chrome / Edge 浏览器书签管理插件 Smart Bookmark 0.2 发布
前端·后端
WebInfra1 小时前
Rsbuild 2.0 发布:即将支持 TanStack Start
前端·javascript·程序员
用户52709648744901 小时前
前端性能指标速查手册
前端
淹死在鱼塘的程序猿1 小时前
🚀 告别"一次性聊天":揭秘让 AI 智能体越用越聪明的秘密武器 —— Skills
前端·人工智能·agent
掘金安东尼1 小时前
OpenMUSE 全面详解:非扩散Transformer文生图开源基座(对标GPT Image 2)
前端·javascript·面试