程序员鸡皮
文章 分类 评论
102 3 28

站点介绍

一名PHP全栈程序员的日常......

React中高阶组件应用-登录鉴权

abzzp 2025-04-07 366 1条评论 前端 React

首页 / 正文
本站是作为记录一名北漂程序员编程学习以及日常的博客,欢迎添加微信BmzhbjzhB咨询交流......

发布于2024-07-04

我们先来看一下高阶组件的应用场景,除了之前更换网站主题颜色(Context共享)的例子, 还有一个常用的场景就是实现实现登录鉴权。我们来看代码:

import React,{PureComponent} from "react";
import Cart from './pages/Cart'

export class App extends PureComponent{
    constructor(){
        super()
        
        this.state = {
            isLogin:false
        }
    }
    
    loginClick(){
        localStorage.setItem("token","coderwhy")
        
        // this.setState({isLogin:true})
        this.forceUpdate()
    }
    
    render(){
        return (
            <div>
                App
                <button onClick={e=>this.loginClick()}>登录</button>
                <Cart></Cart>
            </div>
        )
    }
}

export default App

上面的代码中,我们通过localStorage.setItem("token","coderwhy")来模拟登录操作。现在我们希望在用户没有登录的情况下,点击购物车按钮时,能够跳转到登录页面。然后我们看一下Cart.jsx组件的代码:

Cart组件

我们先看代码:

import React,{PureComponent} from "react";
import loginAuth from '../hoc/login_auth'

export class Cart extends PureComponent{
    render(){
        return (
            <h2>Cart Page</h2>
        )
    }
}

export default loginAuth(Cart)

上面的代码中,我们通过import loginAuth from '../hoc/login_auth'来引入loginAuth高阶组件。然后我们通过export default loginAuth(Cart)来导出loginAuth高阶组件。

login_auth高阶组件

我们先看代码:

function loginAuth(OriginComponent){
    return props => {
        // 从localStorage中获取token
        const token = localStorage.getItem("token")
        
        if(token){
            return <OriginComponent {...props} />
        } else {
            return <h2>请先登录,再进行跳转到对应的页面中</h2> 
        }
    }
}

export default loginAuth

上面的代码中,我们通过const token = localStorage.getItem("token")来获取本地存储的token。如果存在token,则说明用户已经登录了,我们就渲染原来的组件;如果不存在token,就返回一个提示信息给用户。这样我们就实现了登录鉴权。最后我们看一下最终浏览器的渲染结果:

React中高阶组件应用-登录鉴权

感谢大家观看,我们下次见!

评论(1)

  1. digital banking 游客 2026-01-16 09:51 回复

    I've learn several good stuff here. Certainly price
    bookmarking for revisiting. I surprise how so much effort you put to make such a great informative website.

最新评论

  • abzzp

    以后焦虑了或者迷茫了记得回来看看[[流泪]]

  • 三十三瀑布

    我非常喜欢 出行博客。鼓舞人心查看路线。

  • 天星碼頭

    你们的博客 百分百 帮助选择路线。坚持!

  • 日落鼓掌

    信息丰富的 出行资源! 越来越棒!

  • digital banking

    My brother suggested I might like this blog. He was entirely right. This post actually made my day. You cann't imagine just how much time I had spent for this information! Thanks!

  • 碧海藍灣

    我热爱, 写得很实在。你的博客 就是 最好的例子。很出色。

  • digital banking

    I've learn several good stuff here. Certainly price bookmarking for revisiting. I surprise how so much effort you put to make such a great informative website.

  • fintechbase

    It's not my first time to pay a visit this web page, i am visiting this website dailly and get good facts from here every day.

  • fintechbase

    Hello, i think that i saw you visited my site so i got here to go back the want?.I'm trying to find things to improve my web site!I suppose its adequate to use a few of your concepts!!

  • fintechbase

    Touche. Outstanding arguments. Keep up the great effort.

日历

2026年01月

    123
45678910
11121314151617
18192021222324
25262728293031

文章目录

站点公告
本站是作为记录一名北漂程序员编程学习以及日常的博客,欢迎添加微信BmzhbjzhB咨询交流......
点击小铃铛关闭
配色方案