电脑知识|欧美黑人一区二区三区|软件|欧美黑人一级爽快片淫片高清|系统|欧美黑人狂野猛交老妇|数据库|服务器|编程开发|网络运营|知识问答|技术教程文章 - 好吧啦网

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

vue 項(xiàng)目中當(dāng)訪問(wèn)路由不存在的時(shí)候默認(rèn)訪問(wèn)404頁(yè)面操作

瀏覽:147日期:2022-12-02 08:02:57

前言:

在Vue項(xiàng)目中,當(dāng)訪問(wèn)的頁(yè)面路由不存在或錯(cuò)誤時(shí),頁(yè)面顯示為一片空白。然而,通常我們需要對(duì)訪問(wèn)url不存在或者錯(cuò)誤的情況下添加默認(rèn)的404頁(yè)面,即not found頁(yè)面。

一般的處理方法是:

在最后添加一個(gè)path: * ,優(yōu)先級(jí)從上到下查找路由,都沒有的時(shí)候全部指向 404頁(yè)面 ,代碼如下:

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: ’’, // 設(shè)備建模 icon: ’’ } }, { path: ’project’, name: ’project’, component: Project, meta: { dynamic: true, // 動(dòng)態(tài)面包屑標(biāo)題 title: ’’ } } ] } { path: ’*’, // 頁(yè)面不存在的情況下會(huì)跳到404頁(yè)面 redirect: ’/404’, name: ’notFound’, hidden: true }]const router = new Router({ routes: baseRoute})

問(wèn)題:

這樣做好處是簡(jiǎn)單,方便,但是因?yàn)槲掖a里面添加了如下代碼,用于頁(yè)面token失效跳出登錄的時(shí)候記住當(dāng)前路由,當(dāng)下次再登錄的時(shí)候直接跳到指定路由

if (to.path.slice(1) !== ’’) { router.push({ path: ’/login’, query: { redirect: to.path.slice(1) } }) } else { router.push({ path: ’/login’ }) }

就是因?yàn)榧恿怂姓也坏蕉贾赶?04,導(dǎo)致了第一次不知道網(wǎng)址的人輸錯(cuò)后,redirect就指向了404,這樣用戶第一次登錄成功后頁(yè)面就進(jìn)入404,體驗(yàn)很差,產(chǎn)品和測(cè)試也一直以為是頁(yè)面出bug了,為了解決這個(gè)問(wèn)題,查找了相關(guān)資料,下面是優(yōu)化后的方法。

優(yōu)化后的設(shè)置方式: 

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: ’’, // 設(shè)備建模 icon: ’’ } }, { path: ’project’, name: ’project’, component: Project, meta: { dynamic: true, // 動(dòng)態(tài)面包屑標(biāo)題 title: ’’ } } ] }, // { // path: ’*’, // 頁(yè)面不存在的情況下會(huì)跳到404頁(yè)面 //redirect: ’/404’, //name: ’notFound’, //hidden: true //}]const router = new Router({ routes: baseRoute})

2、在router.beforeEach 里面使用 to.matched 匹配出的路由個(gè)數(shù)來(lái)作為判斷條件,匹配不到路由就跳轉(zhuǎn)到404頁(yè)面,代碼如下

pemmision.js

代碼如下:

import router from ’./router’import { getCookie } from ’./utils/auth’// 通過(guò)beforeEach鉤子來(lái)判斷用戶是否登陸過(guò) 有無(wú)tokenconst whiteList = [’/login’] // 不重定向白名單// const userInfo = getUserInfo()router.beforeEach((to, from, next) => { console.log(to.matched) // 判斷是否有登錄過(guò) if (getCookie(’userId_dev’)) { // 如果包含userId_dev 從登錄頁(yè)面跳轉(zhuǎn) 直接跳轉(zhuǎn)到首頁(yè) / if (to.path === ’/login’) { next() } else { if (to.matched.length === 0) { next(’/404’) // 判斷此跳轉(zhuǎn)路由的來(lái)源路由是否存在,存在的情況跳轉(zhuǎn)到來(lái)源路由,否則跳轉(zhuǎn)到404頁(yè)面 } next() // 如果匹配到正確跳轉(zhuǎn) } // 沒有登錄 } else { if (whiteList.indexOf(to.path) !== -1) { next() } else { // 還沒有登錄過(guò) 則跳轉(zhuǎn)到登錄界面 // 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’ }) } } }})

這樣就解決了一開始輸錯(cuò)就跳到404的尷尬了!

補(bǔ)充知識(shí):Vue中用戶輸入無(wú)效地址,跳轉(zhuǎn)到錯(cuò)誤提示頁(yè)面

1. 在動(dòng)態(tài)路由中,有的路徑是無(wú)效路徑,可以讓無(wú)效的路勁跳轉(zhuǎn)到錯(cuò)誤提示頁(yè)面

組件的$router屬性的原型上有一些方法(this.$router)

vue 項(xiàng)目中當(dāng)訪問(wèn)路由不存在的時(shí)候默認(rèn)訪問(wèn)404頁(yè)面操作

(1)go方法

(2)replace:用新的路徑替換錯(cuò)誤路徑,同時(shí)創(chuàng)建錯(cuò)誤頁(yè)面的組件

