”工欲善其事,必先利其器。“—孔子《论语.录灵公》
首页 > 编程 > 一种仅使用 CSS 实时测试 HTML 和 CSS 的实用方法。

一种仅使用 CSS 实时测试 HTML 和 CSS 的实用方法。

发布于2024-11-16
浏览:530

A practical way to test HTML and CSS in real-time using only CSS.

最近,我公开了一个我为创建放射状设计而开发的 CSS 框架。在开发过程中,我遇到了一些挑战,包括测试不同的功能。我注意到 CSS linter 和其他工具不允许我了解为什么某些东西不起作用,即使没有基本错误。另一个典型的 CSS 问题是如何在不同的浏览器之间共享它。幸运的是,我发现某些新的 CSS 功能可以用来创建一系列实时测试。这些功能是@support、@container 和:has()。

通过结合这些功能,我开发了一个测试系统,不仅可以检查框架在浏览器中是否正常工作,而且最重要的是,看看我们是否根据浏览器的要求正确应用 HTML,并避免开发时出现无意的错误一个应用程序。

由于我的 CSS 框架必然使用只有最新浏览器才有的功能,例如像 cos() 和 sin() 这样的三角函数,我创建了一系列规则来测试浏览器是否支持它们。如果不是,则会出现一条消息,要求更新浏览器。同样,如果浏览器不支持 :has(),整个框架都会使用它。

也有浏览器不兼容的典型情况,所以在一些非关键情况下,我使用@support或@container来隐藏某些不影响其使用的Orbit功能。例如,Safari不接受SVG上下文笔画,所以我隐藏它们。

然而,除了这些关键的检查和兼容性之外,使用 CSS 框架时最常见的问题是不知道如何正确使用它。这就是为什么我创建了其他 CSS 规则,允许分析父元素是否具有所需的子元素而不是其他元素。在这里,开发时也会出现视觉警报,以提示代码中的错误位置。

我不想让您厌倦 Orbit 的具体细节,但我会给您留下支持源和相关文档的链接。

仓库:https://github.com/zumerlab/orbit
源文件:https://github.com/zumerlab/orbit/blob/main/src/scss/_support.scss
Orbit 支持文档:https://zumerlab.github.io/orbit-docs/tools/support/

很高兴深入了解:https://heydonworks.com/article/testing-html-with-modern-css

