首页 > 其他分享 >Vue.js:Vue-Router动态路由从服务器接口获取路由数据

Vue.js:Vue-Router动态路由从服务器接口获取路由数据

时间:2023-05-07 22:04:23浏览次数:48  
标签:Vue js 添加 routes router 动态 数据 路由

(目录)

文档

版本号

"vue": "2.6.10",
"vue-router": "3.6.5",

有几种方式实现动态路由:

  1. 前端配置完整路由,通过接口返回的数据判断是否可显示,是否可访问
  2. 前端配置部分路由,由后端接口返回的数据生成新路由
  3. 抛开路由的思维,是否能直接通过url查询参数或者是动态路径参数解决问题

需求

部分页面通过服务器端接口返回的参数判断是否显示

用户可以添加新的分类,分类和路由的显示方式一致,拥有和路由相同的逻辑,故而采用通过服务端返回数据生成动态路由的方式解决

实现思路

1、添加路由

通过服务端接口返回的数据生成路由,是异步返回的数据,动态添加

可以通过Vue-Router提供的api,动态添加路由数据

addRoute(parentName: string, route: RouteConfig): () => void

文档说:

如果该路由规则有 name,并且已经存在一个与之相同的名字,则会覆盖它。

我想直接覆盖原有路由,这样路由位置就不变了

实际操作的时候发现:并不会覆盖,控制台会提示路由重复

2、添加时机

应该在路由跳转之前进行

router.beforeEach(async (to, from, next) => {
  // 需要有一个全局变量记录是否添加过
  if (!globalData.hasAddDynamicRoute) {
    await Store.dispatch('router/updateDynamicRoutes')
    globalData.hasAddDynamicRoute = true
  }
})

3、获取路由配置

该接口获取的路由数据是一维数组,和路由配置格式不一样

// 不要使用this.$router.options.routes
getRoutes(): RouteRecord[]

页面上显示的时候,需要从vuex获取路由信息,可以及时刷新页面数据

4、响应式路由

既然是动态路由,所以需要响应式,当路由数据发生变化时,可以及时的获取通知

通过vuex状态管理实现

// store/modules/router.js

export default {
  namespaced: true,

  state: {
    routes: [],
  },

  getters: {
    // 返回路由数据
    getRoutes(state) {
      return state.routes
    }
  },

  mutations: {
    setRoutes(state, routes) {
      state.routes = routes
    },
  },

  actions: {
    async updateDynamicRoutes({ commit }, userinfo) {
      
      // 添加动态路由
      await addDynamicRoutes()

      // 获取完整的路由信息
      const routes = router.getRoutes()

      commit('setRoutes', routes)
    },
  },
}

5、路由跳转

动态路由首次跳转的时候,动态路由还没有添加,需要转换处理

// 根据 to.name 来判断是否为动态路由
if (!to.name) {
    // 当前路由是动态的,确定是否存在
    if (router.getRoutes().findIndex((i) => i.path === to.path) !== -1) {
      next({ ...to, replace: true })
    } else {
      next('/')
    }
} else {
    next()
}

6、路由排序

添加的路由只能在最后,无法指定插入位置

通过meta元数据,添加排序字段order_value,可以在显示的时候实现排序

meta: {
    order_value: 1,
},

7、更新路由

如果数据变化,需要更新路由数据,再次添加同样会提示重复

[vue-router] Duplicate named routes definition

更新前需要先重置路由数据

// src/router/index.js

// 路由的创建
function createRouter() {
  return new VueRouter({
    mode: 'history',
    base: process.env.BASE_URL,
    routes,
  })
}

const router = createRouter()

// 重置路由
export function resetRouter() {
  const newRouter = createRouter()

  router.matcher = newRouter.matcher // reset router
}

export default router

参考文章

标签:Vue,js,添加,routes,router,动态,数据,路由
From: https://blog.51cto.com/mouday/6252600

相关文章

  • JS逆向 -- 某平台登录算法分析(RSA加密)
    一、输入账号密码,进行抓包二、F12打开开发者工具,抓包分析,password被加密了三、全局搜索password关键字,挨个分析,在箭头标记处找到了关键代码四、局部搜索,定位加密的关键点,通过JSEncrypt,setPublicKey等关键字分析是RSA加密五、代码编写1、调用RSA加密的基本代码编写functionaiyou(pw......
  • js基础---对象的序列化(JSON)与map
    序列化概念json工具类就是那个转换字符串的方法调用json静态方法,不需要new。注意事项将对象转换为json后再转换为对象,相当于做了一次深复制。当对象的字符串key属性满足不了需求时,可用map的对象属性作为keymap属性和方法map与数组之间的转换......
  • 使用 @ResponseBody 注解直接返回json字符串结果中文出现乱码
    在类上直接使用@RestController,这样子,里面所有的方法都只会返回json字符串了,不用再每一个都添加@ResponseBody!我们在前后端分离开发中,一般都使用@RestController,十分便捷!@RestControllerpublicclassUserController{//produces:指定响应体返回类型和编码@Request......
  • URL查询字符串与JS对象互转
    formatUrlQuery:function(...urlQuerys){letresult={};urlQuerys.forEach((urlQuery)=>{if(typeofurlQuery=='object'){Object.assign(result,urlQuery);}else{Object.assign(result,se......
  • Vue2入门之超详细教程九-监视属性
    1、简介监视属性watch:1.当被监视的属性变化时,回调函数自动调用,进行相关操作2.监视的属性必须存在,才能进行监视!!3.监视的两种写法:(1) newVue时传入watch配置(2) 通过vm.$watch监视深度监测:(1) Vue中的......
  • 在web中使用json json异常
    今天在web中使用Jacjson将后端对象转换为json类型传输,在pom中导入依赖,代码中也可以引用,启动tomcat后发现启动失败,报jackson的异常。以为是jacson和spring的版本冲突问题,换版本,也是不能启动。换了fastjson后在代码中导入包,发现不能正常弹出方法引用,突然发觉,可能是tomcat的lib目录没......
  • VueUse 是怎么封装Vue3 Provide/Inject 的?
    Provide/InjectProvide和Inject可以解决Prop逐级透传问题。注入值类型不会使注入保持响应性,但注入一个响应式对象,仍然有响应式的效果。Provide的问题是无法追踪数据的来源,在任意层级都能访问导致数据追踪比较困难,不知道是哪一个层级声明了这个或者不知道哪一层级或若干个......
  • 在vue3中使用elementPlus的el-select时样式穿透问题
    下拉框的option样式只能在全局样式里改,千万不能用scope,否则不生效<el-selectclass="select":popper-append-to-body="false"v-model="selectValue"placeholder="请选择"popper-class="select-option"><......
  • IDEA 设置JSP启动页面/默认页面
    一图解千惑在项目中WEB-INF中的web.xml文件中配置项目的默认启动页面。web.xml 是个XML格式的文件<?xmlversion="1.0"encoding="UTF-8"?><web-appxmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance&......
  • IDEA 设置JSP启动页面/默认页面
    一图街千惑额在项目中WEB-INF中的web.xml文件中配置项目的默认启动页面。web.xml 是个XML格式的文件<?xmlversion="1.0"encoding="UTF-8"?><web-appxmlns="http://xmlns.jcp.org/xml/ns/javaee"xmlns:xsi="http://www.w3.org/2001/XMLSchema-instanc......