vue动态路由配置 (vue3 动态路由)
整理分享vue动态路由配置 (vue3 动态路由),希望有所帮助,仅作参考,欢迎阅读内容。
内容相关其他词:vue动态路由写法,vue3.0动态路由,vuerouter动态路由,vue3 动态路由,vue动态路由配置实现,vue动态路由配置方法和过程,vue动态路由配置实现,vue动态路由配置实现,内容如对您有帮助,希望把内容链接给更多的朋友!
vue-动态路由的实现能够传递参数的路由即为动态路由应用场景:从列表页跳转到好肆让详情页实现步骤:一.先创建动态路由组件detail.vue(一级路由组件)二、路由配置(router/index.js)importdetailfrom'@/views/detail.vue'ath:'/detail/:id'友局等价于'detail/2'--2即是传递的idid属性名要和detail中雹激接收参数名一致vue动态路由template el-containerstyle="height:vh;border:1pxsolid#eee" el-asidewidth="px"style="background-color:rgb(,,)" !--:default-openeds="['1','3']"表示默认打开第一个和第三个菜单-- !--1对应了el-submenuindex="1" 2对应了el-submenuindex="2"-- !--el-submenuindex="1-1表示把el-submenu当作是第一个导航的第一个子项-- 陵正念 !-- :router="true使用vue-router的模式,启用该模式会在激活导航时以index作为path进行路由跳转-- !--default-active="/index/users"-- !--★ :default-openeds不可以直接使用['1']需要使用一个变量openList代替因为值随时会变如果写的 清源 是['1']那么就永远不会改变会出现点击二级菜单一级菜单会缩起来的情况-- !--default-active="/index/users"表示一进入页面就默认激活/index/user导航菜单 default-active不能直接写死值路径要用变量代替使用**路由解决-- !--unique-opened 是否只保持一个子菜单的展开boolean默认是false-- el-menu :default-openeds="openList" :router="true" :default-active="pagepath" :unique-opened="true" !--index接收的字符串类型,(i+1)是数字类型,所以使用toString方法转成字符串传给index-- !--因为i是从0开始的所以需要加1-- el-submenu :index="(i+1).toString()" v-for="(v,i)innavList" :key="i" templateslot="title" iclass="el-icon-menu"/i{{v.authName}}/template !--子选项需要改成例如:1-1格式以字符串的形式传给index属性-- !--因为子选项也是一个数组所以需要再次循环-- !--:index="'/index/'+item.path"路径最前面必须加上/否则会出现路径覆盖的问题-- el-menu-item :index="'/index/'+item.path"尺困 v-for="(item,index)inv.children" :key="index" {{item.authName}}/el-menu-item /el-submenu /el-menu /el-aside el-container el-headerstyle="text-align:right;font-size:px" el-dropdown iclass="el-icon-setting"style="margin-right:px"/i el-dropdown-menuslot="dropdown" el-dropdown-item查看/el-dropdown-item el-dropdown-item新增/el-dropdown-item el-dropdown-item删除/el-dropdown-item /el-dropdown-menu /el-dropdown span王小虎/span /el-header el-main router-view/router-view /el-main /el-container /el-container/templatescriptimportaxiosfrom"axios";exportdefault{ data(){ return{ navList:[], openList:["1"], pagepath:"/index/users", }; }, watch:{ /*当路由发生变化的时候,就把最新的*给到pagepath变量 作用是为了保持路由菜单栏的高亮显示以及解决点击不跳转的bug*/ $route:{ handler:function(newV){ this.pagepath=newV.path; }, immediate:true, }, }, created:function(){ this.getNavList(); }, methods:{ getNavList:function(){ axios .get("/mock/menu.json",{ headers:{ Authorization:localStorage.token, }, }) .then((res)={ let{data,meta}=res.data; /*数据获取成功*/ if(meta.status==){ this.navList=data; /*动态添加路由菜单*/ /*因为第一个路由是默认,所以我们从第二个路由开始动态添加*/ /*slice不会改变原数据而splice会*/ letarr=this.navList.slice(1,3); /*循环路由数组动态添加路由*/ arr.forEach(v={ /*我们尽量使用v.children[0].path原因是我们的路径名用的是子路由的*/ /*如果我们直接写死v.children[0].path会导致只有一个子路由路径被动态添加了 如果有多个,就无法生效了,所以我们要二次循环v.children,从而实现多个二级子路由 能够被动态的添加*/ v.children.forEach(r={ this.$router.addRoute("index",{ path:r.path, name:r.path, /*把名字改成我们页面的名称例如CategoriesView.vue*/ component:()=import(`@/views/${r.path.substring(0,1).toUpperCase()+r.path.substring(1)}View.vue`), }); }) }); console.log(this.$router) }else{ /*防止数据获取失败,给出相应的后台提示*/ this.$message.error(meta.msg); } }) .catch((err)={ console.log(err); }); }, },};/scriptstylescoped.el-header{ background-color:#b3c0d1; color:#; line-height:px;}.el-aside{ color:#;}/stylevue项目动态路由怎么做vue项目实现动态路由的方式大体可分为两种:前端这边把路由写好,登录的时候根据用户的角色权限来动态展示路由,(前端控制路由)详情可参阅花裤衩大佬的项目手把手...后台传来当前用户对应权限的路由表,前端通过调接口拿到后处理(后端处理路由)这两种方法各有优点,效果都能实现,我们公司是通过第二中种方法实现的,原因就是公司项目里有一个专门的用户中心,里边逻辑很复杂,不好返给前端用户权限,担心路由放到前端不安全(以上的话是公司的后台同学讲的),那好吧,抱着都试试、锻炼下自己能力的态度,我们搞了第二种方法。大体步骤:*路由-后台取到路由-保存路由到localStorage(用户登录进来只会从后台取一次,其余都从本地取,所以用户,只有退出在登录路由才会更新)菜单名字menName;菜单路径menPath;菜单指向的资源menuUrl(也就是组件*,一般从views层级开始写)前端登录后通过接口请求拿到菜单数据后,menName---namemenPath---pathmenuUrl----components文件转换时,用到这个此蔽方法找组件资源把menuUrl可以变为components的格式,转为组件文件生成路由表可以再过滤一遍生成的路由表下面这个方法找到views底下所有的组件资源路由表里路由的组件在所有组件资源里没找到时,将该路由的path变为/getRouter.push({path:'*',redirect:'/',hidden:true});router.addRoutes(getRouter);//动态添加路由前置工作:配置项目路由文件,该文件中没有路由,或者存在一部分公共路由,即没有权限的路由每个路由都使用到组件Layout,这个组件是整体的页面布局:左侧菜单列,右侧页面,所以children下边的森饥州第一级路由就是你自己的开发的页面,meta里包*路由的名字,以及路由对应的icon;因为可能会有多级菜单,所以会出现children下边嵌套children的情况;路由是数组格式实际前端需要的component是component:()=import('@/views/content/classify'),因为有多级路由的出现,所以要写成遍历递归方法,确保把每个component转成组件对象因为后台传回的是字符串,所以要把加载组件的过程封装成一个方法,用这个方法在遍历中使用;详情查看项目里的router文件夹下的_import_development.js和_import_production.js文件Layout我放的目录跟其他文件的目录不一样,所以我在遍历里单独处理,各位小伙伴可自己调整哈beforeEach路由*,进入判断,如果发现本地没有路由数据,那就利用axios后台取一次,取完以后,利用localStorage存储起来,利用addRoutes动态添加路由,ps:beforeEach好坏啊,一步小心就进入到了他的死循环,浏览器都tm崩了,得在一开始就加判断,拿到路由了,就直接next(),嘤嘤嘤global.antRouter是为了传递数据给左侧菜单组件进行渲染上边第三步会给global.antRouter赋值,这是一个全局变量(可以用vuex替代),菜肢李单那边拿到路由,进行渲染vue动态路由/路由权限解决方案路由权限思路:1.菜单栏/导航栏(一级权限)在登录成功后,获取后端的权限数据,根据铅扮权限数据,展示对应的路由导航或菜单即可;2.界面的控制如果用户没有登录,用户手动在*栏输入路由*,则需要跳转到登录界面.如果用户已经登录,用户手动输入的非权限内的路由*,则给他跳转到界面.3.按钮的搭游控制(二级权限)在页面中,有些账号有:添加,删除,修改,增加等权限,有些没有.没有权限的账号在这个页面只是可以浏览页面中的数据,需要对这些按钮禁用or隐藏。4.请求和响应的控制(这一步其实后端也会根据token判断身份信息,来返回数据,可以省略)如果用户通过非常规的手段(可能是同行),比如通过浏览器f将禁用的按钮disabled改成false,隐藏的按钮apacity:0改成了1,这些按钮就可以使用了,此时需要对按钮点击后发出的请求作出*.login.vuehome.vue(elment-ui)侧边导航栏store.jsrouter.js动态路需知激销两个地方调用:1login.vue中登录成功后立即执行动态路由函数2app.vue中,在根组件中添加执行动态路由函数,这样每一次用户刷新,就会执行,否则刷新之后,动态路由就没了思路3:按钮的控制(二级权限):这里我是通过自定义指令来实现对按钮(增,删,改等二级权限按钮)的显示隐藏。更简单直接的方式,直接就在html中对button添加v-if显示隐藏即可import'./utils/permission.js'--main.js中引入文件,嫌麻烦直接在main.js中写4服务器返回状态码,代表token超时ortoken被串改or未传token,此时强制跳转到登录页重新登录搭建一个良好的*网络环境,不仅可以让你更好地工作和学习,还可以让你畅快地享受数字化生活。希望本文所介绍的内容可以对你有所帮助。