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

相关内容

热门资讯

6月24日港股通红利低波ETF... 6月24日,港股通红利低波ETF华宝(159220)涨0.00%,成交额2308.42万元。当日份额...
田村:需将利率上调至2%左右的... 日本央行政策委员会成员田村表示,需将利率提升至2%左右的中性水平。译文内容由第三方软件翻译。声明:市...
6月24日科创医药ETF华夏(... 6月24日,科创医药ETF华夏(588130)涨1.17%,成交额2439.04万元。当日份额增加6...
6月24日科创50ETF富国(... 6月24日,科创50ETF富国(588940)涨3.99%,成交额8658.76万元。当日份额减少9...
清华新林院的“红色客厅”   周惠斌  清华新林院8号,是著名建筑学家梁思成、林徽因夫妇在1946年至1954年间居住的地方,...