Web前端(11)-vue刷新网页404、登录状态页面路由处理

问题

一、登录状态路由处理

我的网页有两个页面,默认进入网站后的首页我指向了LoginView登录组件。

另一个是需要登录后才能看到的homepage页面。

现在遇到了两个问题:

1、没有登录直接将域名添加/homepage也能看到这个页面

2、已经登陆后访问网站默认域名没有跳转到/homepage,而是去到了默认的首页指向的LoginView登录页。

这明显不符合使用习惯。

二、刷新homepage页面404错误

用户已经登陆会跳转到homepage页面,但是刷新就报404,这是不正常的,正常应该是继续展示homepage页面即可。

解决方案

一、登录状态路由处理

未登陆状态如果用户想进入除了首页默认登录页以外的其他路由页面,都应该跳转回登录页面。

如果已经登陆,用户访问默认域名,则应该跳转到homepage登录后首页。

js 复制代码
router.beforeEach((to, from, next) => {
  if (to.meta.title) {
    document.title = to.meta.title;
  }
  const token = localStorage.getItem('token')
  const isLogined = token && token.trim() !== ''
  console.log("isLogined = ", isLogined + " to.path = " + to.path)
  // 统一处理路由
  if (to.path === '/' && isLogined) {
    // 如果用户已登录且访问登录页面,直接跳转到首页
    next('/homepage');
  } else if (to.path !== '/' && !isLogined) {
    // 如果没有登录就进入二级页面,都跳转到首页
    next('/')
  } else {
    next()
  }
});

二、刷新404

因为默认路由配置是使用的History模式,这种模式下每次刷新都会向服务器发送请求,服务器没有正确处理就会报404。

而hash模式会在页面路由前加上/#/,并且刷新不会向服务器发送请求,所以就不会404,所以route下的index.js改成hash模式即可。

js 复制代码
const router = createRouter({
  // history: createWebHistory(),// homepage页面刷新会404,因为history模式会向服务器发送请求,服务器没有正确处理就会报404
  history: createWebHashHistory(),
  routes
});
相关推荐
2601_9494800627 分钟前
【无标题】
开发语言·前端·javascript
css趣多多31 分钟前
Vue过滤器
前端·javascript·vue.js
理人综艺好会1 小时前
Web学习之用户认证
前端·学习
We་ct1 小时前
LeetCode 36. 有效的数独:Set实现哈希表最优解
前端·算法·leetcode·typescript·散列表
weixin_395448911 小时前
main.c_cursor_0129
前端·网络·算法
2401_859049082 小时前
git submodule update --init --recursive无法拉取解决
前端·chrome·git
这是个栗子2 小时前
【Vue代码分析】前端动态路由传参与可选参数标记:实现“添加/查看”模式的灵活路由配置
前端·javascript·vue.js
刘一说2 小时前
Vue 动态路由参数丢失问题详解:为什么 `:id` 拿不到值?
前端·javascript·vue.js
熊猫钓鱼>_>3 小时前
动态网站发布部署核心问题详解
前端·nginx·容器化·网页开发·云服务器·静态部署
方也_arkling3 小时前
elementPlus按需导入配置
前端·javascript·vue.js