requestAnimationFrame导致的dom元素读取为null的bug

作者在Vue3项目中遇到DOMref为null的错误,发现错误发生在requestAnimationFrame的回调中。问题源于未在beforeUnmount中取消动画。解决方案是确保在组件卸载时使用cancelAnimationFrame。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

打工日志:requestAnimationFrame导致的ref读取dom元素为null

今天遇到一个bug,自己写的vue3项目。当我第一次运行时完美,不会报错。但是当我修改代码后,保存。代码就会报错,都是报dom的ref为null之类的。但是页面渲染没有问题,只不过报错也会把页面卡死。

在我的逐一排查下,发现dom为null的报错都是在一个requestAnimationFrame的回调动画函数里报错的。于是我猜想应该是我没有在beforeUnmount中将requestAnimationFrame卸载。导致重新保存代码时之前的requestAnimationFrame仍然存在并且在调用保存代码前的ref,而因为代码已经保存刷新,因此之前的ref的对象就变成了null导致了报错。

因此解决办法就是在beforeUnMount中将requestAnimationFrame用cancelAnimationFrame去卸载即可,事实上也确实解决了

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值