草庐IT

vue 刷新页面实现自动选中上次的菜单以及点击菜单实现选中效果

CoderZb 2023-09-28 原文

image.png

router->index.js中的如下代码

import Vue from 'vue'
import store from '../store'
import VueRouter from 'vue-router'
Vue.use(VueRouter)


// 主入口
import MainPage from '../views/MainPage.vue';
import Dad from '../views/Dad.vue';
import ChannelList from '../views/channelList.vue';
import ChannelOrder from '../views/channelOrder.vue';
import YearCardManage from '../views/yearCardManage.vue';
const routes = [
  {
    path: '/',
    redirect: '/login'
  },
  {
    path: '/mainPage',
    component: MainPage,
    redirect: '/channelOrder',
    children: [
      {
        path: '/channelManage',
        meta: {title: '渠道商管理'},
        redirect: '/channelList',
        component: Dad,
        children: [
          {
            path: '/channelList',
            name:'channelList',
            meta: {title: '渠道商列表'},
            component:ChannelList
          },
          {
            path: '/channelOrder',
            name:'channelOrder',
            meta: {title: '渠道商订单'},
            component: ChannelOrder
          },
        ],
      },
      {
        path: '/yearCardManage',
        name:"yearCardManage",
        meta: {title: '年卡管理'},
        component: YearCardManage
      }
    ]
  },
]
const router = new VueRouter({
  routes: routes
})
// 挂载路由导航守卫。每进入到一个页面就会调用
router.beforeEach((to, from, next) => {

  console.log('xixixixhhhhhh---to',to,'----from---',from);
  if (to.path === '/login') {
    const cbUserName = window.localStorage.getItem("cbUserName");
    if (!cbUserName) {
      return next()// 没有用户名,去登录页面
    }else{
      return next('/mainPage')// 您已登录,去首页吧
    }
  }else{
    const cbUserId = store.state.cbUserId;
    if(!cbUserId ){
      return next('/login')
    }
    // 将本次访问的目的路径存入缓存。
    window.localStorage.setItem("activeLink", to.path);
  }
  next()
})


export default router

MainPage.vue中的如下代码

<template>
  <a-layout id="components-layout-demo-custom-trigger">
    <a-layout-sider
      :trigger="null"
      collapsible
      :style="{ overflow: 'auto', height: '100vh', position: 'fixed', left: 0 }"
    >
      <div style="height:20px;"></div>

      <a-menu theme="dark" mode="inline" :selectedKeys="selectedKeys">
        <template v-for="item in menuList">
          <!-- 二级类型的 -->
          <a-sub-menu v-if="item.child" :key="item.path">
            <div slot="title" style="display:flex;">
              <span :class="item.icons" style="display:flex;margin-right:13px;">
              </span>
              <span>{{ item.title }}</span>
            </div>
            <a-menu-item
              v-for="item2 in item.child"
              :key="item2.path"
              style="margin-left:4px;"
            >
              {{ item2.title }}
              <router-link :to="item2.path"> </router-link>
            </a-menu-item>
          </a-sub-menu>
          <!-- 一级类型的 -->
          <a-menu-item v-else :key="item.path">
            <span :class="item.icons" style="margin-right:10px;"></span>
            <span class="nav-text">{{ item.title }}</span>
            <router-link :to="item.path"> </router-link>
          </a-menu-item>
        </template>
      </a-menu>
    </a-layout-sider>
  </a-layout>
</template>
<script>
export default {
  data() {
    return {
      selectedKeys: [],
      menuList: [
        {
          title: "年卡管理",
          path: "/yearCardManage",
          icons: "iconfont icon-jingying",
          child: null
        },
        {
          title: "渠道商管理",
          path: "/channelManage",
          icons: "iconfont icon-qudao",
          child: [
            {
              title: "渠道商列表",
              path: "/channelList",
              icons: null,

              child: null
            },
            {
              title: "渠道商订单",
              path: "/channelOrder",
              icons: null,
              child: null
            }
          ]
        }
      ]
    };
  },
  watch: {
    // 监听路由变化。每次点击菜单就会调用。
    $route(to, from) {
      // 将目的路径赋值给selectedKeys,实现选中当前菜单
      this.selectedKeys = to.path.split(",");
    }
  },
  mounted() {
    // 刷新页面就会调用,获取上次存入的菜单
    var link = window.localStorage.getItem("activeLink");
    // 选中菜单
    this.selectedKeys = link.split(",");
  }
};
</script>

