所属分类:web前端开发
本篇文章带大家进行Vue学习,聊聊Vue2和Vue3中设置404界面的方法,希望对大家有所帮助!
vue页面中,如果跳转了不存在的路由那么,那么页面就会出现白屏状态,为了解决这个问题,我们可以自己写一个404界面,让其跳转过去。
在此文件中,一般存放的都是我们的路由信息,我们经常使用path:'*'来进行捕获我们的路由,度过不存在那么我们就让它进行跳转至我们自定义的404页面。
import Vue from 'vue'
import Router from 'vue-router'
import Homepage from '@/components/Homepage'
Vue.use(Router)
export default new Router({
routes: [
{
path: '/',
component: Homepage,
},
{
path:'*',
component:()=>import('../views/404.vue')
}
]
})
登录后复制
注意:这个path一定要写在最外面。【相关推荐:vuejs视频教程、web前端开发】
这个页面通常我们可以自定义,一般包括跳转某个页面的超链接或者就是定时多长时间进行跳转。
<template>
<div>
<p>
页面将在<span>{{ time }}</span>秒后自动跳转首页,<br>
您也可以点击这里跳转<a href="/">首页</a>
</p>
</div>
</template>
<script>
// 这里可以导入其他文件(比如:组件,工具js,第三方插件js,json文件,图片文件等等)
export default {
name: '',
components: {
},
// 定义属性
data() {
return {
time: '10',
time_end: null
}
},
// 计算属性,会监听依赖属性值随之变化
computed: {},
// 监控data中的数据变化
watch: {},
// 方法集合
methods: {
GoIndex() {
let _t = 9
this.time_end = setInterval(() => {
if (_t !== 0) {
this.time = _t--;
} else {
this.$router.replace('/')
clearTimeout(this.time_end)
this.time_end = null
}
}, 1000)
}
},
// 生命周期 - 创建完成(可以访问当前this实例)
created() {
this.GoIndex()
},
// 生命周期 - 挂载完成(可以访问DOM元素)
mounted() {
},
beforeCreate() { }, // 生命周期 - 创建之前
beforeMount() { }, // 生命周期 - 挂载之前
beforeUpdate() { }, // 生命周期 - 更新之前
updated() { }, // 生命周期 - 更新之后
beforeDestroy() { }, // 生命周期 - 销毁之前
destroyed() {
clearTimeout(this.time_end)
this.time_end = null
}, // 生命周期 - 销毁完成
activated() { }, // 如果页面有keep-alive缓存功能,这个函数会触发
}
</script>
<style scoped>
.not_found {
width: 100%;
height: 100%;
background: url('../../static/img/404.gif') no-repeat;
background-position: center;
background-size: cover;
p {
position: absolute;
top: 50%;
left: 20%;
transform: translate(-50%, 0);
color: #fff;
span{
color: orange;
font-family: '仿宋';
font-size: 25px;
}
a {
font-size: 30px;
color: aqua;
text-decoration: underline;
}
}
}
</style>
登录后复制
那么实现的效果就如下图所示:
404实现效果
为什么要分开说呢?因为在vue3中我们进行如下设置:
{
path:'*',
component:()=>import('../views/404.vue')
}
登录后复制
会产生错误,错误信息:Catch all routes ("*") must now be defined using a param with a custom regexp.,意思就是:现在必须使用与自定义Regexp的参数定义所有路由(“*”)。
那么官方是这么说的:
// plan on directly navigating to the not-found route using its name
{ path: '/:pathMatch(.*)*', name: 'not-found', component: NotFound },
// if you omit the last `*`, the `/` character in params will be encoded when resolving or pushing
{ path: '/:pathMatch(.*)', name: 'bad-not-found', component: NotFound },
登录后复制
那么我们vue2中的index.js文件中的代码就变成了如下:
...
export default new Router({
routes: [
...,
{
path:'/:pathMatch(.*)*',
component:()=>import('../views/404.vue')
}
//或者
{
path:'/:pathMatch(.*)',
component:()=>import('../views/404.vue')
}
]
})
登录后复制
(学习视频分享:vuejs入门教程、编程基础视频)
以上就是聊聊Vue2和Vue3中怎么设置404界面的详细内容,更多请关注zzsucai.com其它相关文章!