- 39
- 0
1,vue使用了keepalive,在mounted里面添加了window.addEventListener("scroll",function(){})
2,首次进入组件,function事件被出发,再次进入,function事件没被触发,怎么解决?
- 共 0 条
- 全部回答
-
淚已干丶心已碎 普通会员 1楼
在 Vue 中使用 keep-alive 组件后,由于被缓存的组件并不会执行销毁和重新创建的过程,因此在组件再次激活时,滚动位置可能不会自动恢复。
如果你需要监听滚动事件并处理这个问题,可以尝试以下方法:
- 在activated 钩子中设置滚动位置。当组件被 keep-alive 缓存并再次激活时,会触发 activated 钩子:
javascript export default { data() { return { lastScrollTop: 0 // 记录上次滚动位置 }; }, mounted() { this.lastScrollTop = window.pageYOffset || document.documentElement.scrollTop; // 初始化滚动位置 window.addEventListener('scroll', this.handleScroll); }, beforeDestroy() { window.removeEventListener('scroll', this.handleScroll); // 组件销毁时移除监听 }, activated() { document.documentElement.scrollTop = this.lastScrollTop; // 恢复滚动位置 window.scrollTo(0, this.lastScrollTop); }, methods: { handleScroll() { this.lastScrollTop = window.pageYOffset || document.documentElement.scrollTop; // 实时更新滚动位置 } } };- 如果是页面内部某个区域(如:div)的滚动,将
window对象替换为该元素即可。
这样,在每次组件被激活时,都会恢复到之前离开时的滚动位置。
- 扫一扫访问手机版
回答动态

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器更新之后。服务器里面有部分玩家要重新创建角色是怎么回事啊?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题函数计算不同地域的是不能用内网吧?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题ARMS可以创建多个应用嘛?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题在ARMS如何申请加入公测呀?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题前端小程序接入这个arms具体是如何接入监控的,这个init方法在哪里进行添加?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器刚到期,是不是就不能再导出存档了呢?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器的游戏版本不兼容 尝试更新怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器服务器升级以后 就链接不上了,怎么办?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器转移以后服务器进不去了,怎么解决?预计能赚取 0积分收益

- 神奇的四哥:发布了悬赏问题阿里云幻兽帕鲁服务器修改参数后游戏进入不了,是什么情况?预计能赚取 0积分收益
- 回到顶部
- 回到顶部
