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. 一致的字体: 浏览器使用相同的默认字体,文本呈现更一致。

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.hqwc.cn/news/238438.html

如若内容造成侵权/违法违规/事实不符,请联系编程知识网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

​iOS Class Guard github用法、工作原理和安装详解及使用经验总结

iOS Class Guard是一个用于OC类、协议、属性和方法名混淆的命令行工具。它是class-dump的扩展。这个工具会生成一个symbol table&#xff0c;这个table在编译期间会包含进工程中。iOS-Class-Guard能有效的隐藏绝大多数的类、协议、方法、属性和 实例变量 名。 iOS-Class-Guard不…

.Net core 6.0 升8.0

1 Update Visual Studio 2 3 用Nutget 更新不同套件版本 更新后结果如下&#xff1a;

苹果 macOS 14.1.2 正式发布 更新了哪些内容?

苹果今日向 Mac 电脑用户推送了 macOS 14.1.2 更新&#xff08;内部版本号&#xff1a;23B92 | 23B2091&#xff09;&#xff0c;本次更新距离上次发布隔了 28 天。 需要注意的是&#xff0c;因苹果各区域节点服务器配置缓存问题&#xff0c;可能有些地方探测到升级更新的时间略…

nagios 监控dell设备(网上相关内容较少,特意留档)

#创作灵感#记录工作实践、项目复盘 错误信息&#xff1a; a.Unable to get status information due to technical issues. b.Dell EMC device discovery is in progress... Error: Empty or Invalid Passphrase is configured c.Error: Path not configured for the macro …

电子学会C/C++编程等级考试2021年12月(四级)真题解析

C/C++等级考试(1~8级)全部真题・点这里 第1题:移动路线 桌子上有一个m行n列的方格矩阵,将每个方格用坐标表示,行坐标从下到上依次递增,列坐标从左至右依次递增,左下角方格的坐标为(1,1),则右上角方格的坐标为(m,n)。 小明是个调皮的孩子,一天他捉来一只蚂蚁,不小心把…

Java-easyExcel入门教程

文章目录 前言一、简介二、使用步骤1. 引入依赖2. 前提准备3. 实现导出4. 实现导入 三、我所遇到的问题四、总结 前言 在日常开发中经常会遇到一些 excel 表导入导出的需求&#xff0c;以往会使用 POI 封装成工具类来处理这些导入导出的需求&#xff0c;但是 POI 在导入大文件…

VM虚拟机的配置文件(.vmx)损坏修复

TOC 一、概述 在使用Vm虚拟机的时候&#xff0c;我的电脑蓝屏后导致.vmx打不开了&#xff0c;而且点击没有任何提示信息。应该是配置文件损坏了 二、环境 VM版本&#xff1a;VMware Workstation 16 Pro 16.2.1 build-18811642Windows版本&#xff1a;Windows 10 家庭版 三…

基于瑞芯微rk3588+寒武纪 | 38TOPS INT8算力的AI边缘计算盒子,智能安防、智慧工地、智慧城管、智慧油站

边缘计算盒子 瑞芯微rk3588寒武纪 | 38TOPS INT8算力 ● 采用 Big-Little 大小核架构&#xff0c;搭载四核 A76四核 A55&#xff0c;CPU主频高达 2.4GHz &#xff0c;提供1MB L2 Cache 和 3MB L3 &#xff0c;Cache提供更强的 CPU 运算能力。 ● 高性能四核 Mali-G610 GPU&a…

基于单片机设计的智能水泵控制器

一、前言 在一些场景中&#xff0c;如水池、水箱等水体容器的管理中&#xff0c;保持水位的稳定是至关重要的。传统上&#xff0c;人们通常需要手动监测水位并进行水泵的启停控制&#xff0c;这种方式不仅效率低下&#xff0c;还可能导致水位过高或过低&#xff0c;从而对水体…

qcustomplot绘图 设置横纵坐标间隔 刻度值标题 绘制样式

ui->widget_ant1->plotLayout()->insertRow(0);ui->widget_ant1->plotLayout()->addElement(0, 0, new QCPTextElement(ui->widget_ant1, "天线1", QFont("Microsoft YaHei UI", 12, QFont::Bold)));//设置背景渐变色plotGradient.se…

scrapy框架

scrapy文档 文档链接 安装指南 — Scrapy 2.5.0 文档 (osgeo.cn)https://www.osgeo.cn/scrapy/intro/install.html 创建scrapy框架 0.介绍&#xff1a; scrapy是异步非阻塞框架 异步&#xff1a;一个主线程有20个任务&#xff0c;可以来回切换 非阻塞&#xff1a;运行的程序不需…

Android超简单实现-即时更新Toast(可直接复制)

效果 实现 第一步、封装个工具类ToastUtil.class&#xff08;可直接复制拿走&#xff09; public class ToastUtil {private static Toast mToast null; // toast对象&#xff0c;用于判断是否第一次使用/*** 即时更新Toast* param content content* param message 消息内容…