搜索
首页web前端css教程为什么 CSS 过渡对最初隐藏的元素不起作用?

Why Doesn't CSS Transition Work on Initially Hidden Elements?

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中文网其他相关文章!

声明
本文内容由网友自发贡献,版权归原作者所有,本站不承担相应法律责任。如您发现有涉嫌抄袭侵权的内容,请联系admin@php.cn
什么是CSS网格?什么是CSS网格?Apr 30, 2025 pm 03:21 PM

CSS网格是创建复杂,响应式Web布局的强大工具。它简化了设计,提高可访问性并提供了比旧方法更多的控制权。

什么是CSS Flexbox?什么是CSS Flexbox?Apr 30, 2025 pm 03:20 PM

文章讨论了CSS FlexBox,这是一种布局方法,用于有效地对齐和分布响应设计中的空间。它说明了FlexBox用法,将其与CSS网格进行了比较,并详细浏览了浏览器支持。

我们如何使用CSS使网站迅速响应?我们如何使用CSS使网站迅速响应?Apr 30, 2025 pm 03:19 PM

本文讨论了使用CSS创建响应网站的技术,包括视口元标签,灵活的网格,流体媒体,媒体查询和相对单元。它还涵盖了使用CSS网格和Flexbox一起使用,并推荐CSS框架

CSS盒装属性有什么作用?CSS盒装属性有什么作用?Apr 30, 2025 pm 03:18 PM

本文讨论了CSS盒装属性,该属性控制了元素维度的计算方式。它解释了诸如Content-Box,Border-Box和Padding-Box之类的值,以及它们对布局设计和形式对齐的影响。

我们如何使用CSS动画?我们如何使用CSS动画?Apr 30, 2025 pm 03:17 PM

文章讨论使用CSS,关键属性并与JavaScript结合创建动画。主要问题是浏览器兼容性。

我们可以使用CSS向我们的项目添加3D转换吗?我们可以使用CSS向我们的项目添加3D转换吗?Apr 30, 2025 pm 03:16 PM

文章讨论了Web项目的3D转换,关键属性,浏览器兼容性和性能注意事项的讨论。(角色计数:159)

我们如何在CSS中添加梯度?我们如何在CSS中添加梯度?Apr 30, 2025 pm 03:15 PM

文章讨论了使用CSS梯度(线性,径向,重复)来增强网站视觉效果,添加深度,焦点和现代美学。

CSS中的伪元素是什么?CSS中的伪元素是什么?Apr 30, 2025 pm 03:14 PM

文章讨论了CSS中的伪元素,它们在增强HTML样式方面的使用以及与伪级的差异。提供实用的例子。

See all articles

热AI工具

Undresser.AI Undress

Undresser.AI Undress

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

AI Clothes Remover

AI Clothes Remover

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

Undress AI Tool

Undress AI Tool

免费脱衣服图片

Clothoff.io

Clothoff.io

AI脱衣机

Video Face Swap

Video Face Swap

使用我们完全免费的人工智能换脸工具轻松在任何视频中换脸!

热工具

mPDF

mPDF

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

禅工作室 13.0.1

禅工作室 13.0.1

功能强大的PHP集成开发环境

SublimeText3 Mac版

SublimeText3 Mac版

神级代码编辑软件(SublimeText3)

SublimeText3 Linux新版

SublimeText3 Linux新版

SublimeText3 Linux最新版

PhpStorm Mac 版本

PhpStorm Mac 版本

最新(2018.2.1 )专业的PHP集成开发工具