版本声明 本文转载于:https://dev.to/tinchox5/a-practical-way-to-test-html-and-css-in-real-time-using-only-css-3c80?1如有侵犯,请联系[email protected]删除
最新教程 更多>
  • 如果 `std::move` 实际上没有移动任何东西,为什么它被称为 `std::move`?
    如果 `std::move` 实际上没有移动任何东西,为什么它被称为 `std::move`?
    为什么 std::move 命名为 std::move?std::move 函数尽管有它的名字,但它并不实际上移动任何东西。它只是将左值(引用对象的表达式)转换为右值(表示临时对象的表达式)。此转换是通过转换为 xvalue 类别来执行的,这与左值和纯右值不同。这种命名选择的原因可以追溯到该概念的历...
    编程 发布于2024-11-16
  • 如何在悬停时使元素背景颜色变暗而不影响透明度?
    如何在悬停时使元素背景颜色变暗而不影响透明度?
    使用 CSS 使元素背景颜色变暗增强用户界面涉及通过改变交互元素(例如按钮)的外观来突出显示它们。一种常见的方法是在悬停时使背景颜色变暗。最初,人们可能会尝试调整不透明度,但这会影响颜色和透明度。存在更有针对性的解决方案。方法:叠加深色图层使用背景图像创建深色叠加层。该方法保留了原始文本颜色,同时使...
    编程 发布于2024-11-16
  • CSS3 转换与 jQuery 动画:iPad HTML5 应用程序哪个更快?
    CSS3 转换与 jQuery 动画:iPad HTML5 应用程序哪个更快?
    性能比较:CSS3 转换与 jQuery 动画在 iPad HTML5 应用程序中,您实现了触摸事件以提高响应速度并利用用于元素操作的 jQuery。然而,您正在争论是使用 jQuery 动画还是 CSS3 动画转换。让我们深入研究一下它们的性能比较。根据基准研究,jQuery 动画的执行速度明显慢...
    编程 发布于2024-11-16
  • Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta 中的列偏移发生了什么?
    Bootstrap 4 Beta:列偏移的删除和恢复Bootstrap 4 在其 Beta 1 版本中引入了重大更改柱子偏移了。然而,随着 Beta 2 的后续发布,这些变化已经逆转。从 offset-md-* 到 ml-auto在 Bootstrap 4 Beta 1 中, offset-md-*...
    编程 发布于2024-11-16
  • 三元条件运算符在编程中如何工作?
    三元条件运算符在编程中如何工作?
    理解三元条件运算符编程中,使用问号(“?”)和冒号(“:”)运算符括号内形成三元条件运算符。它提供了传统 if-else 语句的简洁替代方案,允许您评估条件并根据其真实性分配值。语法和用法The三元运算符遵循语法:boolean_expression ? true_value : false_val...
    编程 发布于2024-11-16
  • 大批
    大批
    方法是可以在对象上调用的 fns 数组是对象,因此它们在 JS 中也有方法。 slice(begin):将数组的一部分提取到新数组中,而不改变原始数组。 let arr = ['a','b','c','d','e']; // Usecase: Extract till index p...
    编程 发布于2024-11-16
  • 如何访问 Maven 依赖项的源代码和 Javadoc?
    如何访问 Maven 依赖项的源代码和 Javadoc?
    在 Maven 存储库中查找源 JARMaven 是一种流行的 Java 项目包管理工具,提供了广泛的库及其依赖项存储库。通常,开发人员需要访问与这些依赖项关联的源代码或 Javadoc,以进行调试或文档记录。虽然 Maven 存储库通常存储二进制 JAR 文件,但有一种方法可以使用 Maven 检...
    编程 发布于2024-11-16
  • 扩展 Quarkus:何时以及如何编写自己的扩展
    扩展 Quarkus:何时以及如何编写自己的扩展
    Quarkus 凭借其创新的扩展框架,为开发人员提供了一种将各种技术无缝集成到其应用程序中的强大方法。这些扩展简化了配置、启用依赖项注入并优化了性能,使其成为 Java 开发人员的一个有吸引力的选择。然而,在深入创建您自己的 Quarkus 扩展之前,了解何时需要以及如何有效地做到这一点至关重要。 ...
    编程 发布于2024-11-16
  • 如何在 JavaScript 中将数组作为函数参数传递?
    如何在 JavaScript 中将数组作为函数参数传递?
    在 JavaScript 中将数组作为函数参数传递将数组作为单独的参数传递给函数可能是乏味且低效的。考虑以下代码:const x = ['p0', 'p1', 'p2']; call_me(x[0], x[1], x[2]); // Unwieldy and prone to errors解决方案1...
    编程 发布于2024-11-16
  • 如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    如何在 PHP 中组合两个关联数组,同时保留唯一 ID 并处理重复名称?
    在 PHP 中组合关联数组在 PHP 中,将两个关联数组组合成一个数组是一项常见任务。考虑以下请求:问题描述:提供的代码定义了两个关联数组,$array1和$array2。目标是创建一个新数组 $array3,它合并两个数组中的所有键值对。 此外,提供的数组具有唯一的 ID,而名称可能重合。要求是构...
    编程 发布于2024-11-16
  • 如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 查找今天生日的用户?
    如何使用 MySQL 识别今天生日的用户使用 MySQL 确定今天是否是用户的生日涉及查找生日匹配的所有行今天的日期。这可以通过一个简单的 MySQL 查询来实现,该查询将存储为 UNIX 时间戳的生日与今天的日期进行比较。以下 SQL 查询将获取今天有生日的所有用户: FROM USERS ...
    编程 发布于2024-11-16
  • 为什么 Docker 在 macOS 上的性能比在本机 Linux 系统上慢?
    为什么 Docker 在 macOS 上的性能比在本机 Linux 系统上慢?
    macOS 上的 Docker 性能问题在 macOS 中运行 Docker 时,用户经常会遇到明显的性能限制,从而成为高效开发的障碍。这个问题源于 macOS 上 Docker 架构的基本性质。Docker 需要 Linux 内核才能运行,但 macOS 本身并不提供 Linux 内核。相反,它使...
    编程 发布于2024-11-16
  • 如何根据同名其他行的数据更新表中的空值?
    如何根据同名其他行的数据更新表中的空值?
    在表中的行之间复制数据在数据库管理中,经常需要根据表中其他行的数据来更新行同一张桌子。考虑一个包含 ID、NAME 和 VALUE 列的表,其中包含重复的 NAME 值,如下所示:ID | NAME | VALUE | ---------------------------- 1...
    编程 发布于2024-11-16
  • 为什么在 Go 中使用 mgo 时我的“_id”字段为空?
    为什么在 Go 中使用 mgo 时我的“_id”字段为空?
    使用 mgo 在 Go 中检索“_id”字段值的问题排查本文解决了无法检索“_id”字段值的问题当将 mgo 与 Go 一起使用时。尝试从 MongoDB 数据库获取数据时遇到了问题。首先,代码片段定义了一个名为“Article”的结构体,它表示数据库中的文档。它包含“_id”、“title”、“a...
    编程 发布于2024-11-16
  • 如何修复 MySQL 中的双编码 UTF8 字符?
    如何修复 MySQL 中的双编码 UTF8 字符?
    从双编码 UTF8 字符中恢复之前使用 LOAD DATA INFILE 导入的数据被错误地假定为以 Latin1 编码。因此,多字节字符被拆分为单独的字节,随后以 UTF8 进行编码,从而产生双重编码。这会导致字符损坏,例如“Ò±”而不是“ñ”。要纠正这些错误,可以使用特殊的 MySQL 函数在双...
    编程 发布于2024-11-16

免责声明: 提供的所有资源部分来自互联网,如果有侵犯您的版权或其他权益,请说明详细缘由并提供版权或权益证明然后发到邮箱:[email protected] 我们会第一时间内为您处理。

Copyright© 2022 湘ICP备2022001581号-3