06-redux中的hook
创始人
2024-05-30 04:58:18

知识点06-redux的hook

在函数组件中要和redux连接,分为两个步骤

前提状态机已经主备就绪

  1. 注入store到根组件

    在函数组件中,使用Provider包裹根组件,并将store注入这一步,依旧是不能少的

     import store from "./redux/store"import { Provider } from "react-redux"ReactDOM.render(store}>,document.getElementById('root'));
    
  2. 在函数组件中,需要使用第三方的hook来完成状态机获取

    在类组件中,我们要获取redux中的数据,使用的方法是先引入 connect高阶函数,传入一个 mapStateToProps作为其参数,并在mapStateToProps函数中将redux中的值返回出去,以这样的的形式来获取redux中的数据。

    在函数组件中,提供了一种比上面使用起来更加方便的方式,也就是使用redux中的一些hook函数来实现redux中数据的获取

    useDispatch:产生一个disptach对象派发action

    useSelector:作用类似于mapStateToProps,获取到状态机state对象,对数据进行刷选

     import {useDispatch,useSelector} from "react-redux"import {incrementAC,decrementAC,addCartAC} from "../../redux/actions"const dispatch = useDispatch()//使用useSelector获取到redux的数据const {courseList,cartList} = useSelector(state=>({courseList:state.shopRD.courseList,cartList:state.shopRD.cartList}))//使用dispatch派发actionconst addCart = (index,id)=>{dispatch(addCartAC(index))}courseList} addCart={addCart}>
    

官方提供的hook:useState、useEffect、useRef、useMemo、useCallback(扩展)

第三方提供:useHistory、useParams、useLocation、useSelector、useDispatch

相关内容

热门资讯

诺德股份跌2.05%,成交额1... 1月26日,诺德股份(维权)盘中下跌2.05%,截至09:49,报7.15元/股,成交1.50亿元,...
滨江集团跌2.00%,成交额7... 1月26日,滨江集团盘中下跌2.00%,截至09:49,报10.76元/股,成交7483.18万元,...
漳州发展跌2.21%,成交额8... 1月26日,漳州发展盘中下跌2.21%,截至09:49,报7.53元/股,成交8628.63万元,换...
石英股份股价跌5.11%,圆信... 1月26日,石英股份跌5.11%,截至发稿,报39.93元/股,成交3.46亿元,换手率1.57%,...
先锋精科股价跌5.04%,华夏... 1月26日,先锋精科跌5.04%,截至发稿,报70.08元/股,成交1.54亿元,换手率1.99%,...