导航守卫(也叫路由守卫)

导航守卫(也叫路由守卫)

  1. 作用: — 类似 【保安】
  • 守卫路由
      • 举例: 携带数据进
      • 举例: 事情完成才能出
  1. 导航守卫一共有三种形式
- A: 全局导航守卫
. 全局前置守卫 router.beforeEach(fn)
  1. fn中有三个参数
    • to:表示要去哪里
    • from:表示从哪里来
    • next:表示通不通过
  • 关于next的使用
    • next() 等价于 next( true ) 表示可以从当前路由跳转到目标路由
    • next( false ) 表示不通过, 表示从当前路由跳转不到目标路由
    • next(’/login’) 等价于 next({path:’/login’}) 跳转指定的路由
    • next(’/login’) 等价于 next({path:’/login’,params,query})
    • next( fn ) 数据预载
全局前置守卫是写在入口文件 main.js 中的,在进入路由前执行

// 全局前置路由守卫
router.beforeEach( (to,from,next) =>{
    const name = localStorage.getItem('name');//查看本地存储上是否有name对象
    if( name || to.path === '/login'){//短路逻辑,有就可以继续执行,没有就跳转到登录页面
        next()
    }else{
     next( '/login' )//跳转登录页面
    }
})


// 全局后置路由守卫 router.afterEach(fn),表示离开当前路由时执行
router.afterEach( (to,from,next)=> {
    if(to.path === '/user'){//当to的path值等于这个时
        alert('确定进入user吗')
    }
})


  1. 全局的解析守卫
  2. 在 2.5.0+ 你可以用 router.beforeResolve 注册一个全局守卫。这和 router.beforeEach 类似,区别是在导航被确认之前,同时在所有组件内守卫和异步路由组件被解析之后,解析守卫就被调用。
  3. 必须保证整个项目的守卫和异步路由组件解析完成
3. 全局的后置守卫 afterEach(fn)
  • 可以做一些用户友好提示
代码在上面
B: 路由独享守卫
  • 写在路由表中的守卫钩子
  • 针对的是和当前路由相关的,那么其他与之不相关的路由,它是无法监听它的变化情况的

{
path: '/user',
component: User,
beforeEnter: ( to,from,next ) =>{
    // console.log(to)
    const name = localStorage.getItem('name');//判断本地存储有没有name对象
    if( name){//存在就可以继续执行
        next()
    }else{
        setTimeout(()=>{
                alert('你还没有登录,点击跳转登录')//不存在就弹窗告诉没有登录,点击登录
                next('/login')
            },0)
       }
    }
},


C: 组件内守卫
  • 有三种
    • beforeRouteEnther( (to,from,next) =>{} ) 进入组件时触发【 //注意写法,fore route 】
    • beforeRouteUpdate( (to,from,next) =>{} ) 数据改变时触发
    • beforeRouteLeave( (to,from,next) =>{} ) 离开组件时触发
  • 组件内的前置守卫 beforeRouteEnter((to,from,next)=>{})
    • 导航进入组件时,调用
    • this是访问不到的,如果非要访问this ,必须通过 next(vm=>{})访问
    • 因为组件此时没有创建,所以没有this
    • 案例: 数据预载(进入组件前就获得数据)
next(vm => { //vm指的就是组件
    const result = JSON.parse(res.data.slice(7,-1)).rp_result.categorys
    vm.$set(vm.category,'categorys',result)
})
组件内的后置守卫
  • 离开组件时,调用
  • this是可以访问到
//判断两个输入框是否有值输入,有就可以直接离开,没有弹窗告诉确定是否离开,防止误触
beforeRouteLeave(to,from,next){
    if(this.username && this.pwd){
        next()
    }else{
        if(confirm('你确定要离开吗')){//返回一个布尔值
            next()
        }else{
            next(false)
        }
    }
}


组件内的更新守卫( 路由传参和路由的接参 )
  • 在当前路由改变,但是该组件被复用时调用
  • 举例来说,对于一个带有动态参数的路径 /foo/:id,在 /foo/1 和 /foo/2 之间跳转的时候,
  • 由于会渲染同样的 Foo 组件,因此组件实例会被复用。而这个钩子就会在这个情况下被调用。
  • 可以访问组件实例 this

