31.高度过渡 & 带粘性分区标题的列表

高度过渡

当元素的高度未知时,将元素的高度从 0 过渡到 auto

  • 使用 transition 指定 max-height 的变化应该被过渡。

  • 使用 overflow: hidden 防止隐藏元素的内容溢出其容器。

  • 使用 max-height 指定 0 的初始高度。

  • 使用 :hover 伪类将 max-height 更改为由 JavaScript 设置的 --max-height 变量的值。

  • 使用 Element.scrollHeightCSSStyleDeclaration.setProperty()--max-height 的值设置为元素的当前高度。 💬 注意 在每个动画帧上导致重排,如果在过渡高度的元素下面有大量元素,会产生延迟。

<div class="trigger">
  悬停在我上面查看高度过渡。
  <div class="el">附加内容</div>
</div>
.el {
  transition: max-height 0.3s;
  overflow: hidden;
  max-height: 0;
}

.trigger:hover > .el {
  max-height: var(--max-height);
}
let el = document.querySelector('.el');
let height = el.scrollHeight;
el.style.setProperty('--max-height', height + 'px');

fd8338a2d58790d4d4dea9ec04df5a8b.gif

这个技巧创建了一个平滑的高度过渡效果,当用户悬停在触发器元素上时,会展开一个隐藏的元素。这在你想要显示额外的内容,但又不想它一直占用页面空间的情况下特别有用。

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

@大迁世界

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值