
在Vue3中动态调整CSS动画,特别是@keyframes属性,并非直接操作样式表那么简单。本文将详细讲解如何利用Vue3的ref、onMounted和CSSOM API来动态获取DOM列表高度并应用于@keyframes动画。
问题:开发者需要根据后端返回的动态数据列表高度来调整动画滚动效果,而预设动画高度是固定的。直接操作style.sheet无法访问@keyframes规则,因为这种方法无法直接操作CSS规则。
解决方案:利用Vue3组件生命周期和CSSOM API动态修改样式。在onMounted钩子函数中获取DOM元素高度,然后使用CSSOM API遍历样式表,找到对应的@keyframes规则,并修改关键帧的transform属性。
代码示例:
功能列表:底层程序与前台页面分离的效果,对页面的修改无需改动任何程序代码。完善的标签系统,支持自定义标签,公用标签,快捷标签,动态标签,静态标签等等,支持标签内的vbs语法,原则上运用这些标签可以制作出任何想要的页面效果。兼容原来的栏目系统,可以很方便的插入一个栏目或者一个栏目组到页面的任何位置。底层模版解析程序具有非常高的效率,稳定性和容错性,即使模版中有错误的标签也不会影响页面的显示。所有的标
立即学习“前端免费学习笔记(深入)”;
代码解释:
-
onMounted钩子函数在组件挂载后执行,获取list元素的高度。 -
document.styleSheets[0]获取第一个样式表(需根据实际情况调整索引)。 - 循环遍历样式表规则,找到名为
scroll-animation的@keyframes规则。 - 循环遍历关键帧,找到
100%关键帧,并修改其transform属性的translateY值,使其与动态获取的listHeight相对应。
注意:document.styleSheets[0]假设@keyframes规则在第一个样式表中,实际应用中可能需要调整索引。 为了更稳健的代码,建议使用更精确的样式表选择方法,例如通过document.querySelector('style')选择特定的标签,或者使用更高级的CSS选择器来定位目标样式规则。 此外,考虑错误处理,例如当没有找到@keyframes规则的情况。









