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

相关推荐
小小小小宇2 小时前
前端转后端基础- 变量和类型
前端
Cobyte3 小时前
1.基于依赖追踪和触发的响应式系统的本质
前端·javascript·vue.js
主宰者3 小时前
C# CommunityToolkit.Mvvm全局事件
java·前端·c#
前端小咸鱼一条4 小时前
16.迭代器 和 生成器
开发语言·前端·javascript
小江的记录本4 小时前
【注解】常见 Java 注解系统性知识体系总结(附《全方位对比表》+ 思维导图)
java·前端·spring boot·后端·spring·mybatis·web
web守墓人4 小时前
【前端】记一次将ruoyi vue3 element-plus迁移到arco design vue的经历
前端·vue.js·arco design
伊步沁心4 小时前
Webpack & Vite 深度解析
前端
libokaifa4 小时前
OpenSpec + TDD:让 AI 写代码,用测试兜底
前端·ai编程
用户15815963743704 小时前
搭 AI Agent 团队踩了 18 个坑,总结出这 5 个关键步骤
前端