CSS 过渡不适用于最初隐藏的元素
当元素最初使用 CSS 的显示隐藏时:无,任何应用于该元素的 CSS 过渡当其可见性改变时不会触发。这是因为 CSS 过渡依赖于元素的初始计算样式,对于隐藏元素,该样式将为空。
CSSOM 与 DOM
要了解此行为,区分 CSS 对象模型 (CSSOM) 和文档对象模型 (DOM) 很重要。 DOM 表示 HTML 文档的层次结构,而 CSSOM 包含每个元素的计算样式。
回流和绘制
当元素的可见性为更改后,浏览器需要更新 CSSOM 并重排页面以反映更改。回流会根据元素的 CSS 规则重新计算元素的计算样式和位置。绘制是在屏幕上渲染页面的过程,发生在重排之后。
过渡启动
CSS 过渡通过在元素的初始计算样式与其元素之间进行插值来工作最终风格。当元素最初隐藏时,其计算样式将为空,因此转换算法无法创建初始状态。
解决方案:强制回流
来触发转换对于隐藏元素,需要在更改其可见性后强制回流。这可以使用 requestAnimationFrame API 来实现,该 API 在浏览器绘制页面之前执行回调。
通过使用 requestAnimationFrame,可以在浏览器更新 CSSOM 后应用 CSS 过渡,从而允许过渡正确启动。
示例
这是代码的修改版本使用 requestAnimationFrame 强制回流:
$('button').on('click', function() { $('.b').show(); requestAnimationFrame(() => { document.body.offsetHeight; // Force a reflow $('.b').css('right', '80%'); // Trigger the transition $('.a').css('right', '80%'); }); });
总之,CSS 过渡不适用于最初隐藏的元素,因为 CSSOM 不包含它们的初始计算样式。要触发转换,需要在更改元素的可见性后强制回流。
以上是为什么 CSS 过渡对最初隐藏的元素不起作用?的详细内容。更多信息请关注PHP中文网其他相关文章!

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

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

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


热AI工具

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

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

Undress AI Tool
免费脱衣服图片

Clothoff.io
AI脱衣机

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

热门文章

热工具

禅工作室 13.0.1
功能强大的PHP集成开发环境

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

Dreamweaver CS6
视觉化网页开发工具

安全考试浏览器
Safe Exam Browser是一个安全的浏览器环境,用于安全地进行在线考试。该软件将任何计算机变成一个安全的工作站。它控制对任何实用工具的访问,并防止学生使用未经授权的资源。

PhpStorm Mac 版本
最新(2018.2.1 )专业的PHP集成开发工具