React 状态管理 - Context API 前世今生(下)

New Context API

Provider【context的生产者组件】

  • createContext 创建一个Context对象,订阅了整个Context对象的组件,会从组件树中离自身最近的那个匹配的Provider中读取到当前的context值。
  • Context.Provider 父Context对象返回的Provider组件,允许消费组件订阅context的变化。

Consumer【context的消费者组件】

  • Class.contextType 申明了contextType属性的组件会被赋值一个Context对象,组件内的this.context可以访问最近Context上的值。
  • Context.Consumer 函数组件订阅Context对象的方式,如同contextType之于Class组件。

New Context API-实战

javascript 复制代码
import React, { Component } from 'react';
import CustomContext from './components/button-context';
import NewButton from './components/new-button';

export default class NewContext extends Component {
    constructor(props) {
        super(props);
        this.state = {
            color: '#28a745',        
        };            
    }
    render() {
        const { color } = this.state;
        // Provider【context的生产者组件】
        return (
            <CustomContext.Provider value={color}>
            	<NewButton>new context api</NewButton>
            </CustomContext>                            
        );    
    }
}
javascript 复制代码
import React, { Component } from 'react';
import PropTypes from 'prop-types';
import CustomContext from '../button-context';

export default class NewButton extends Component {
    // 【context的消费者组件】
    static contextType = CustomContext;
    
    static propTypes ={
        children: PropTypes.string,    
    }
    
    static defaultProps = {
        children: '默认文案',   
    }
    
    render() {
        const { children } = this.props;
        
        return (
            <button type="button" style={{color: this.context }}>
            	{children}
            </button>        
        );   
    }
}
javascript 复制代码
import React from 'react';

const CustomContext = React.createContext();

export default CustomContext;
相关推荐
leobertlan3 小时前
2025年终总结
前端·后端·程序员
子兮曰3 小时前
OpenClaw架构揭秘:178k stars的个人AI助手如何用Gateway模式统一控制12+通讯频道
前端·javascript·github
百锦再4 小时前
Reactive编程入门:Project Reactor 深度指南
前端·javascript·python·react.js·django·前端框架·reactjs
Ashley的成长之路4 小时前
2025 年最新:VSCode 中提升 React 开发效率的必备插件大全
ide·vscode·react.js·工作提效·react扩展
莲华君4 小时前
React快速上手:从零到项目实战
前端·reactjs教程
百锦再4 小时前
React编程高级主题:测试代码
android·前端·javascript·react.js·前端框架·reactjs
易安说AI4 小时前
Ralph Loop 让Claude无止尽干活的牛马...
前端·后端
失忆爆表症6 小时前
05_UI 组件库集成指南:Shadcn/ui + Tailwind CSS v4
前端·css·ui
小迷糊的学习记录6 小时前
Vuex 与 pinia
前端·javascript·vue.js
发现一只大呆瓜6 小时前
前端性能优化:图片懒加载的三种手写方案
前端·javascript·面试