Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

青灯夜游
Lepaskan: 2023-02-06 20:10:35
ke hadapan
2648 orang telah melayarinya

Bagaimanakah CSS boleh menjadikan ketinggian automatik menyokong animasi peralihan dengan sempurna? Artikel berikut akan bercakap dengan anda tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS. Saya harap ia akan membantu anda!

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

Seperti yang kita semua tahu, ketinggian tidak akan mencetuskan animasi peralihan auto apabila ditetapkan kepada kata kunci transition Berikut ialah kod pseudo

div{
  height: 0;
  transition: 1s
}
.wrap:hover div{
  height: auto
}
Salin selepas log masuk

Kesannya adalah seperti berikut

Kapture 2023-01-31 at 19.19.59.gif

Jika anda ingin mempunyai animasi peralihan semasa mengembangkan, contohnya,

Kapture 2023-01-31 at 19.21.02.gif

Biasanya dapatkannya secara dinamik dengan bantuan JS Ketinggian elemen (agak menyusahkan, anda perlu tahu ketinggian selepas rendering). Malah, CSS juga mempunyai penyelesaian yang bijak menggunakan max-height untuk menyesuaikan diri dengan ketinggian dinamik Berikut ialah kod pseudo [Pembelajaran yang disyorkan: tutorial video css]

div{
  max-height: 0;
  transition: 1s
}
.wrap :hover div{
  max-height: 800px /*大概的值,需要超过元素高度*/
}
Salin selepas log masuk

Jika. anda berminat, anda boleh rujuk Artikel ini: Helah CSS: animasi peralihan ketinggian dinamik , tetapi terdapat had Lebih besar perbezaan ketinggian, lebih teruk kesan peralihan elemen hanya 100px Jika max-height ialah 800px, maka hanya yang pertama 1/8 mempunyai animasi, seperti ini

Kapture 2023-01-31 at 19.36.12.gif

Jadi, adakah cara yang lebih baik untuk menyelesaikan masalah ini?

Sudah tentu ada, kali ini saya akan memperkenalkan cara baharu untuk mencapai peralihan ketinggian dinamik, mari kita lihat

1 Unit fr dalam susun atur grid

grid Terdapat unit fr serba baharu dalam reka letak yang mentakrifkan faktor keanjalan saiz trek grid. gridSusun aturnya agak rumit dan tidak dapat dijelaskan dengan jelas dalam beberapa perkataan Mereka yang berminat boleh merujuk kepada grid tutorial berkaitan, seperti

Berikut ialah pengenalan ringkas kepada tujuan unit fr, sebagai contoh, terdapat susun atur sedemikian

<div class="grid">
  <span class="item">1fr</span>
  <span class="item">1fr</span>
  <span class="item">1fr</span>
</div>
Salin selepas log masuk

Gaya utama adalah seperti berikut

.grid{
  display: grid;
  grid-template-columns: repeat(3, 1fr);
}
Salin selepas log masuk

untuk mendapatkan kesan sedemikian

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

repeat(3, 1fr) di sini sebenarnya adalah singkatan daripada 1fr 1fr 1fr Menunjukkan 3 membahagikan ruang yang tinggal. Ia juga boleh ditetapkan dalam arah menegak

.grid{
  grid-template-rows: repeat(3, 1fr);
}
Salin selepas log masuk

dengan kesan berikut

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

Anda juga boleh menukar nisbah pengedaran masing-masing

.grid{
  grid-template-rows: 1fr 2fr 1fr;
}
Salin selepas log masuk
Salin selepas log masuk

kesan Seperti berikut

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

Sekarang mari kita lihat kes khas, anda juga boleh menetapkan nisbah pengedaran kepada 0fr

.grid{
  grid-template-rows: 0fr 2fr 1fr;
}
Salin selepas log masuk

kesan Seperti berikut:

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

Bukankah ia sedikit pelik Mengapa 0fr dan 1fr menduduki bahagian yang sama?

Malah, ini ditentukan oleh peraturan saiz minimum grid Ketinggian minimum pada masa ini ialah min-content, yang ditentukan oleh teks dalaman. Jika tiada teks, 0fr secara semula jadi tidak mengambil ruang Berikut ialah kesan selepas mengalih keluar teks

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

Jika anda mahu mengekalkan teks dan. tidak mengambil ruang Apa yang perlu dilakukan? Anda boleh terus menetapkan saiz minimum secara manual

span{
  min-height: 0
}
Salin selepas log masuk

Cara ini0fr tidak akan mengambil ruang

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

Anda juga boleh menggunakan over-hide untuk sembunyikan sepenuhnya sub-kandungan

.grid{
  overflow: hidden;
}
span{
  min-height: 0
}
Salin selepas log masuk

Kesannya adalah seperti berikut

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

应该还是比较容易理解吧,那么和动画有啥关系呢?接着往下看

二、grid 中的过渡动画

有同学可能纳闷了,为啥要折腾这个0fr呢?下面就来揭晓

如果重新设置1fr,子内容又会重新出现