a——b(不存在的路徑)——c(用c取代了b);所以路徑中就是a——c

(3)push:a——b(不存在的路徑)——c(在b后面添加了c);所以路徑就是a——b——c

vue 項(xiàng)目中當(dāng)訪問(wèn)路由不存在的時(shí)候默認(rèn)訪問(wèn)404頁(yè)面操作

以上這篇vue 項(xiàng)目中當(dāng)訪問(wèn)路由不存在的時(shí)候默認(rèn)訪問(wèn)404頁(yè)面操作就是小編分享給大家的全部?jī)?nèi)容了,希望能給大家一個(gè)參考,也希望大家多多支持好吧啦網(wǎng)。

標(biāo)簽: Vue
相關(guān)文章:
主站蜘蛛池模板: 多功能真空滤油机_润滑油全自动滤油机_高效真空滤油机价格-重庆润华通驰 | 合景一建-无尘车间设计施工_食品医药洁净车间工程装修总承包公司 | 挤出熔体泵_高温熔体泵_熔体出料泵_郑州海科熔体泵有限公司 | 消电检公司,消电检价格,北京消电检报告-北京设施检测公司-亿杰(北京)消防工程有限公司 | 四合院设计_四合院装修_四合院会所设计-四合院古建设计与建造中心1 | STRO|DTRO-STRO反渗透膜(科普)_碟滤 | 活性炭-果壳木质煤质柱状粉状蜂窝活性炭厂家价格多少钱 | 闪蒸干燥机-喷雾干燥机-带式干燥机-桨叶干燥机-[常州佳一干燥设备] | 巩义市科瑞仪器有限公司| 杭州ROHS检测仪-XRF测试仪价格-百科 | _网名词典_网名大全_qq网名_情侣网名_个性网名 | 电缆隧道在线监测-智慧配电站房-升压站在线监测-江苏久创电气科技有限公司 | 天然气分析仪-液化气二甲醚分析仪|传昊仪器 | 亳州网络公司 - 亳州网站制作 - 亳州网站建设 - 亳州易天科技 | 尚为传动-专业高精密蜗轮蜗杆,双导程蜗轮蜗杆,蜗轮蜗杆减速机,蜗杆减速机生产厂家 | 成都热收缩包装机_袖口式膜包机_高速塑封机价格_全自动封切机器_大型套膜机厂家 | 上海防爆真空干燥箱-上海防爆冷库-上海防爆冷柜?-上海浦下防爆设备厂家? | 自动螺旋上料机厂家价格-斗式提升机定制-螺杆绞龙输送机-杰凯上料机 | 奥运星-汽车性能网评-提供个性化汽车资讯| 新中天检测有限公司青岛分公司-山东|菏泽|济南|潍坊|泰安防雷检测验收 | EPK超声波测厚仪,德国EPK测厚仪维修-上海树信仪器仪表有限公司 | 电动高压冲洗车_价格-江苏速利达机车有限公司 | 北京宣传片拍摄_产品宣传片拍摄_宣传片制作公司-现像传媒 | 天津中都白癜风医院_天津白癜风医院_天津治疗白癜风 | 宁夏档案密集柜,智能密集柜,电动手摇密集柜-盛隆柜业宁夏档案密集柜厂家 | 变频器维修公司_plc维修_伺服驱动器维修_工控机维修 - 夫唯科技 变位机,焊接变位机,焊接变位器,小型变位机,小型焊接变位机-济南上弘机电设备有限公司 | 会议会展活动拍摄_年会庆典演出跟拍_摄影摄像直播-艾木传媒 | 风电变桨伺服驱动器-风电偏航变桨系统-深圳众城卓越科技有限公司 | 浙江寺庙设计-杭州寺院设计-宁波寺庙规划_汉匠 | 大流量卧式砂磨机_强力分散机_双行星双动力混合机_同心双轴搅拌机-莱州市龙跃化工机械有限公司 | 防火卷帘门价格-聊城一维工贸特级防火卷帘门厂家▲ | 医学动画公司-制作3d医学动画视频-医疗医学演示动画制作-医学三维动画制作公司 | 字典-新华字典-在线字典查字-字典趣 | 刺绳_刀片刺网_刺丝滚笼_不锈钢刺绳生产厂家_安平县浩荣金属丝网制品有限公司-安平县浩荣金属丝网制品有限公司 | 氢氧化钾厂家直销批发-济南金昊化工有限公司 | 电采暖锅炉_超低温空气源热泵_空气源热水器-鑫鲁禹电锅炉空气能热泵厂家 | 球形钽粉_球形钨粉_纳米粉末_难熔金属粉末-广东银纳官网 | 大_小鼠elisa试剂盒-植物_人Elisa试剂盒-PCR荧光定量试剂盒-上海一研生物科技有限公司 | 真空乳化机-灌装封尾机-首页-温州精灌| 伊卡洛斯软装首页-电动窗帘,别墅窗帘,定制窗帘,江浙沪1000+别墅窗帘案例 | 丽陂特官网_手机信号屏蔽器_Wifi信号干扰器厂家_学校考场工厂会议室屏蔽仪 |