- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
在最终弄清楚登录和基于用户 Angular 色的路由的第一步之后,我开始在各种 URL 上设置一些身份验证保护措施。
这看起来很简单,但我遇到了一个错误,似乎找不到具有类似用例的示例。我见过的其他人谁有这个错误似乎错误地将他们的路由器实例命名为“路由器”以外的东西。据我所知,我没有。我正在使用带有 webpack 的 vue-cli 模板,仅供引用。
来 self 的 index.js:
Vue.use(VueRouter)
const router = new VueRouter({
routes: [
{
path: '/'
},
{
path: '/login',
component: Login
},
{
path: '/trucker',
component: Trucker,
meta: { requiresAuth: true, truckerAuth : true, dispatchAuth: false },
children: [
{
path: '/loads',
component: Loads
}
]
},
{
path: '/dispatch',
component: Dispatch,
meta: { requiresAuth: true, truckerAuth : false, dispatchAuth: true },
children: [
{
path: '/drivers',
component: Drivers
}
]
},
]
})
router.beforeEach((to, from, next) => {
if(to.meta.requiresAuth) {
const employeeId = window.localStorage.getItem('employee_id')
if(!employeeId) {
next('/login')
}
else if(to.meta.truckerAuth) {
const employeeId = window.localStorage.getItem('employee_id')
if(employeeId === 3) {
next()
}else {
next('/login')
}
} else if(to.meta.dispatchAuth) {
const employeeId = window.localStorage.getItem('employee_id')
if(employeeId === 2) {
next()
}else {
next('/login')
}
}
}else {
next()
}
})
来 self 的 main.js:
import router from './router'
new Vue({
el: '#app',
router,
components: { App },
template: '<App/>'
})
关于导致此错误的原因的任何线索?
更新:我回过头来删除了一些东西,直到它再次工作——结果是将我以前的 export default new Router
语法更改为 const router = new Router
(为了以防万一,将普通的“Router”更改为 VueRouter,以匹配示例)实际上是导致此错误的原因。仍然不确定为什么会发生这种情况。
最佳答案
意识到我只需要将我的导航守卫移动到 main.js 文件中,而不是将它放在带有路由器的 index.js 中。
所以更正后的文件看起来像:
index.js:
Vue.use(Router)
export default new Router({
routes: [
{
path: '/'
},
{
path: '/login',
component: Login
},
{
path: '/trucker',
component: Trucker,
meta: { requiresAuth: true, truckerAuth : true, dispatchAuth: false },
children: [
{
path: '/loads',
component: Loads
}
]
},
{
path: '/dispatch',
component: Dispatch,
meta: { requiresAuth: true, truckerAuth : false, dispatchAuth: true },
children: [
{
path: '/drivers',
component: Drivers,
children: [
{
path: 'calendar',
component: Calendar
}
]
}
]
},
]
})
主要.js:
new Vue({
el: '#app',
router,
components: { App },
template: '<App/>'
})
router.beforeEach((to, from, next) => {
if(to.meta.requiresAuth) {
const employeeId = window.localStorage.getItem('employee_id')
if(employeeId == null) {
next('/login')
}
else if(to.meta.truckerAuth) {
const employeeId = window.localStorage.getItem('employee_id')
console.log(employeeId)
if(employeeId === 3) {
next('/trucker')
}else {
next('/')
console.log(employeeId)
}
} else if(to.meta.dispatchAuth) {
const employeeId = window.localStorage.getItem('employee_id')
if(employeeId === 2) {
next()
}else {
next('/')
}
}
}else {
next()
}
})
关于javascript - Vue-router 仅在添加全局导航守卫后抛出 "Cannot read property ' matched' of undefined"错误,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/51272704/
我如何使用 if 守卫的理解? type Error = String type Success = String def csrfValidation(session:Session,
我试图深入理解 Angular,所以我阅读了 the docs这非常有帮助。 现在我正在研究守卫。我在文档中阅读了此声明。 The router checks the CanDeactivate an
是否可以批量guard's 观看通知? 例如,如果移动了一个子文件夹,watch 会为每个文件发出一个事件。我真正想要的是一个通知,而不是几个,如果有什么变化。 最佳答案 虽然这不是批量更改,因此没有
我正在使用 Guard gem 在开发的某些时候,我只需要跟踪一个特定的文件或几个文件,而不是整个项目。 是否有一些方便的方法来临时跟踪特定文件? 我知道这可以通过修改保护文件来完成,但我认为这不是一
已解决 真正帮助我的是我可以#include .cpp 文件中的 header 而不会导致重新定义的错误。 我是 C++ 新手,但我有一些 C# 和 Java 编程经验,所以我可能会遗漏一些 C++
是否有可能保证在范围退出时完成的变量。 具体来说,我想要一个守卫:在初始化时调用特定函数,并在作用域退出时调用另一个特定函数的东西。 最佳答案 这最好明确地完成: class Guard def
我有一个类型代表我的应用程序的游戏状态,对于这个问题假装它很简单,例如: Game { points :: Int } 我用 State monad 定义我的游戏逻辑。 type GameState
这个问题在这里已经有了答案: Why is GHC complaining about non-exhaustive patterns? (3 个答案) 关闭 7 个月前。 我有以下代码,它定义了一
我知道在头文件中使用 include guards 是为了防止某些东西被定义两次。不过,使用此代码示例完全没问题: foo.c #include #include #include "bar.h"
这个问题在这里已经有了答案: Why is GHC complaining about non-exhaustive patterns? (3 个答案) 关闭 7 个月前。 我有以下代码,它定义了一
我知道 guard 在 Swift 中的作用。我已经阅读了有关使用 guard 或 if let 的问题。但是,guard (condition) else { return } 和if !condi
我正在试验 Xcode 提供的不同分析选项,但是当我在 Diagnostics 选项卡中启用 Guard Malloc 选项并尝试运行时,我收到了这个错误立即崩溃: dyld: could not l
这是我的 canDeactivate 守卫,它可以工作。但是我不想在使用提交按钮时调用守卫。只有当我通过任何其他方式导航时。怎么办? import { Injectable } from '@angu
嗨,这让我发疯。找了半天也没找到解决方法。 如何为 Guardfile 中的所有守卫触发“run_all”。 当我在 shell 中运行“guard”时,我希望它假装所有文件都已更改并触发所有守卫。
我想知道是否有守卫(断言)函数的 golang 命名约定?我用谷歌搜索了一下,但找不到任何确定的东西。我在“The Go Programming Language”一书中读到,使用“必须”前缀是一种常
我正在尝试使用 guard 的 --listen-on带有 vagrant 的选项,如概述 here ,但我无法让它工作。 如果我添加 config.vm.network :forwarded_por
我目前有一个路线守卫,例如 export class EntityGuard implements CanActivate { constructor(private readonly route
我正尝试在 less 中创建一个高度可定制的按钮 mixin。例如,我希望客户能够进入他们的 .less 文件并写入: .my-button { .btn(@bg: #FFF, @font:
这个问题在这里已经有了答案: #pragma once vs include guards? [duplicate] (13 个答案) 关闭 3 年前。 我正在浏览 Implementation d
这个问题在这里已经有了答案: Is #pragma once a safe include guard? (15 个答案) 关闭 3 年前。 我正在开发一个已知只能在 Windows 上运行并在 V
我是一名优秀的程序员,十分优秀!