CSS技巧:从高度0过渡到自动高度

news/2024/7/24 13:17:09 标签: css, 前端, 前端框架

本文翻译自 CSS trick: transition from height 0 to auto!,作者:Francesco Vetere, 略有删改。

如果你在CSS上花了足够长的时间,很可能你曾尝试过从height:0auto的平滑过渡。。。却发现它不起作用!😢

️幸运的是现在有一个解决这个问题的方法:使用CSS Grid布局可以解决这个问题,而且代码简单,运行的很完美。

让我们从一个实际的例子开始。我做了这个简单的手风琴效果:

它的HTML非常简单:

<div class="accordion">
  <div class="accordion-title">Hover me!</div>
  <div class="accordion-body">
    <div>
      <p>Lorem ipsum ...</p>
    </div>
  </div>
</div>

如果你将鼠标悬停在手风琴上,你会注意到有一个下拉菜单出现。效果不错,但如果我们想要添加一个漂亮的平滑过渡效果呢?

实际上,我在前面演示的效果中的CSS代码里面对height属性上添加了一个小过渡:

css">.accordion-body {
  height: 0;
  transition: 500ms height ease;
}

.accordion:hover .accordion-body {
  height: auto;
}

不幸的是,从height: 0转换到height: auto不起作用,正如我之前所说的,是CSS不可能实现的。

🤔如何解决这个问题?

第一个解决方案是将height属性设置为一个固定的数字,而不是auto

这是可行的,但它不是一个很好的方法:为了计算这个固定的数字,我们必须求助于JavaScript,以计算我们的.accordion-body实际上有多高。这不是我们的目标。

💡事实上,为什么不直接用max-height呢?

css">.accordion-body {
  max-height: 0;
  transition: 500ms max-height ease;
}

.accordion:hover .accordion-body {
  max-height: 200px;
}

由于我们为max-height定义了一个固定值,浏览器现在可以正确地执行转换。

😕唯一的问题是,由于我们为max-height定义了一个固定值,现在内容可能会溢出。

如果你确信你的内容永远不会达到一定的高度…那么用这个方法完全可以!只要为max-height使用一个合适的值,就可以了。

但是要注意,max-height的值越高,过渡就越奇怪。

🤔我们能做得更好吗?我们可以避免任何固定的height/max-height值吗?

🎉 CSS Grid 来拯救

我们实际上可以使用一个简单的技巧,就是用一个网格项制作一个CSS网格。

然后真正要做的就是把我们的grid-template-rows0fr过渡到1fr。这样我们的网格项将从0过渡到它的“自然”高度。

css">.accordion-body {
  display: grid; 
  grid-template-rows: 0fr;
  transition: 250ms grid-template-rows ease;
}

.accordion:hover .accordion-body {
  grid-template-rows: 1fr;
}

.accordion-body > div {
  overflow: hidden;
}

感觉干净多了。没有固定的高度,没有花哨的东西,我们的手风琴效果依然按预期工作。好极了!😄

这个解决方案的一个警告是需要设置一个overflow: hidden.accordion-body的内部div,以便使这个方案正常工作。在我看来这一点额外的CSS是完全值得的,你可以在评论中说出你对它的看法!

🎁 额外提示

这个技巧之所以有效,是因为grid-template-rows的可动性,这是一些浏览器最近才有的功能。在我写这篇文章的时候,所有主流的浏览器都支持这个特性,但是如果你想在生产代码中使用这个特性,一定要先检查兼容性!


看完本文如果觉得有用,记得点个赞支持,收藏起来说不定哪天就用上啦~

专注前端开发,分享前端相关技术干货,公众号:南城大前端(ID: nanchengfe)


http://www.niftyadmin.cn/n/5230500.html

相关文章

Linux中的Swap和Mem:有什么区别?

在Linux系统中&#xff0c;内存管理是操作系统的重要部分。在内存管理方面&#xff0c;Swap和Mem是两种不同的内存类型&#xff0c;它们在Linux系统中发挥着不同的作用。本文将解释Swap和Mem的区别以及它们在Linux系统中的作用。 一、Swap Swap是Linux系统中的交换分区&#…

【网络安全 --- 文件包含漏洞】文件包含漏洞详解

一&#xff0c;环境搭建及工具下载 1-1 VMware 虚拟机安装 【网络安全 --- 工具安装】VMware 16.0 详细安装过程&#xff08;提供资源&#xff09;-CSDN博客文章浏览阅读272次&#xff0c;点赞9次&#xff0c;收藏2次。【网络安全 --- 工具安装】VMware 16.0 详细安装过程&am…

三十二、微服务保护

目录 一、雪崩问题 介绍&#xff1a; 解决方案&#xff1a; 1、超时处理 2、舱壁模式 3、熔断降级 4、流量控制 总结&#xff1a; 二、Sentinel与Hystrix的对比 三、认识Sentinel&#xff08;微服务与控制台进行整合&#xff09; 特点&#xff1a; 1、启动sentinel…

Python基础:标准库概览

1. 标准库介绍 Python 标准库非常庞大&#xff0c;所提供的组件涉及范围十分广泛&#xff0c;正如以下内容目录所显示的。这个库包含了多个内置模块 (以 C 编写)&#xff0c;Python 程序员必须依靠它们来实现系统级功能&#xff0c;例如文件 I/O&#xff0c;此外还有大量以 Pyt…

【SparkSQL】SparkSQL函数定义(重点:定义UDF函数、使用窗口函数)

【大家好&#xff0c;我是爱干饭的猿&#xff0c;本文重点介绍SparkSQL 定义UDF函数、SparkSQL 使用窗口函数。 后续会继续分享其他重要知识点总结&#xff0c;如果喜欢这篇文章&#xff0c;点个赞&#x1f44d;&#xff0c;关注一下吧】 上一篇文章&#xff1a;《【SparkSQL…

android https 证书过期

有的时候 我们android https 证书过期 &#xff0c;或者使用明文等方式去访问服务器 可能会碰到类似的 问题 &#xff1a; javax.net.ssl.SSLHandshakeException: Chain validation failed java.security.cert.CertPathValidatorException: Response is unreliable: its validi…

jetson nano网络配置(有线、无线、USB)

文章目录 网络配置&#xff08;有线、无线&#xff09;1.前言1.1 RJ451.2 无线网卡 2.有线连接2.1 连接方法2.2 检测连接状态 3.无线3.1 网卡安装步骤3.2 连接方法3.3 检测连接状态 4.通过USB 线控制Jetson Nano4.1 连接4.2 查看设备4.3 查看设备IP 网络配置&#xff08;有线、…

力扣:182. 查找重复的电子邮箱(Python3)

题目&#xff1a; 表: Person ---------------------- | Column Name | Type | ---------------------- | id | int | | email | varchar | ---------------------- id 是该表的主键&#xff08;具有唯一值的列&#xff09;。 此表的每一行都包含一封电子…