React 状态管理 Reducer 的 dispatch 不是一个方法?

image.png

import { Button } from 'antd-mobile'
import { usePageContext, usePageData } from '../core/Context'

export default function C_Button ({ text = "啊啊啊" }) {
    const title: any = usePageContext()
    const dispatch = usePageData();

    return <>
        <Button block color='primary' size='large' >{text}</Button>
        <Button block color='success' size='mini' onClick={() => dispatch({ text: "变化成功!!!!" })} >{title.text}</Button>
    </>

}
import { createContext, useContext, useReducer } from "react";

const PageContext = createContext({})

const PageData = createContext({})

export function PageProvider({ children } : any) {

    const [tasks, dispatch] = useReducer(
        tasksReducer,
        { text: "这是初始化" }
    );

    return (
        <PageContext.Provider value={tasks}>
            <PageData.Provider value={dispatch}>
                {children}
            </PageData.Provider>
        </PageContext.Provider>
    );
}

export function usePageContext() {
    return useContext( PageContext );
}

export function usePageData() {
    return useContext( PageData );
}

export function tasksReducer(tasks: any, action: any) {
    return { text: action.text }
}

image.png

阅读 1.8k
1 个回答

context的值来源于provider上的value属性。你的PageContext.Providervaluetasks也就是你usePageContext得到的是这个值,而不是dispatch这个函数

撰写回答
你尚未登录,登录后可以
  • 和开发者交流问题的细节
  • 关注并接收问题和回答的更新提醒
  • 参与内容的编辑和改进,让解决方法与时俱进
推荐问题