我的上下文.js
import React from "react";
const MyContext = React.createContext('test');
export default MyContext;
我在一个单独的js
文件中创建了我的上下文,我可以在其中访问我的父组件和我的子组件
父.js
import MyContext from "./MyContext.js";
import Child from "./Child.js";
class Parent extends Component {
constructor(props) {
super(props);
this.state = {
Message: "Welcome React",
ReturnMessage:""
};
}
render() {
return (
<MyContext.Provider value={{state: this.state}}>
<Child />
</MyContext.Provider>
)
}
}
所以我用 Provider 上下文创建了父组件,并在 provider 选项卡中调用子组件
儿童.js
import MyContext from "./MyContext.js";
class Child extends Component {
constructor(props) {
super(props);
this.state = {
ReturnMessage:""
};
}
ClearData(context){
this.setState({
ReturnMessage:e.target.value
});
context.state.ReturnMessage = ReturnMessage
}
render() {
return (
<MyContext.Consumer>
{(context) => <p>{context.state.Message}</p>}
<input onChange={this.ClearData(context)} />
</MyContext.Consumer>
)
}
}
所以在 child 通过使用Consumer
,我可以在 child 渲染部分显示数据。
当我想从消费者那里更新状态时,我遇到了一个问题。
如何更新提供者状态或操作提供者的状态?