vue 前端记录用户访问过的页面,根据排序,获取用户常访问的页面

 在main.js中

// 记录用户访问页面及访问次数
let ToRouter;
// let ToRouter = JSON.parse(sessionStorage.getItem("ToRouter"));
if (JSON.parse(sessionStorage.getItem("ToRouter"))) {
  ToRouter = JSON.parse(sessionStorage.getItem("ToRouter"));
} else {
  ToRouter = [];
}
router.beforeEach((to, from, next) => {
  // console.log(to, from, next);

  if (to.meta.requireAuth === true && !getToken()) {
    next({
      // name: "Login",
    });
  } else {
    const routerData = new Object();
    routerData.router = new Object();
    routerData.router.name = to.name;
    routerData.router.params = to.params;
    routerData.router.query = to.query;
    routerData.title = to.meta.title;
    routerData.name = to.name;
    routerData.num = 0;
    if (ToRouter.length == 0  && routerData.name != "Login") {
      ToRouter.push(routerData);
    } else {
      for (var i = 0; i < ToRouter.length; i++) {
        if (ToRouter[i].title == routerData.title) {
          console.log("如果数组中已经存在这条数据");
          ToRouter[i].num++;
          break;
        }
        if (i == ToRouter.length - 1  && routerData.name != "Login") {
          console.log("不存在这条数据");
          ToRouter.push(routerData);
          break;
        }
      }
    }

    console.log("ToRouter", ToRouter);
//保存到本地
    sessionStorage.setItem("ToRouter", JSON.stringify(ToRouter));
    next();
  }
});

在使用的页面   获取数组

  // 拿到存在本地的访问过的页面
    let ToRouter = JSON.parse(sessionStorage.getItem("ToRouter"));
    // 对页面根据点击次数排序
    ToRouter.sort((a, b) => {
      return b.num - a.num;
    });
    console.log("home======ToRouter", ToRouter);
    // 截取常用的前十个页面
    this.ToRouter = ToRouter.splice(0, 10);

  • 5
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
如果Vue无法访问前端页面,可能是由于以下原因之一造成的: 1. 路由守卫限制:在Vue项目中,可以使用路由守卫来限制前端页面访问权限。你可以在路由配置中设置路由守卫,以确保只有具有特定权限的用户可以访问某些页面。这可以通过在路由守卫中检查用户的身份认证状态或角色来实现。 2. 浏览器缓存问题:有时候,浏览器可能会缓存旧的资源,导致请求失败或无法访问前端页面。你可以通过在入口文件index.html中添加meta标签来解决这个问题,例如设置no-cache的HTTP头部信息。另外,如果你部署在nginx服务器上,你也可以在nginx配置文件中添加Cache-Control头部信息来禁止缓存。 3. 版本号控制:对于大型应用程序,你可以考虑使用版本号控制来确保前端页面的更新。你可以在前端轮询一个版本号的服务接口,每次发版时更新版本号,然后在每次请求时检查当前版本号与配置的版本是否一致,如果不一致,则强制刷新页面。这可以通过在每次请求中附加版本号参数来实现。 4. 强制刷新浏览器:对于使用电脑浏览器的用户,你可以建议他们使用Ctrl+F5键来强制刷新浏览器。这将导致浏览器不使用缓存,并直接向服务器发送请求获取最新的内容。 综上所述,如果你无法访问Vue前端页面,你可以检查路由守卫配置、处理浏览器缓存问题、使用版本号控制或建议用户强制刷新浏览器来解决问题。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* [vue路由守卫,限制前端页面访问权限的例子](https://download.csdn.net/download/weixin_38523728/12932264)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *2* [vue全局修改前端访问地址](https://blog.csdn.net/weixin_56204334/article/details/126946836)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] - *3* [VUE前端应用部署页面访问404问题](https://blog.csdn.net/qq_35120986/article/details/123927074)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 33.333333333333336%"] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值