React useContext与useReducer函数组件使用
更新时间:2023年02月06日 10:24:47 作者:碰磕
useContext和useReducer 可以用来减少层级使用, useContext,可以理解为供货商提供一个公共的共享值,然后下面的消费者去接受共享值,只有一个供货商,而有多个消费者,可以达到共享的状态改变的目的
useContext
介绍
与class中写法对比减少了代码量,省去了返回回调函数获取传来的值
使用
/** * useContext(减少组件层级) */ import React, { useState, useRef, useContext } from 'react'; const GlobalContext=React.createContext()//创建Context对象 function FilmItem(){ const value=useContext(GlobalContext) console.log(value)//可以拿到传过来的value return( <div> <span>{value.name}CSDN碰磕</span> </div> ) } export default function MyContext() { return ( //供应商 <GlobalContext.Provider value={{ name:"碰磕", age:18 }}> <div> Context方案 <FilmItem></FilmItem> </div> </GlobalContext.Provider> ); }
通过**useContext(GlobalContext)**就可以获取到传来值
useReducer
介绍
将多个state放到对象中,进行统一管理
使用(简单示例实现计算器)
/** * useReducer(减少组件层级) */ import React, {useReducer } from 'react'; //处理函数 const reducer=(pervState,action)=>{ //第一个参数是原数据,第二个参数是传来的数据 let newarr={...pervState};//定义新对象拷贝 switch(action.type){ case "pengke-jian": newarr.count-- return newarr case "pengke-jia": newarr.count++ return newarr default: return pervState } } //外部的对象 const intialState={ count:0, } export default function MyReducer() { const [state,dispatch]=useReducer(reducer,intialState) return ( <div> <button onClick={()=>{ dispatch({ type:"pengke-jian" }) }}>-</button> <span>{state.count}</span> <button onClick={()=>{ dispatch({ type:"pengke-jia" }) }}>+</button> </div> ) }
将useContext与useReducer整合
实现多个组件通过他们俩互相通信传值…
/** * useReducer+useContext */ import React, {useContext, useReducer } from 'react'; const intialState={ num1:"666", num2:"碰磕" } const reducer=(state,action)=>{ let newarr={...state}; switch(action.msg){ case "change-num1": newarr.num1=action.value return newarr case "change-num2": newarr.num2=action.value return newarr default: return newarr } } const GlobalContext = React.createContext(); export default function MyReducer2() { const [state,dispatch]=useReducer(reducer,intialState) return ( <GlobalContext.Provider value={ { state,dispatch } }> <div> <Children1 /> <Children2 /> <Children3 /> </div> </GlobalContext.Provider> ) } function Children1(){ const {dispatch}=useContext(GlobalContext)//这里传值 return <div style={{background:"red"}}> <button onClick={()=>{ dispatch({ msg:"change-num1", value:"被我修改了num1哈哈哈" }) }}>改变值1</button> <button onClick={()=>{ dispatch({ msg:"change-num2", value:"被我修改了num2哈哈哈" }) }}>改变值2</button> </div> } function Children2(){ const {state}=useContext(GlobalContext)//拿到值 return <div style={{background:"orange"}}>Children2---{state.num1}</div> } function Children3(){ const {state}=useContext(GlobalContext)//拿到值 return <div style={{background:"skyblue"}}>Children3---{state.num2}</div> }
到此这篇关于React useContext与useReducer函数组件使用的文章就介绍到这了,更多相关React useContext与useReducer内容请搜索脚本之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持脚本之家!
相关文章
React Router V5:使用HOC组件实现路由拦截功能
这篇文章主要介绍了React Router V5:使用HOC组件实现路由拦截功能,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下2023-03-03React函数组件useContext useReducer自定义hooks
这篇文章主要为大家介绍了React函数组件useContext useReducer自定义hooks示例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪2022-08-08
最新评论