时间:2021-05-26
前言:
在Vue项目中,当访问的页面路由不存在或错误时,页面显示为一片空白。然而,通常我们需要对访问url不存在或者错误的情况下添加默认的404页面,即not found页面。
一般的处理方法是:
在最后添加一个path: * ,优先级从上到下查找路由,都没有的时候全部指向 404页面 ,代码如下:
const baseRoute = [ { path: '/login', name: 'login', component: Login }, {path: '/', redirect: '/index', component: Layout, name: 'dashboard'}, // 404page { path: '/404', name: 'page404', component: page404 }, { path: '/', redirect: '/index', component: Layout, children: [ { path: 'index', name: 'index', component: ModeIndex, meta: { title: '', // 设备建模 icon: '' } }, { path: 'project', name: 'project', component: Project, meta: { dynamic: true, // 动态面包屑标题 title: '' } } ] } { path: '*', // 页面不存在的情况下会跳到404页面 redirect: '/404', name: 'notFound', hidden: true }]const router = new Router({ routes: baseRoute})问题:
这样做好处是简单,方便,但是因为我代码里面添加了如下代码,用于页面token失效跳出登录的时候记住当前路由,当下次再登录的时候直接跳到指定路由
if (to.path.slice(1) !== '') { router.push({ path: '/login', query: { redirect: to.path.slice(1) } }) } else { router.push({ path: '/login' }) }就是因为加了所有找不到都指向404,导致了第一次不知道网址的人输错后,redirect就指向了404,这样用户第一次登录成功后页面就进入404,体验很差,产品和测试也一直以为是页面出bug了,为了解决这个问题,查找了相关资料,下面是优化后的方法。
优化后的设置方式:
1、route --> index.js
末尾去掉 * --> 404
const baseRoute = [ { path: '/login', name: 'login', component: Login }, {path: '/', redirect: '/index', component: Layout, name: 'dashboard'}, // 404page {path: '/404', component: page404, name: 'page404'}, { path: '/', redirect: '/index', component: Layout, children: [ { path: 'index', name: 'index', component: ModeIndex, meta: { title: '', // 设备建模 icon: '' } }, { path: 'project', name: 'project', component: Project, meta: { dynamic: true, // 动态面包屑标题 title: '' } } ] }, // { // path: '*', // 页面不存在的情况下会跳到404页面 //redirect: '/404', //name: 'notFound', //hidden: true //}]const router = new Router({ routes: baseRoute})2、在router.beforeEach 里面使用 to.matched 匹配出的路由个数来作为判断条件,匹配不到路由就跳转到404页面,代码如下
pemmision.js
代码如下:
import router from './router'import { getCookie } from './utils/auth'// 通过beforeEach钩子来判断用户是否登陆过 有无tokenconst whiteList = ['/login'] // 不重定向白名单// const userInfo = getUserInfo()router.beforeEach((to, from, next) => { console.log(to.matched) // 判断是否有登录过 if (getCookie('userId_dev')) { // 如果包含userId_dev 从登录页面跳转 直接跳转到首页 / if (to.path === '/login') { next() } else { if (to.matched.length === 0) { next('/404') // 判断此跳转路由的来源路由是否存在,存在的情况跳转到来源路由,否则跳转到404页面 } next() // 如果匹配到正确跳转 } // 没有登录 } else { if (whiteList.indexOf(to.path) !== -1) { next() } else { // 还没有登录过 则跳转到登录界面 // next('/login') if (to.path.slice(1) !== '') { if (to.matched.length === 0) { router.push({ path: '/login' }) } else { router.push({ path: '/login', query: { redirect: to.path.slice(1) } }) } } else { router.push({ path: '/login' }) } } }})这样就解决了一开始输错就跳到404的尴尬了!
补充知识:Vue中用户输入无效地址,跳转到错误提示页面
1. 在动态路由中,有的路径是无效路径,可以让无效的路劲跳转到错误提示页面
组件的$router属性的原型上有一些方法(this.$router)
(1)go方法
(2)replace:用新的路径替换错误路径,同时创建错误页面的组件
a——b(不存在的路径)——c(用c取代了b);所以路径中就是a——c
(3)push:a——b(不存在的路径)——c(在b后面添加了c);所以路径就是a——b——c
以上这篇vue 项目中当访问路由不存在的时候默认访问404页面操作就是小编分享给大家的全部内容了,希望能给大家一个参考,也希望大家多多支持。
声明:本页内容来源网络,仅供用户参考;我单位不保证亦不表示资料全面及准确无误,也不保证亦不表示这些资料为最新信息,如因任何原因,本网内容或者用户因倚赖本网内容造成任何损失或损害,我单位将不会负任何法律责任。如涉及版权问题,请提交至online#300.cn邮箱联系删除。
在SEO优化中404页面常常被忽视,即使是大型网站,也会有不存在404页面的情况发生,当用户由于某种原理访问网站不存在页面时,没有客制化的404页面就会大大降低
建站过程中,404页面必不可少。404页面,就是当网站某个内页删除后,用户点击跳转进去,会提示页面不存在或连接错误,且该页面可访问到网站其他页面。通常,404页
下面我就对404页面进行透彻的讲解。 404页面的概念: 当你打开某一个网站的内页页面不存在,提示页面不存在或者连接错误,该页面上可以访问到网站的其他页
当网站的用户和搜索引擎访问网站上不存在的页面时,服务器终端会返回404错误页面,如果站长没有给网站设计人性化的404页面,那服务会默认返回错误信息页面,用户并不
404页面是网站必备的一个页面,它承载着用户体验与SEO优化的重任。404页面通常为用户访问了网站上不存在或已删除的页面,服务器返回的404错误。如果站长没有设