CSS 过渡不会触发隐藏元素
在 Web 开发中,通常使用 CSS 过渡来对元素属性的更改进行动画处理。然而,一个常见的障碍是当一个元素最初被隐藏(例如,使用 display: none),然后变得可见,但 CSS 过渡没有激活。
CSSOM 和的幕后花絮DOM
要理解这种行为,我们需要考虑 CSS 对象模型 (CSSOM) 和文档对象模型之间的关系(DOM)。 DOM 表示页面的 HTML 结构,而 CSSOM 表示每个元素的计算样式。
在渲染过程中,首先发生 DOM 操作(例如,更改显示属性)。然后,浏览器重新计算页面上所有元素的计算样式 (CSSOM),称为回流或布局。最后,这些变化会以视觉方式呈现在屏幕上(绘画)。
对 CSS 过渡的影响
CSS 过渡需要元素的初始计算样式来计算开始状态。但是,对于隐藏元素,计算出的样式本质上为空,因为它们不会显示。这意味着当触发转换时,初始状态对于任何可转换值都无效。
解决方案
要解决此问题,您可以使用以下方法之一方法:
- 强制回流:使用 requestAnimationFrame 或其他方法触发回流会强制浏览器重新计算计算的样式。通过在触发转换之前调用回流,您可以确保计算的样式是最新的。
- 在内部使用 $.animate()**: .animate()通过触发 DOM 操作然后调度回调来触发转换来强制回流。但是,这种方法通常比使用直接回流方法慢。
示例
以下代码片段演示了如何使用 requestAnimationFrame 强制回流:
$('button').on('click', function() { $('.b').show(); // Show the hidden element requestAnimationFrame(() => { // Force a reflow // Trigger the transitions $('.b').css('right', '80%'); $('.a').css('right', '80%'); }); });
通过使用requestAnimationFrame,我们确保CSS转换能够成功触发,即使对于最初隐藏的元素。
以上是为什么 CSS 过渡不适用于隐藏元素?的详细内容。更多信息请关注PHP中文网其他相关文章!

这是我们在形式可访问性上进行的小型系列中的第三篇文章。如果您错过了第二篇文章,请查看“以:focus-visible的管理用户焦点”。在

本教程演示了使用智能表单框架创建外观专业的JavaScript表单(注意:不再可用)。 尽管框架本身不可用,但原理和技术仍然与其他形式的建筑商相关。

CSS盒子阴影和轮廓属性获得了主题。让我们查看一些在真实主题中起作用的示例,以及我们必须将这些样式应用于WordPress块和元素的选项。

Svelte Transition API提供了一种使组件输入或离开文档(包括自定义Svelte Transitions)时动画组件的方法。

本文探讨了Envato Market上可用的PHP表单构建器脚本,比较了其功能,灵活性和设计。 在研究特定选项之前,让我们了解PHP形式构建器是什么以及为什么要使用一个。 PHP形式


热AI工具

Undresser.AI Undress
人工智能驱动的应用程序,用于创建逼真的裸体照片

AI Clothes Remover
用于从照片中去除衣服的在线人工智能工具。

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

AI Hentai Generator
免费生成ai无尽的。

热门文章

热工具

适用于 Eclipse 的 SAP NetWeaver 服务器适配器
将Eclipse与SAP NetWeaver应用服务器集成。

MinGW - 适用于 Windows 的极简 GNU
这个项目正在迁移到osdn.net/projects/mingw的过程中,你可以继续在那里关注我们。MinGW:GNU编译器集合(GCC)的本地Windows移植版本,可自由分发的导入库和用于构建本地Windows应用程序的头文件;包括对MSVC运行时的扩展,以支持C99功能。MinGW的所有软件都可以在64位Windows平台上运行。

VSCode Windows 64位 下载
微软推出的免费、功能强大的一款IDE编辑器

螳螂BT
Mantis是一个易于部署的基于Web的缺陷跟踪工具,用于帮助产品缺陷跟踪。它需要PHP、MySQL和一个Web服务器。请查看我们的演示和托管服务。

mPDF
mPDF是一个PHP库,可以从UTF-8编码的HTML生成PDF文件。原作者Ian Back编写mPDF以从他的网站上“即时”输出PDF文件,并处理不同的语言。与原始脚本如HTML2FPDF相比,它的速度较慢,并且在使用Unicode字体时生成的文件较大,但支持CSS样式等,并进行了大量增强。支持几乎所有语言,包括RTL(阿拉伯语和希伯来语)和CJK(中日韩)。支持嵌套的块级元素(如P、DIV),