由以上代码分析,首先得知道router.beforeEach((to, from, next) => { })$route(to,from) {}的异同:

  • 相同点:
    参数to和from打印的内容是一样的。
  • 不同点:
    由于两个函数分别在不同的文件中,决定了分别有不同的作用。
    前者作用:跳转到任何一个页面都会走该函数,该函数和菜单标签不在一个页面,因此在该函数将目的路径存入缓存最合适。
    后者作用:点击每个菜单都会走该函数。因为该函数和菜单标签在同一文件,因此将目的路径赋值给菜单变量即可,不用存入缓存,当做临时变量使用。


  • 1、router->index.js文件中的router.beforeEach((to, from, next) => { })函数里面写入window.localStorage.setItem("activeLink", to.path);实现存入缓存
    2、MainPage.vue中的mounted() {}函数里面写入var link = window.localStorage.getItem("activeLink"); this.selectedKeys = link.split(",");实现获取上次的菜单并选中。

  • MainPage.vue中写入如下代码即可:
watch: {
    // 监听路由变化。每次点击菜单就会调用。
    $route(to, from) {
      // 将目的路径赋值给selectedKeys,实现选中当前菜单
      this.selectedKeys = to.path.split(",");
    }
  },

注意点:a-menu-item中的:key="item.path"很重要。<a-menu> 中的:selectedKeys="selectedKeys"就是根据这个:key对应的值来实现选中某个item的,同时要保证item.path值的唯一性。当然你也可以取item.aaitem.bb,只需要保证aa、bb有值且唯一就行。