在这里插入图片描述
在这里插入图片描述
在这里插入图片描述

### 路由导航守卫的概念 路由导航守卫是一种用于控制页面跳转逻辑的机制,在前端框架中广泛应用于权限验证、数据预加载以及页面访问拦截等功能。以下是 Vue.js 和 React 中实现路由导航守卫的具体方法。 --- ### Vue.js 中的路由导航守卫 Vue Router 提供了全局守卫路由独享守卫和组件内的守卫三种方式来实现导航守卫功能[^1]。 #### 全局前置守卫 (`beforeEach`) 通过 `router.beforeEach` 方法可以在每次路由切换前执行特定逻辑: ```javascript // 定义全局前置守卫 router.beforeEach((to, from, next) => { if (to.meta.requiresAuth && !isAuthenticated()) { // 如果目标路由需要认证且未登录,则重定向到登录页 next('/login'); } else { next(); // 继续导航 } }); ``` #### 路由独享守卫 (`beforeEnter`) 可以通过在路由定义时设置 `beforeEnter` 来为某个具体路由添加单独的守卫逻辑: ```javascript const routes = [ { path: '/dashboard', component: Dashboard, meta: { requiresAuth: true }, beforeEnter: (to, from, next) => { if (!isAuthenticated()) { next('/login'); // 非授权用户重定向至登录页 } else { next(); } } } ]; ``` #### 组件内守卫 还可以在组件内部定义三个生命周期钩子函数:`beforeRouteEnter`, `beforeRouteUpdate`, 和 `beforeRouteLeave`,分别对应进入组件、更新组件和离开组件时的行为。 ```javascript export default { beforeRouteEnter(to, from, next) { console.log('即将进入该组件'); next(vm => { vm.initData(); // 初始化数据 }); }, beforeRouteLeave(to, from, next) { const confirmLeave = window.confirm('您确定要离开吗?'); if (confirmLeave) { next(); } else { next(false); } } }; ``` --- ### React 中的路由导航守卫 React 并没有像 Vue Router 这样的内置守卫机制,但可以通过自定义高阶组件(HOC)或者条件渲染的方式实现类似的导航守卫效果[^3]。 #### 使用 HOC 实现守卫 创建一个通用的高阶组件来封装守卫逻辑: ```javascript import React from 'react'; import { Redirect } from 'react-router-dom'; function withAuthGuard(Component) { return function AuthenticatedComponent(props) { const isAuthenticated = props.isAuthenticated; if (!isAuthenticated) { return <Redirect to="/login" />; } return <Component {...props} />; }; } export default withAuthGuard; ``` 然后将其包裹在受保护的组件外部使用: ```javascript import React from 'react'; import { Route } from 'react-router-dom'; import ProtectedPage from './ProtectedPage'; import withAuthGuard from './withAuthGuard'; const App = () => ( <Route path="/protected" render={(props) => ( <withAuthGuard isAuthenticated={false}> <ProtectedPage /> </withAuthGuard> )} /> ); export default App; ``` #### 使用条件渲染 另一种简单的方法是在组件内部直接判断用户的登录状态并决定是否允许访问: ```javascript import React from 'react'; import { Redirect } from 'react-router-dom'; class SecurePage extends React.Component { constructor(props) { super(props); this.state = { isLoggedIn: false, // 假设初始状态下未登录 }; } componentDidMount() { fetchUserStatus().then((isLoggedIn) => { this.setState({ isLoggedIn }); }); } render() { if (!this.state.isLoggedIn) { return <Redirect to="/login" />; } return <div>这是安全页面</div>; } } ``` --- ### 总结 无论是 Vue.js 还是 React,都可以灵活地实现路由导航守卫功能。Vue Router 提供了更加直观和便捷的支持,而 React 则依赖于开发者自行设计解决方案。两种方式各有优劣,需根据具体的业务需求和技术栈特点选择合适的方案[^1][^3]。 ---
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值