.grid{
  grid-template-rows: 1fr 2fr 1fr;
}
Salin selepas log masuk
Salin selepas log masuk

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

下面重点来了,grid中的fr单位也是支持过渡动画的(0fr=>1fr )

.grid{
  grid-template-rows: 1fr 2fr 1fr;  
  transition: .3s
}
Salin selepas log masuk

效果如下

Kapture 2023-01-30 at 20.14.59.gif

由于高度是由内部文本撑开的,也就是高度不确定,而0fr1fr的过渡变化,相当于实现了 高度不固定的过渡动画

进一步精简一下,可以实现这样的效果

Kapture 2023-01-31 at 10.40.33.gif

这就是高度不固定动画的雏形了,换个文本多一点也完美支持

Kapture 2023-01-31 at 19.48.37.gif

完整 demo可以查看以下任意链接

三、自适应高度动画的两个实例

现在根据上面的原理来实现两个实例。

首先来看文章最开头的示例,HTML 结构是这样的

<div class="wrap">
  <button class="trigger">鼠标放上来试试</button>
  <div class="grid">
    <div><p>欢迎关注前端侦探,这里有一些有趣的、你可能不知道的HTML、CSS、JS小技巧技巧,比如这篇文章,如何让 auto height 支持过渡动画?一起看看吧</p></div>
  </div>
</div>
Salin selepas log masuk

简单修饰一下,应该比较容易,可以得到这样的效果

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

然后通过上面的技巧将下拉内容隐藏起来,关键样式如下

.grid{
  display: grid;
  grid-template-rows: 0fr;
  transition: .3s;
  overflow: hidden;
}
.grid>div{
  min-height: 0;
}
Salin selepas log masuk

然后通过hover触发显示,也就是改变grid-template-rows

.wrap:hover .grid{
  grid-template-rows: 1fr;
}
Salin selepas log masuk

这样就实现了不定高度的过渡动画

Kapture 2023-01-31 at 20.02.28.gif

完整 demo可以查看以下任意链接

如果仅仅是悬浮窗口,由于是绝对定位,不会影响其他布局,其实是可以用transform scale 进行缩放的,再来看另外一个更加实用的例子,常见的菜单展开收起效果,就像这样

Kapture 2023-01-30 at 16.35.21.gif

可以看到,在展开的同时,下方的元素也被挤压下去了,这样效果更加自然,也是transform实现不了的,这里的切换是通过:checked实现的,关键代码如下

<input hidden type="checkbox" id="s1" checked />
<label for="s1">工作台</label>
<div class="sub">
  <ul>
    <li>项目列表</li>
    <li>数据配置器</li>
  </ul>
</div>
Salin selepas log masuk
ul{
  min-height: 0;
}
.sub {
  display: grid;
  grid-template-rows: 0fr;
  transition: 0.3s;
  overflow: hidden;
}
:checked ~ .sub {
  grid-template-rows: 1fr;
}
Salin selepas log masuk

完整 demo可以查看以下任意链接

四、注意事项和一些局限性

下面是一些注意事项。

这里的动画源于grid-template-rows的变化,也就是0fr1fr

**注意,注意,注意,**这里的0fr必须是0fr,不能是0或者0px,必须是fr单位

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

下面是改为40px的效果(动画丢失)

Kapture 2023-02-02 at 18.44.50.gif

再者,0fr也不支持calc计算,直接被认为不合法

Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS

这意味着,例如你希望默认有一个固定高度(非0),然后展开到自适应高度,这种方法是无法实现过渡动画的,略遗憾?

五、最后总结一下

最后再来回顾一下实现关键过程

.grid{
  display: grid;
  grid-template-rows: 0fr;
  transition: .3s;
  overflow: hidden;
}
.grid>div{
  min-height: 0;
}
.wrap:hover .grid{
  grid-template-rows: 1fr;
}
Salin selepas log masuk

主要是利用了grid弹性布局可以实现过渡动画的特点,下面总结一些实现要点

  • 高度在设置成auto关键词时不会触发transition过渡动画

  • grid布局中的fr单位,可以用于定义网格轨道大小的弹性系数

  • grid布局的尺寸计算规则是由最小高度决定的,默认是min-content,也就是由内部文本决定的,可以通过手动设置min-height来实现0fr

  • grid布局也支持过渡动画(0fr=>1fr ),这样就实现高度不固定的过渡动画

  • 要使过渡动画生效,必须是fr单位,其他单位不行,也不能通过calc计算

  • 这种方法只能实现初始高度为0自适应高度的过渡变化,略微遗憾

(学习视频分享:web前端

Atas ialah kandungan terperinci Mari kita bincangkan tentang cara membuat animasi peralihan sokongan ketinggian automatik dalam CSS. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Label berkaitan:
sumber:juejin.cn
Kenyataan Laman Web ini
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn
Tutorial Popular
Lagi>
Muat turun terkini
Lagi>
kesan web
Kod sumber laman web
Bahan laman web
Templat hujung hadapan