有关vue 刷新页面实现自动选中上次的菜单以及点击菜单实现选中效果的更多相关文章

  1. ruby-on-rails - 使用 Ruby on Rails 进行自动化测试 - 最佳实践 - 2

    很好奇,就使用ruby​​onrails自动化单元测试而言,你们正在做什么?您是否创建了一个脚本来在cron中运行rake作业并将结果邮寄给您?git中的预提交Hook?只是手动调用?我完全理解测试,但想知道在错误发生之前捕获错误的最佳实践是什么。让我们理所当然地认为测试本身是完美无缺的,并且可以正常工作。下一步是什么以确保他们在正确的时间将可能有害的结果传达给您? 最佳答案 不确定您到底想听什么,但是有几个级别的自动代码库控制:在处理某项功能时,您可以使用类似autotest的内容获得关于哪些有效,哪些无效的即时反馈。要确保您的提

  2. ruby - 什么是填充的 Base64 编码字符串以及如何在 ruby​​ 中生成它们? - 2

    我正在使用的第三方API的文档状态:"[O]urAPIonlyacceptspaddedBase64encodedstrings."什么是“填充的Base64编码字符串”以及如何在Ruby中生成它们。下面的代码是我第一次尝试创建转换为Base64的JSON格式数据。xa=Base64.encode64(a.to_json) 最佳答案 他们说的padding其实就是Base64本身的一部分。它是末尾的“=”和“==”。Base64将3个字节的数据包编码为4个编码字符。所以如果你的输入数据有长度n和n%3=1=>"=="末尾用于填充n%

  3. ruby - RuntimeError(自动加载常量 Apps 多线程时检测到循环依赖 - 2

    我收到这个错误:RuntimeError(自动加载常量Apps时检测到循环依赖当我使用多线程时。下面是我的代码。为什么会这样?我尝试多线程的原因是因为我正在编写一个HTML抓取应用程序。对Nokogiri::HTML(open())的调用是一个同步阻塞调用,需要1秒才能返回,我有100,000多个页面要访问,所以我试图运行多个线程来解决这个问题。有更好的方法吗?classToolsController0)app.website=array.join(',')putsapp.websiteelseapp.website="NONE"endapp.saveapps=Apps.order("

  4. ruby - 如何根据特征实现 FactoryGirl 的条件行为 - 2

    我有一个用户工厂。我希望默认情况下确认用户。但是鉴于unconfirmed特征,我不希望它们被确认。虽然我有一个基于实现细节而不是抽象的工作实现,但我想知道如何正确地做到这一点。factory:userdoafter(:create)do|user,evaluator|#unwantedimplementationdetailshereunlessFactoryGirl.factories[:user].defined_traits.map(&:name).include?(:unconfirmed)user.confirm!endendtrait:unconfirmeddoenden

  5. 华为OD机试用Python实现 -【明明的随机数】 2023Q1A - 2

    华为OD机试题本篇题目:明明的随机数题目输入描述输出描述:示例1输入输出说明代码编写思路最近更新的博客华为od2023|什么是华为od,od薪资待遇,od机试题清单华为OD机试真题大全,用Python解华为机试题|机试宝典【华为OD机试】全流程解析+经验分享,题型分享,防作弊指南华为o

  6. 【鸿蒙应用开发系列】- 获取系统设备信息以及版本API兼容调用方式 - 2

    在应用开发中,有时候我们需要获取系统的设备信息,用于数据上报和行为分析。那在鸿蒙系统中,我们应该怎么去获取设备的系统信息呢,比如说获取手机的系统版本号、手机的制造商、手机型号等数据。1、获取方式这里分为两种情况,一种是设备信息的获取,一种是系统信息的获取。1.1、获取设备信息获取设备信息,鸿蒙的SDK包为我们提供了DeviceInfo类,通过该类的一些静态方法,可以获取设备信息,DeviceInfo类的包路径为:ohos.system.DeviceInfo.具体的方法如下:ModifierandTypeMethodDescriptionstatic StringgetAbiList​()Obt

  7. 基于C#实现简易绘图工具【100010177】 - 2

    C#实现简易绘图工具一.引言实验目的:通过制作窗体应用程序(C#画图软件),熟悉基本的窗体设计过程以及控件设计,事件处理等,熟悉使用C#的winform窗体进行绘图的基本步骤,对于面向对象编程有更加深刻的体会.Tutorial任务设计一个具有基本功能的画图软件**·包括简单的新建文件,保存,重新绘图等功能**·实现一些基本图形的绘制,包括铅笔和基本形状等,学习橡皮工具的创建**·设计一个合理舒适的UI界面**注明:你可能需要先了解一些关于winform窗体应用程序绘图的基本知识,以及关于GDI+类和结构的知识二.实验环境Windows系统下的visualstudio2017C#窗体应用程序三.

  8. ruby-on-rails - 从应用程序中自定义文件夹内的命名空间自动加载 - 2

    我们目前正在为ROR3.2开发自定义cms引擎。在这个过程中,我们希望成为我们的rails应用程序中的一等公民的几个类类型起源,这意味着它们应该驻留在应用程序的app文件夹下,它是插件。目前我们有以下类型:数据源数据类型查看我在app文件夹下创建了多个目录来保存这些:应用/数据源应用/数据类型应用/View更多类型将随之而来,我有点担心应用程序文件夹被这么多目录污染。因此,我想将它们移动到一个子目录/模块中,该子目录/模块包含cms定义的所有类型。所有类都应位于MyCms命名空间内,目录布局应如下所示:应用程序/my_cms/data_source应用程序/my_cms/data_ty

  9. MIMO-OFDM无线通信技术及MATLAB实现(1)无线信道:传播和衰落 - 2

     MIMO技术的优缺点优点通过下面三个增益来总体概括:阵列增益。阵列增益是指由于接收机通过对接收信号的相干合并而活得的平均SNR的提高。在发射机不知道信道信息的情况下,MIMO系统可以获得的阵列增益与接收天线数成正比复用增益。在采用空间复用方案的MIMO系统中,可以获得复用增益,即信道容量成倍增加。信道容量的增加与min(Nt,Nr)成正比分集增益。在采用空间分集方案的MIMO系统中,可以获得分集增益,即可靠性性能的改善。分集增益用独立衰落支路数来描述,即分集指数。在使用了空时编码的MIMO系统中,由于接收天线或发射天线之间的间距较远,可认为它们各自的大尺度衰落是相互独立的,因此分布式MIMO

  10. 计算机毕业设计ssm+vue基本微信小程序的小学生兴趣延时班预约小程序 - 2

    项目介绍随着我国经济迅速发展,人们对手机的需求越来越大,各种手机软件也都在被广泛应用,但是对于手机进行数据信息管理,对于手机的各种软件也是备受用户的喜爱小学生兴趣延时班预约小程序的设计与开发被用户普遍使用,为方便用户能够可以随时进行小学生兴趣延时班预约小程序的设计与开发的数据信息管理,特开发了小程序的设计与开发的管理系统。小学生兴趣延时班预约小程序的设计与开发的开发利用现有的成熟技术参考,以源代码为模板,分析功能调整与小学生兴趣延时班预约小程序的设计与开发的实际需求相结合,讨论了小学生兴趣延时班预约小程序的设计与开发的使用。开发环境开发说明:前端使用微信微信小程序开发工具:后端使用ssm:VU

随机推荐