位置: IT常识 - 正文

记录vue-router跳转页面空白问题(vue-router跳转)

编辑:rootadmin
记录vue-router跳转页面空白问题

推荐整理分享记录vue-router跳转页面空白问题(vue-router跳转),希望有所帮助,仅作参考,欢迎阅读内容。

文章相关热门搜索词:vue$router,vuerouter跳转原理,vue route跳转,vuerouter跳转原理,vue的router跳转,vuerouter跳转原理,vue的router跳转,vuerouter跳转原理,内容如对您有帮助,希望把文章链接给更多的朋友!

vue- router里踩坑太多,全记录在这里,持续更新

1.父组件中要配置路由出口 RouterView<template> <div class="main"> <router-view></router-view> </div></template>2.检查路由表配置子路由路径 不要加 /routes配置项名称 不要写成 routeexport default new Router({ routes: [ // 1.这里不要写成route,注意是复数! { path: '/', name: 'HelloWorld', component: HelloWorld }, path: '/hi', component: Hi, children: [ // 2.子路由路径 不要加 / {path: '/hi2', component: Hi2}, // 错误写法 {path: 'hi3', component: Hi3}。// 正确写法 ] } ]})

component配置项

component配置项名称 不要写成 components中间路由跳转重定向,也要配置 component

layout 这个路由跳转后重定向到 ‘/user/manage’,虽然这个路由被重定向,但是组件也要注册,否则它的子组件 userManage 无法挂载。

错误写法:

{ path: '/user', name: 'user', redirect: '/user/manage', // 此路由跳转后重定向到 '/user/manage' children: [ { path: '/user/manage', name: 'userManage', component: () => import('@/views/user-manage'), } }记录vue-router跳转页面空白问题(vue-router跳转)

正确写法:

{ path: '/user', name: 'user', component: () => import('@/views/layout'), // 虽然这个路由被重定向,但是不要忘记 注册组件 redirect: '/user/manage', // 此路由跳转后重定向到 '/user/manage' children: [ { path: '/user/manage', name: 'userManage', component: () => import('@/views/user-manage'), } }3. 使用 transition组件后页面空白确保路由组件中只有一个根节点

虽然 Vue3的 template 中可以使用多个根节点,但是<transition>中的组件渲染无法设置动画的非元素根节点,换句话,<transition>中的组件中只能有一个根节点。 多个根节点会导致 过渡无法生效,组件无法切换就出现了空白页。

<template><div>A1</div><div>A1</div></template><template><div> <div>A1</div> <div>A1</div> </div></template>

注意:注释标签也是节点,例如以下属于多个根节点

<template><!-- 注释 --><div> <div>A2</div> <div>A2</div></div></template>component组件添加key值

于Vue机制的原因,为了性能会使用同一个元素。也就是说你切换时并不会更换掉整个元素,而是替换掉该元素中的内容的值,以此来切换,所以在这里需要添加key。

为了保证key的唯一性,可以使用route的path来作为key。

<router-view v-slot="{ Component,route }"> <transition name="fade" mode="out-in"> <component :is="Component" :key="route.path"/> </transition></router-view>添加动态路由后页面空白

使用 addRoutes 动态添加路由跳转后页面刷新空白

原因:(动态)异步路由添加,执行addRoutes是需要时间的,刚刚addRoutes()就执行next()立刻访问被添加的路由,然而此时addRoutes()没有执行结束,因而找不到刚刚被添加的路由导致白屏。

解决方法:使用 next({…to}),从新访问一次路由 (结束当前导航,执行新的导航,再次执行beforeEach回调,直到 {…to}路径找到为止,才执行next()

// 全局 前置守卫router.beforeEach(async(to, from, next) => { document.title = getPageTitle(to.meta.title) const hasToken = getToken() if (hasToken) { if (to.path === '/login') { next({ path: '/' }) } else { const hasGetUserInfo = store.getters.name if (hasGetUserInfo) { next() } else { try { await store.dispatch('user/getInfo') // next(path) 中断当前导航,执行新的导航 // 如果 addRoutes 并未完成,路由守卫会一层一层的执行,直到 addRoutes 完成,找到对应的路由才会放行 next({ ...to, replace: true }) // 正确写法 // next() // 错误写法 } catch (error) { await store.dispatch('user/resetToken') Message.error(error || 'Has Error') next(`/login?redirect=${to.path}`) NProgress.done() } } } } else { ...})其他

如果以上操作排查不出原因,可能是组件自身无法渲染,与路由切换无关,不要注册路由组件,直接开一个页面渲染该组件,再排查原因

本文链接地址:https://www.jiuchutong.com/zhishi/285092.html 转载请保留说明!

上一篇:【NLP相关】AI绘画api集合(nlp图)

下一篇:西孟加拉邦的双角犀鸟,印度 (© Debapratim Saha/Minden Pictures)(什么是西孟加拉邦首府)

  • 出口货物适用什么税率
  • 进项税额转出要补所得税吗
  • 出库单上面的单位写谁的
  • 固定资产后续支出可以计入哪些费用
  • 企业所得税申报表A类
  • 赊销现金折扣分录
  • 税收的基本特点有
  • 普通发票扣税
  • 经营租用的设备有哪些
  • 银行卡收单机构外包业务管理指引
  • 代扣代缴的增值税怎么做账
  • 印花税的计税依据含税吗
  • 携税宝报税流程
  • 协方差cov计算公式展开
  • 长期待摊费用当月减少当月摊销吗
  • 交通卡定额发票购买
  • 企业合并以外
  • 个人报销汽油费会计分录
  • 企业利息收入如何做分录
  • 个人所得税申报截止时间
  • 电脑美式键盘怎么设置
  • 小企业会计准则会计科目表
  • 总资产净利率与权益乘数的关系
  • 定向增发利好还是利空股票
  • linux运行后出现乱码
  • 账务和申报表不一致
  • win10wifi老是自动断开怎么回事
  • PHP:mb_ereg_match()的用法_mbstring函数
  • php截取网页指定内容
  • 生活服务业内容
  • 咨询服务费需要什么附件
  • 资不抵债从资产负债表上怎么看出来
  • scworker.exe是病毒
  • PHP:imagetruecolortopalette()的用法_GD库图像处理函数
  • 公司支付保洁费可以付给个人吗
  • 企业安置残疾人如何残联备案
  • vue3.0项目
  • PHP:imagecolorexact()的用法_GD库图像处理函数
  • php数据库删除数据
  • vue2转vue3工具
  • php模板引擎类
  • php生成图片验证怎么弄
  • 有什么办法解决前进中的问题
  • vue脚手架配合springsecurity
  • 代扣代缴的企业所得税计入成本吗
  • 旅游景点的门票能做费用吗
  • 关于英语的25个单词
  • 标签显示内容怎么设置
  • 其他收益在报表列示的项目是
  • 企业所得税申报错误怎么更改
  • 企业所得税会计利润
  • sql2008用户sa登录失败
  • 费用报销冲抵借支
  • 出售投资性房地产的收入计入什么科目
  • 给员工购买的意外险可以税前扣除吗
  • 企业征地款会计分录
  • 金税盘税费减免分录
  • 坏账准备计入营业外支出什么明细
  • 最新商业会计科目做账
  • 企业如何建账做账
  • mysql 5.6 5.7
  • linux bin sbin
  • sql注入式攻击中单引号的作用
  • sql函数使用
  • u盘安装vista
  • redhat常用命令总结
  • debian reference
  • win8.1如何更改密码
  • 手机上的安全模式是什么
  • windows万能wifi
  • win10未检测到任何网络硬件
  • thinkpade431升级内存多大好
  • python调用ansible执行playbook
  • Nodejs+Socket.io实现通讯实例代码
  • 安卓模拟器错误怎么办
  • javascript基于什么的语言
  • js对象类
  • 蓝牙模块手机程序
  • 江西增值税发票查询
  • 居民个人从境外公司获得分红
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

    网站地图: 企业信息 工商信息 财税知识 网络常识 编程技术

    友情链接: 武汉网站建设