位置: 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)(什么是西孟加拉邦首府)

  • vivo手机分身怎么弄(vivo手机分身怎么恢复原来)

    vivo手机分身怎么弄(vivo手机分身怎么恢复原来)

  • 小米手环6pai功能怎么关闭(小米手环6功能详解)

    小米手环6pai功能怎么关闭(小米手环6功能详解)

  • 淘鲜达在淘宝哪里(淘鲜达在哪里)

    淘鲜达在淘宝哪里(淘鲜达在哪里)

  • 流量主收入怎样到账(流量主收入的钱到哪里去了)

    流量主收入怎样到账(流量主收入的钱到哪里去了)

  • xs黑屏转圈无法重启(iphonexs黑屏转圈)

    xs黑屏转圈无法重启(iphonexs黑屏转圈)

  • qq扩列被限制多久可以解除(qq扩列被系统限制匹配怎么办)

    qq扩列被限制多久可以解除(qq扩列被系统限制匹配怎么办)

  • 华为p40pro相机怎么用(华为p40pro相机怎么设置最好)

    华为p40pro相机怎么用(华为p40pro相机怎么设置最好)

  • k2100m显卡是什么水平(k2100显卡评测)

    k2100m显卡是什么水平(k2100显卡评测)

  • 手机音响孔进水了怎么办(手机音响孔进水了怎么办华为)

    手机音响孔进水了怎么办(手机音响孔进水了怎么办华为)

  • 小米遥控器突然不能用了(小米遥控器突然不能用了,指示灯也不亮)

    小米遥控器突然不能用了(小米遥控器突然不能用了,指示灯也不亮)

  • 苹果11清晰度可以提高吗(苹果11清晰度可以调节吗)

    苹果11清晰度可以提高吗(苹果11清晰度可以调节吗)

  • 华为v30耳机接口在哪(华为荣耀v30耳机接口)

    华为v30耳机接口在哪(华为荣耀v30耳机接口)

  • 电话正忙稍后再拨什么意思(电话正忙稍后再拨怎么办)

    电话正忙稍后再拨什么意思(电话正忙稍后再拨怎么办)

  • 荣耀20可以遥控空调吗(荣耀手机可以遥控空调吗?)

    荣耀20可以遥控空调吗(荣耀手机可以遥控空调吗?)

  • 微信上视频怎么美颜(微信上视频怎么删除)

    微信上视频怎么美颜(微信上视频怎么删除)

  • 二手苹果为啥不让升级(二手苹果为啥不能走海关)

    二手苹果为啥不让升级(二手苹果为啥不能走海关)

  • 五g卡4g手机能用吗(五g手机4g卡可以用5g网络吗)

    五g卡4g手机能用吗(五g手机4g卡可以用5g网络吗)

  • 户户通怎么授权(戸户通怎么授权)

    户户通怎么授权(戸户通怎么授权)

  • boss直聘怎么屏蔽自己公司(boss直聘怎么屏蔽主播岗位)

    boss直聘怎么屏蔽自己公司(boss直聘怎么屏蔽主播岗位)

  • 刷机删的照片怎么恢复(刷机丢掉的照片还能找回来吗)

    刷机删的照片怎么恢复(刷机丢掉的照片还能找回来吗)

  • 滴滴未满十八岁怎么打车(滴滴未满十八岁怎么接单)

    滴滴未满十八岁怎么打车(滴滴未满十八岁怎么接单)

  • 闲鱼双方评价怎么删除(闲鱼互相评价)

    闲鱼双方评价怎么删除(闲鱼互相评价)

  • 淘宝帮我选在哪里找(淘宝帮我选记录怎么删除)

    淘宝帮我选在哪里找(淘宝帮我选记录怎么删除)

  • 苹果x分屏怎么打开(苹果x分屏怎么开)

    苹果x分屏怎么打开(苹果x分屏怎么开)

  • 苹果11怎么装双卡(苹果11怎么装双卡双待)

    苹果11怎么装双卡(苹果11怎么装双卡双待)

  • 淘宝不发货多久自动退款(淘宝不发货多久自动退单)

    淘宝不发货多久自动退款(淘宝不发货多久自动退单)

  • 手机修改无线密码(手机修改无线密码怎么改)

    手机修改无线密码(手机修改无线密码怎么改)

  • 苹果x怎么换成其他刘海(苹果x怎么换成英文模式)

    苹果x怎么换成其他刘海(苹果x怎么换成英文模式)

  • blued如何恢复聊天记录(blued怎么恢复聊天记录)

    blued如何恢复聊天记录(blued怎么恢复聊天记录)

  • findfont: Font family [‘Times New Roman‘] not found. Falling back to DejaVu Sans.

    findfont: Font family [‘Times New Roman‘] not found. Falling back to DejaVu Sans.

  • 记账凭证红字冲销
  • 发票未到怎么暂估入账
  • 报完税的发票还能作废吗
  • 人力资源公司开办条件
  • 销售滞后是什么行为
  • 固定资产净残值率
  • 营业外收入包括其他业务收入吗
  • 存货的加工成本指的是加工过程中发生的追加费用
  • 土地增值税清算扣除项目
  • 固定资产属于净资产的哪一项
  • 货物运输企业在运输货物时应当尽可能采用
  • 收到发票冲预付账款摘要怎么写
  • 当月取得的进项必须当月勾选吗
  • 教育费附加会计分录
  • 个人持有原始股要交税吗
  • 劳务发票普票怎么开
  • 案例分析两个分公司转资金怎么做账?
  • 小规模季度超过30万是全额纳税吗
  • 增值税专用发票几个点
  • 高新技术企业优惠政策叠加
  • 进口设备不需要交关税吗
  • 应交增值税下面有几个科目
  • 应交税费未交增值税怎么计算
  • 工商年度报表怎么打印出来
  • 稻谷增值税税率多少
  • 材料验收入库会计分录怎么写计划成本法
  • 生产工人工资和福利费是产品成本项目
  • 设置戴尔笔记本锁屏时间
  • 采购及安装合同怎么缴纳印花税
  • Intel 酷睿i5 8300H
  • win10默认网关自动清空
  • 进程控制块PCB不包括( )
  • rsync inotify sersync
  • 拍卖土地印花税
  • 车辆违章罚款的钱上交到那了
  • 执行企业会计制度的企业有哪些
  • 巴塞罗那城市布局
  • input输入框非空验证
  • 【深度学习】datasets.ImageFolder 使用方法
  • php获取当前文件夹
  • 人力为主的公司名称
  • 微信公众号认证300元每年都要吗
  • 利息收入怎么做账务处理
  • 员工探亲证明怎么写
  • 对企业采取以旧换新方式销售的应税产品
  • 搅拌机属于什么费用
  • 小企业机械作业指导书
  • 出口退税还需要交企业所得税吗
  • 财务软件属于什么设备
  • mysql数据库函数
  • 修改数据库为多个数据
  • 出口退税是什么
  • 金蝶建账初始数据修改
  • 确认收入后销售怎么算
  • 研发加计扣除抵减税额怎么算
  • 产品销售收入的确认条件
  • 成品油 规定
  • sqlserver如何设置主键
  • 请问usb是什么意思啊
  • win7打开注册表的命令
  • win10耳机和扬声器有什么区别
  • cocos2d-js教程
  • python基本用法
  • percona mongodb
  • unity shaders and effects cookbook
  • opengl基础知识噪声名词解释
  • shell 字符操作
  • python读json文件和写json文件
  • python模拟用户登录过程,输入账号及密码
  • html如何用css
  • js 键盘码
  • shell 批量删除
  • javascript怎么学
  • unityugui
  • Android本地文件怎么显示歌词
  • code encode的区别
  • 企业房产税公式
  • 开量贩ktv一年能赚多少
  • 国税增值税申报怎么记账凭证填写
  • 税控盘抵税申报表怎么填
  • 免责声明:网站部分图片文字素材来源于网络,如有侵权,请及时告知,我们会第一时间删除,谢谢! 邮箱:opceo@qq.com

    鄂ICP备2023003026号

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

    友情链接: 武汉网站建设