useReducer和useContext 代替redux

usereducer和usecontext实现redux视频地址
文章地址
React Hook 中 createContext & useContext 这篇文章讲的很不错

从技术胖那看了视频小案例分为四个组件
通过useReducer和useContext实现 在不同组件点击按钮字体变色


image.png

思路:

先把所有代码贴上

Text.js

import React, { useContext } from 'react';
import { ColorContext } from './Color'
export default function Text() {
    const { color,dispatch } = useContext(ColorContext)
    console.log(color);
    console.log(dispatch);
    return (<div style={{ color: color }}>字体颜色为{color}</div>)
}

Color.js

import React, { createContext, useReducer } from 'react';
const ColorContext = React.createContext({})
const reducer = (state, action) => {
    switch (action.type) {
        case UPDATE_COLOR:
            return action.color
        default:
            return state
    }
}
const UPDATE_COLOR = 'UPDATE_COLOR'

export default function Color(props) {
    const [color, dispatch] = useReducer(reducer, 'blue')
    return <ColorContext.Provider value={{color, dispatch}}>
        {props.children}
    </ColorContext.Provider>
}
export {
    ColorContext,
    reducer,
    UPDATE_COLOR
}

Button.js

import React, { createContext, useReducer } from 'react';
const ColorContext = React.createContext({})
const reducer = (state, action) => {
    switch (action.type) {
        case UPDATE_COLOR:
            return action.color
        default:
            return state
    }
}
const UPDATE_COLOR = 'UPDATE_COLOR'

export default function Color(props) {
    const [color, dispatch] = useReducer(reducer, 'blue')
    return <ColorContext.Provider value={{color, dispatch}}>
        {props.children}
    </ColorContext.Provider>
}
export {
    ColorContext,
    reducer,
    UPDATE_COLOR
}

App.js

import React, { createContext, useReducer } from 'react';
const ColorContext = React.createContext({})
const reducer = (state, action) => {
    switch (action.type) {
        case UPDATE_COLOR:
            return action.color
        default:
            return state
    }
}
const UPDATE_COLOR = 'UPDATE_COLOR'

export default function Color(props) {
    const [color, dispatch] = useReducer(reducer, 'blue')
    return <ColorContext.Provider value={{color, dispatch}}>
        {props.children}
    </ColorContext.Provider>
}
export {
    ColorContext,
    reducer,
    UPDATE_COLOR
}
©著作权归作者所有,转载或内容合作请联系作者
【社区内容提示】社区部分内容疑似由AI辅助生成,浏览时请结合常识与多方信息审慎甄别。
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

相关阅读更多精彩内容

友情链接更多精彩内容