이 글은 Vue에 대한 관련 지식을 주로 소개하며, Vue의 다양한 권한 제어 및 관리 구현 아이디어를 자세히 소개하고 있으니 관심 있는 친구들이 함께 살펴보시면 좋겠습니다.
clear()
메소드를 통해 로컬 데이터를 삭제하고, window.location을 통해 현재 페이지를 새로고침하세요. vuex 데이터를 삭제하기 위한 점프 후 reload()
clear()
方法清除本地数据,跳转后通过window.location.reload()
刷新当前页面,可实现清除vuex数据的操作initDynamicRoutes
,分别是登录成功时和页面创建时,否则动态路由为默认值,刷新无法访问import Vue from 'vue' import VueRouter from 'vue-router' import Layout from '@/layout' import store from '@/store' Vue.use(VueRouter) // 动态路由规则 const tableRule = { path: '/table', name: 'table', component: () => import('@/views/table/index.vue') } const imageRule = { path: '/image', name: 'image', component: () => import('@/views/image') } const userRule = { path: '/users', name: 'users', component: () => import('@/views/users') } // 路由规则和字符串的映射关系 const ruleMapping = { table: tableRule, users: userRule, image: imageRule } //静态路由 const routes = [ { path: '/login', // name: 'login', // 这里如果有name 控制台会提示 component: () => import('@/views/login') }, { path: '/', component: Layout, children: [ { path: '', // name: 'home', component: () => import('@/views/home') }, { path: '/chart', component: () => import('@/views/chart') } ] } ] const router = new VueRouter({ routes }) //路由权限:用户登录后接口返回,存储到本地缓存 const rightList = [ { id: 1, authName: "基本页面", icon: "el-icon-connection", children: [ { id: 11, authName: "表格页面", icon: "el-icon-s-grid", path: "table", rights: ["view", "edit", "add", "delete"] }, { id: 12, authName: "素材页面", icon: "el-icon-s-marketing", path: "image", rights: ["view", "edit", "add", "delete"] } ] }, { id: 2, authName: "用户权限", icon: "el-icon-set-up", children: [ { id: 21, authName: "权限页面", icon: "el-icon-s-custom", path: "users", rights: ["view", "edit", "add", "delete"] } ] } ]; //在登录(login.vue)、页面刷新(App.vue)的时候,调用initDynamicRoutes export function initDynamicRoutes () { // 根据二级权限 对路由规则进行动态的添加 const currentRoutes = router.options.routes rightList.forEach(item => { // 如果是没有子路由的话 就直接添加进去 如果有子路由的话就进入二级权限遍历 if (item.path) { const temp = ruleMapping[item.path] // 路由规则中添加元数据meta temp.meta = item.rights currentRoutes[1].children.push(temp) } item.children.forEach(item => { // item 二级权限 const temp = ruleMapping[item.path] // 路由规则中添加元数据meta,用于按钮权限控制 temp.meta = item.rights currentRoutes[1].children.push(temp) }) }) // 添加路由规则 router.addRoutes(currentRoutes) } export default router
v-permission
binding.value
获取到自定义制定属性值的数据vuex|本地缓存
中获取到的按钮权限数据是否包含了自定义指令包含的权限el.style.display = “none”
,或者使用el.parentNode.removeChild(el)
删除当前 按钮元素<el-button v-permission="[$route.path, 'add']">添加</el-button> directives: { // 检测全选的指令 permission: { // 绑定此指令的标签插入到dom节点触发 inserted(el, bind) { // el:绑定该指令标签 // bind:对象格式 当前绑定指令标签上的数据情况 // 获取按钮上的value值,就是用户当前要使用的权限和请求的路由地址 let value = bind.value//['/user','add'] //模拟后端返回的当前角色对应的权限 let rules = { '/menu': ['add', 'edit'], "/user": [ 'edit', 'remove'], "/goods": ['add'] } // 根据访问的路由地址获取该模块的操作权限 let allow = rules[value[0]] // 检测当前操作是否合法 if (!allow.includes(value[1])) { // 不合法隐藏操作按钮 el.style = "display:none" } } } }
数据权限
initDynamicRoutes</code를 호출해야 합니다. > 두 번, 즉 로그인이 성공할 때와 페이지가 생성될 때. 그렇지 않으면 동적 경로가 기본값이 되며 새로 고쳐도 액세스할 수 없습니다. 3. 버튼 권한</li></ul><p> 소위 버튼 권한은 특정 메뉴의 인터페이스에서 백엔드에서 반환된 역할의 현재 작업 모듈에 대응해야 함을 의미합니다. 버튼 권한 데이터는 조작할 수 있는 버튼을 보여줍니다. <a href="//m.sbmmt.com/course/list/18.html" target="_blank"></a><ol><br/>버튼 권한 제어를 구현하려면 vue의 사용자 정의 지침을 사용해야 합니다. 먼저 버튼 권한 제어를 위한 명령을 만들어야 합니다. 이 명령의 이름을 다음과 같이 정의합니다: <code>v-permission
bind.value
🎜< /ol>🎜🎜vuex|local 캐시
에서 얻은 버튼 권한 데이터에 사용자 지정 명령에 포함된 권한이 포함되어 있는지 여부🎜el.style.display = “none”
설정 또는 el.parentNode.removeChild(el)
사용 현재 버튼 요소 삭제🎜import axios from 'axios' import router from '@/router' const request = axios.create() // 映射 const actionMapping = { get: 'view', post: 'add', put: 'edit', delete: 'delete' } // request.defaults.baseURL = 'http://127.0.0.1:7001' // 注释掉之后调的接口将是Mock数据 // 请求拦截器 request.interceptors.request.use(req => { // console.log(req.url) // console.log(req.method) if (req.url !== '/login' && req.url !== '/roles') { // 不是登录的请求 也不是获取权限的请求 则在请求头中加入token 不知道如何使用Mock来验证请求头中的token 故此处注释 // req.headers.Authorization = sessionStorage.getItem('token') const action = actionMapping[req.method] // 判断非权限范围内的请求 // console.log(router) const currentRight = router.currentRoute.meta // console.log(currentRight) if (currentRight && currentRight.indexOf(action) === -1) { // 没有权限 alert('没有权限') return Promise.reject(new Error('没有权限')) } } return req }) export default request
데이터 권한
은 다른 역할을 가진 사용자가 보는 테이블 데이터입니다. 다릅니다🎜🎜예를 들어 Zhang San이 프로젝트 관리자인 경우 , 그는 특정 비즈니스 형식의 모든 데이터 및 필드 정보를 볼 수 있습니다🎜🎜Li Si는 일반 직원이며 테이블에서 자신의 데이터만 볼 수 있습니다🎜🎜코드 구현: 프런트 엔드가 에 있습니다. 요청 헤더가 균일하게 캡슐화됩니다. 마지막으로 백엔드는 사용자 권한을 감지하고 구문 분석하여 해당 데이터를 반환합니다. 🎜vue Video Tutorial🎜"🎜🎜🎜위 내용은 Vue의 다양한 권한 제어 및 관리 구현 아이디어에 대한 자세한 설명의 상세 내용입니다. 자세한 내용은 PHP 중국어 웹사이트의 기타 관련 기사를 참조하세요!