我们先来看一下高阶组件的应用场景,除了之前更换网站主题颜色(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
,就返回一个提示信息给用户。这样我们就实现了登录鉴权。最后我们看一下最终浏览器的渲染结果:
感谢大家观看,我们下次见!
of course like your web site but you need to test the spelling on quite a few of your posts. A number of them are rife with spelling problems and I in finding it very troublesome to inform the reality nevertheless I will surely come again again.
新年快乐!
十天看一部剧,还可以吧
@梦不见的梦 行,谢谢提醒,我优化一下
网站的速度有待提升,每次打开都要转半天还进不来呢
@React实战爱彼迎项目(二) - 程序员鸡皮 哪里有问题了,报错了吗?
@Teacher Du 那是怕你们毕不了业,我大学那会儿给小礼品
我们大学那会,献血还给学分~
@ab 我想去学网安,比如网警,但分也贼高😕
@夜 加油,你一样也可以成为程序员的,需要学习资料可以V我