Quirks(怪癖)模式是什么?它和 Standards(标准)模式有什么区别?

2023-12-02 18:04

本文主要是介绍Quirks(怪癖)模式是什么?它和 Standards(标准)模式有什么区别?,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

前言:

"Quirks模式"和"Standards模式"是与HTML文档渲染模式相关的两种模式。它们影响着浏览器如何解释和渲染HTML和CSS。理解它们之间的区别对于前端开发者和网页设计师来说是至关重要的。本文将深入讨论Quirks模式和Standards模式的区别,以及它们的用途和影响。

用法:

要理解Quirks模式和Standards模式,首先需要知道它们是如何触发的。这两种模式的触发方式是通过文档类型(DOCTYPE)声明来确定的。

<!DOCTYPE HTML PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN">
<html><head><title>示例文档</title></head><body><!-- 页面内容 --></body>
</html>

<!DOCTYPE> 声明指定了文档的类型和版本。不同类型的文档声明会触发不同的渲染模式。

代码:
Quirks模式示例:

如果没有指定文档类型或使用了旧的文档类型,浏览器将进入Quirks模式。这是一种兼容性模式,用于支持旧的HTML文档。

<!-- 没有指定文档类型,将触发Quirks模式 -->
<html><head><title>Quirks模式示例</title></head><body><!-- 页面内容 --></body>
</html>
Standards模式示例:

如果使用了现代的文档类型声明,浏览器将进入Standards模式。这是一种更严格的模式,用于支持HTML5和现代Web标准。

<!DOCTYPE html>
<html><head><title>Standards模式示例</title></head><body><!-- 页面内容 --></body>
</html>
理解:
Quirks模式:

Quirks模式是一种宽松的渲染模式,它是为了与旧版本的HTML文档兼容而设计的。在Quirks模式下,浏览器的行为可能会有一些怪异之处,与标准模式不同。以下是Quirks模式的一些特点:

  1. 怪癖盒模型: 在Quirks模式下,浏览器使用怪癖盒模型来计算元素的宽度和高度。这意味着边距和填充会影响元素的实际大小。
  2. 浮动和定位: 浮动和定位的行为在Quirks模式下与标准模式不同,可能导致页面布局问题。
  3. 垂直对齐: 垂直对齐可能不一致,可能需要额外的样式来修复。
  4. 默认字体: 浏览器可能使用不同的默认字体,导致文本呈现不同。
Standards模式:

Standards模式是一种更严格的渲染模式,它遵循HTML5和现代Web标准。在Standards模式下,浏览器按照标准规范解释和渲染HTML和CSS。以下是Standards模式的一些特点:

  1. 标准盒模型: 在Standards模式下,浏览器使用标准盒模型来计算元素的宽度和高度,边距和填充不会影响实际大小。
  2. 一致的浮动和定位: 浮动和定位的行为在Standards模式下更一致,更容易控制。
  3. 一致的垂直对齐: 垂直对齐行为更一致,不太可能出现不一致的问题。
  4. 一致的字体: 浏览器使用相同的默认字体,文本呈现更一致。

这篇关于Quirks(怪癖)模式是什么?它和 Standards(标准)模式有什么区别?的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/446295

相关文章

Java中ArrayList和LinkedList有什么区别举例详解

《Java中ArrayList和LinkedList有什么区别举例详解》:本文主要介绍Java中ArrayList和LinkedList区别的相关资料,包括数据结构特性、核心操作性能、内存与GC影... 目录一、底层数据结构二、核心操作性能对比三、内存与 GC 影响四、扩容机制五、线程安全与并发方案六、工程

Java实现状态模式的示例代码

《Java实现状态模式的示例代码》状态模式是一种行为型设计模式,允许对象根据其内部状态改变行为,本文主要介绍了Java实现状态模式的示例代码,文中通过示例代码介绍的非常详细,需要的朋友们下面随着小编来... 目录一、简介1、定义2、状态模式的结构二、Java实现案例1、电灯开关状态案例2、番茄工作法状态案例

java中不同版本JSONObject区别小结

《java中不同版本JSONObject区别小结》本文主要介绍了java中不同版本JSONObject区别小结,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们... 目录1. FastjsON2. Jackson3. Gson4. org.json6. 总结在Jav

数据库使用之union、union all、各种join的用法区别解析

《数据库使用之union、unionall、各种join的用法区别解析》:本文主要介绍SQL中的Union和UnionAll的区别,包括去重与否以及使用时的注意事项,还详细解释了Join关键字,... 目录一、Union 和Union All1、区别:2、注意点:3、具体举例二、Join关键字的区别&php

java中的HashSet与 == 和 equals的区别示例解析

《java中的HashSet与==和equals的区别示例解析》HashSet是Java中基于哈希表实现的集合类,特点包括:元素唯一、无序和可包含null,本文给大家介绍java中的HashSe... 目录什么是HashSetHashSet 的主要特点是HashSet 的常用方法hasSet存储为啥是无序的

2.1/5.1和7.1声道系统有什么区别? 音频声道的专业知识科普

《2.1/5.1和7.1声道系统有什么区别?音频声道的专业知识科普》当设置环绕声系统时,会遇到2.1、5.1、7.1、7.1.2、9.1等数字,当一遍又一遍地看到它们时,可能想知道它们是什... 想要把智能电视自带的音响升级成专业级的家庭影院系统吗?那么你将面临一个重要的选择——使用 2.1、5.1 还是

Python中@classmethod和@staticmethod的区别

《Python中@classmethod和@staticmethod的区别》本文主要介绍了Python中@classmethod和@staticmethod的区别,文中通过示例代码介绍的非常详细,对大... 目录1.@classmethod2.@staticmethod3.例子1.@classmethod

Golan中 new() 、 make() 和简短声明符的区别和使用

《Golan中new()、make()和简短声明符的区别和使用》Go语言中的new()、make()和简短声明符的区别和使用,new()用于分配内存并返回指针,make()用于初始化切片、映射... 详细介绍golang的new() 、 make() 和简短声明符的区别和使用。文章目录 `new()`

Python中json文件和jsonl文件的区别小结

《Python中json文件和jsonl文件的区别小结》本文主要介绍了JSON和JSONL两种文件格式的区别,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下... 众所周知,jsON 文件是使用php JSON(JavaScripythonpt Object No

Python 标准库time时间的访问和转换问题小结

《Python标准库time时间的访问和转换问题小结》time模块为Python提供了处理时间和日期的多种功能,适用于多种与时间相关的场景,包括获取当前时间、格式化时间、暂停程序执行、计算程序运行时... 目录模块介绍使用场景主要类主要函数 - time()- sleep()- localtime()- g