react Provider Consumer 使用方法

相关文章 React Context的使用方法

跨几个组件传递值或者方法的时候, 如果依赖父子组件传值, 那势必会很麻烦. 好在react提供了Provider 和 Consumer

1 调用react的createContext()方法, 产生生产者和消费者组件.

bash 复制代码
// context.js
import React from 'react'
let { Consumer, Provider } = React.createContext();
export {
    Consumer,
    Provider
}

在父(祖先)级组件中, 把要传递东西的后代组件包起来, 要传递的东西放进value里面, value是一个对象, 所以看着像双括号语法, 其实不是.

bash 复制代码
import React from 'react'
import List from './List'
import {Provider} from './context'
export default class TodoWrapper extends React.Component {
    state = {
        list: []
    }
    task = React.createRef()
    handleClick = () => {
        let list = [...this.state.list, this.task.current.value]
        this.setState({
            list: list
        })
        this.task.current.value = ''
    }
    deleteTask = (index) => {
        let list = this.state.list
        list.splice(index, 1)
        this.setState({
            list: list
        })
    }
    render() {
        return (
            <Provider value={{deleteTask: this.deleteTask}}>
                <input type="text" ref={this.task}/>
                <button onClick={this.handleClick}> Add </button>
                <List list={this.state.list} deleteTask={this.deleteTask}/>
            </Provider>
        );
    }
}

后代组件中的组件放在Consumer里面, 内部是一个函数, 这个函数接受一个对象作为参数, 参数是Provider里面提供的值. 然后直接使用就可以了.

bash 复制代码
import React from 'react'
import {Consumer} from './context'

export default class List extends React.Component{

    render() {
        const { list } = this.props
        return (
            <Consumer>
                {
                    ({ deleteTask }) => {
                        return list.map((item, index) => {
                            return (
                                <li key={item + index}>
                                    { item }
                                    <button onClick={()=>{deleteTask(index)}}> delete </button>
                                </li>
                            )
                        })
                    }
                }
            </Consumer>
        );
    }
}
相关推荐
阿赛工作室7 分钟前
Vue中onBeforeUnmount不触发的解决方案
前端·javascript·vue.js
码王吴彦祖8 分钟前
顶象 AC 纯算法迁移实战:从补环境到纯算的完整拆解
java·前端·算法
小叶lr20 分钟前
jenkins打包前端样式丢失/与本地不一致问题
运维·前端·jenkins
浩星26 分钟前
electron系列1:Electron不是玩具,为什么桌面应用需要它?
前端·javascript·electron
ZC跨境爬虫1 小时前
Scrapy工作空间搭建与目录结构解析:从初始化到基础配置全流程
前端·爬虫·python·scrapy·自动化
小村儿1 小时前
连载04-最重要的Skill---一起吃透 Claude Code,告别 AI coding 迷茫
前端·后端·ai编程
_院长大人_1 小时前
Vue + ECharts 实现价格趋势分析图
前端·vue.js·echarts
IT_陈寒2 小时前
Vite的alias配置把我整不会了,原来是这个坑
前端·人工智能·后端
万物得其道者成2 小时前
Cursor 提效实战:我的前端 Prompt、审查 SKILL、MCP 接入完整方法
前端·prompt
酒鼎2 小时前
学习笔记(12-02)事件循环 - 实战案例 —⭐
前端·javascript