找回密码
 立即注册
首页 业界区 业界 不定高元素动画实现方案(中)

不定高元素动画实现方案(中)

简千叶 2025-9-21 09:58:28
前情

最近小程序接了一个需求,需要实现一个列表,列表可展开收起,展开收起需要有一个动画效果,而列表个数不定且每项内容高度也不固定,所以是一个不定高的收起展开效果,于是特意抽时间尝试了一些动画实现方案,特此记录
通过scale来实现

通过css3的transform:scaleY()来实现,就是设置内容的缩放从0到1,这里有一个小技巧,默认缩放是相对于元素的正中心,这里要设置相对于顶边来实现动画,通过transform-origin来修改变换中心点
关键代码如下:
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4.   <meta charset="utf-8">
  5.   <meta name="viewport" content="width=device-width">
  6.   <title>JS Bin</title>
  7. </head>
  8. <body>
  9.   
  10.    
  11.       header
  12.       <ul >
  13.         <li>scale111111111</li>
  14.         <li>scale2222222222</li>
  15.         <li>scale333333333</li>
  16.         <li>scale444444444</li>
  17.       </ul>
  18.    
  19.   
  20. </body>
  21. </html>
复制代码
  1. *{
  2.   margin: 0;
  3.   padding: 0;
  4. }
  5. .container{
  6.   width: 100%;
  7.   overflow: hidden;
  8. }
  9. .container:hover .list{
  10.   transform:scaleY(1)
  11. }
  12. .header{
  13.   width: 100%;
  14.   height: 48px;
  15.   background-color: #ccc;
  16.   display: flex;
  17.   align-items: center;
  18.   justify-content: center;
  19. }
  20. .list{
  21.   background-color: green;
  22.   transition: transform .4s;
  23.   transform:scaleY(0);
  24.   transform-origin:top center;
  25. }
复制代码
演示地址:https://jsbin.com/haxatotohi/edit?html,css,output
1.gif

注意:
此缩放属性兼容性已经非常好了,可以大但使用,但是它的动画方式相比修改亮度过渡不是特别好看,能看到内容明显的压扁缩放过程,但是它是性能最好的,因为修改transform不会引起回流,如果这种效果产品能接受,优先使用此种方式
2.png

通过interpolate-size来实现

interpolate-size属性允许在 CSS 中对尺寸相关的属性进行插值计算,从而实现过渡动画效果
可设置的属性有两个值:numeric-only(数字) 和 allow-keywords(关键字)
默认过渡动画只能针对数字,如果想对如auto/fill-content/max-content等关键字做动画就得把interpolate-size设置为allow-keywords
代码如下:
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4.   <meta charset="utf-8">
  5.   <meta name="viewport" content="width=device-width">
  6.   <title>JS Bin</title>
  7. </head>
  8. <body>
  9.   
  10.    
  11.       header
  12.       <ul >
  13.         <li>interpolate-size111111111</li>
  14.         <li>interpolate-size2222222222</li>
  15.         <li>interpolate-size333333333</li>
  16.         <li>interpolate-size444444444</li>
  17.       </ul>
  18.    
  19.   
  20. </body>
  21. </html>
复制代码
  1. *{
  2.   margin: 0;
  3.   padding: 0;
  4. }
  5. .container{
  6.   width: 100%;
  7.   height: 48px;
  8.   overflow: hidden;
  9.   transition:all .4s;
  10.   interpolate-size: allow-keywords
  11. }
  12. .container:hover{
  13.   height: auto;
  14. }
  15. .header{
  16.   width: 100%;
  17.   height: 48px;
  18.   background-color: #ccc;
  19.   display: flex;
  20.   align-items: center;
  21.   justify-content: center;
  22. }
  23. .list{
  24.   background-color: green;
  25. }
复制代码
演示地址:https://jsbin.com/nucinaleva/edit?html,css,output
3.gif

注意:
interpolate-size是新出的css就是为了解决关键词过渡动画的,但目前兼容性非常差,如果你是做后台管理项目或者electron桌面端项目可以用用,当然用在项目中也是无防的对于支持的就有过渡,不支持的就无过渡,这叫做优雅降级
4.png

通过calc-size来实现

calc-size() CSS function 允许您对固有值执行计算,例如 auto 、 fit-content 和 max-content ;常规 calc() 函数不支持此功能
calc-size() 返回值也可以是插值的 ,从而允许在 animations 和 transitions 中使用 size 关键字值。实际上,在属性值中包含 calc-size() 会自动将 interpolate-size: allow-keywords 应用于选择
关键代码如下:
  1. <!DOCTYPE html>
  2. <html>
  3. <head>
  4.   <meta charset="utf-8">
  5.   <meta name="viewport" content="width=device-width">
  6.   <title>JS Bin</title>
  7. </head>
  8. <body>
  9.   
  10.    
  11.       header
  12.       <ul >
  13.         <li>calc-size111111111</li>
  14.         <li>calc-size2222222222</li>
  15.         <li>calc-size333333333</li>
  16.         <li>calc-size444444444</li>
  17.       </ul>
  18.    
  19.   
  20. </body>
  21. </html>
复制代码
  1. *{
  2.   margin: 0;
  3.   padding: 0;
  4. }
  5. .container{
  6.   width: 100%;
  7.   height: 48px;
  8.   overflow: hidden;
  9.   transition:all .4s;
  10. }
  11. .container:hover{
  12.   height: calc-size(auto, size);
  13. }
  14. .header{
  15.   width: 100%;
  16.   height: 48px;
  17.   background-color: #ccc;
  18.   display: flex;
  19.   align-items: center;
  20.   justify-content: center;
  21. }
  22. .list{
  23.   background-color: green;
  24. }
复制代码
演示地址:https://jsbin.com/gedezajoni/edit?html,css,output
5.gif

注意:
兼容性有些差,如果你是做后台管理项目或者electron桌面端项目可以用用,当然用在项目中也是无防的对于支持的就有过渡,不支持的就无过渡,这叫做优雅降级
6.png

小结

对于做技术的我们,每天都是提出问题解决问题的一个过程,过程中会尝试各种方案,因为解决问题的方案千千万,此篇文章记录了实现不定高内容过渡效果的另外三种实现方式,怕篇幅太长,此文暂时写这么多,下篇继续……

来源:程序园用户自行投稿发布,如果侵权,请联系站长删除
免责声明:如果侵犯了您的权益,请联系站长,我们会及时删除侵权内容,谢谢合作!

相关推荐

您需要登录后才可以回帖 登录 | 立即注册