
vue3 onload 方法不执行的原因
在 Vue3 中,使用 onload 方法监听页面加载完成可能会遇到不执行的情况。这是因为 onload 事件只会在初始化时执行一次,即在 HTML 文档加载完成后。
场景详情及问题
以下是一个测试代码示例:
window.onload = () => {
console.log('loaded')
}
onMounted(() => {
console.log('mounted')
nextTick(() => {
console.log('nextTick');
})
})在这个示例中,mounted 和 nextTick 都会在组件挂载时执行,但 onload 不会执行。这导致了一个问题:当需要创建一个加载中状态并需要在页面完全加载后关闭该状态时,使用 onload 无法满足需求,因为在背景图完成渲染之前 onload 就已经执行了。
立即学习“前端免费学习笔记(深入)”;
思乐微信商城微分销系统是以.net+access/mssql进行开发的微信分销系统。基于微信朋友圈的传播,是打造以分销商为中心的全新微信分销体验。让粉丝实时有效的获取朋友圈流量并快速分享购买分佣。因为是基于微信,所以要在微信上体验才更好。关注我们的微信核心功能:1、自动提示用户关注微信,解决一般程序无关注微信公众号的过程2、只要通过链接进一次,不过好久注册,什么方面注册,只要是用微信注册的,都会算
解决方案
为了解决这个问题,建议使用 Vue 组件中的 $nextTick 函数。$nextTick 确保在组件挂载完成后执行回调,从而避免在 onload 事件触发前执行。
改进的代码示例
onMounted(() => {
nextTick(() => {
console.log('页面加载完成')
// 关闭加载中状态
})
})通过使用 $nextTick,可以确保在组件挂载并完成页面渲染后执行代码,从而满足页面加载完成后关闭加载中状态的需求。









