首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >如何在ReactJS中将isValid变量从one.js访问到two.js?

如何在ReactJS中将isValid变量从one.js访问到two.js?
EN

Stack Overflow用户
提问于 2019-09-27 20:52:28
回答 2查看 65关注 0票数 0

我在下面的问题中遇到的问题是存储在'one.js‘中的代码

代码语言:javascript
复制
const One= (props) => {
  const [isValid, setIsValid]=useState(true);
  return(
      <div>Hello</div>
 );
}
export default One;

下面是存储在'two.js‘中的代码

代码语言:javascript
复制
import One from './one.js'; 
var Two=()=>{
    return(
        <div>Two</div>
    );
 }
 export default Two;
EN

回答 2

Stack Overflow用户

发布于 2019-09-27 21:07:32

您不能访问一个组件的状态,因为每个组件的状态都是私有的,这是不可访问的,但是您可以创建公共的父组件,并使用回调函数来更改其状态,并将值作为正确的值传递给两个组件

Flow - One -> CallbackFunction -> Parent -> Props -> Two

您还可以尝试使用useContext,并在2和1之间共享一些数据值

票数 0
EN

Stack Overflow用户

发布于 2019-09-29 19:40:34

不能从reactjs中的另一个组件访问组件的状态

为了这个目标,你必须学习和使用redux或者使用钩子。

但是如果你想在纯reactjs中实现,你必须让一个组件成为另一个组件的父组件,并将状态作为道具发送给子组件。

如下所示:

代码语言:javascript
复制
//one.jsx
class one extend React.Component{
    constructor(props){
        super(props)
        this.state = {
            text: ""
        }
    }
    render(){
        return <Two props={this.state.text} />
}

然后在two.jsx组件中使用它

代码语言:javascript
复制
class Two extend React.Component{
    render(){
        <div>{this.props.text}</div>
    }
}
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/58134969

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档