javascript – 如何从父母中激活一个函数反应?
内容导读
互联网集市收集整理的这篇技术教程文章主要介绍了javascript – 如何从父母中激活一个函数反应?,小编现在分享给大家,供广大互联网技能从业者学习和参考。文章包含2432字,纯文字阅读大概需要4分钟。
内容图文
![javascript – 如何从父母中激活一个函数反应?](/upload/InfoBanner/zyjiaocheng/735/34595098130a40b2bc0be86a9ac71cb0.jpg)
我的React应用程序有三个组件.其中两个是子组件,另一个是父组件.我需要通过父组件将数据(projectId)从一个子组件传递给另一个子组件,并在接收到数据后触发一个函数.作为我的例子,我将projectId从ChildOne发送到Parent,然后将projectId从Parent发送到ChildTwo. ChildTwo有一个名为setProject(projectId)的函数,我需要在收到projectID后触发它.问题是我无法通过单击ChildOne中的按钮来获取在ChildTwo中触发的函数getProjectId.我也尝试过componentDidMount和componentWillReceiveProps,它们对我不起作用.我怎样才能做到这一点?
这是我尝试过的
ChildOne:
class ChildOne extends React.Component {
constructor(props) {
super(props);
this.state = {
projectId: 3,
};
}
sendProjectId = (projectId) => {
this.props.sendId(projectId)
}
render() {
return(
<button onClick={() => this.sendProjectId(this.state.projectId)}>
Click
</button>
)
}
}
家长:
class Parent extends React.Component {
constructor(props) {
super(props);
this.state = {
projectId: '',
};
}
getId = (proId) => {
this.setState({
projectId : proId
})
}
render() {
return(
<div>
<CildOne sendId={this.getId} />
<CildTwo sendOneId={this.state.projectId} />
</div>
)
}
}
ChildTwo:
class ChildTwo extends React.Component {
constructor(props) {
super(props);
this.state = {
projectId: '',
};
}
getProjectId = (this.props.sendOneId) => {
//Do something with this.props.sendOneId
}
render() {
return(
<div></div>
)
}
}
解决方法:
这取决于ChildTwo希望用所述数据完成什么.
情况1:
ChildTwo打算使用相应的projectId获取一些数据并将其显示在组件中.然后,您可以轻松地在父组件中获取此数据,并将数据作为道具传递下来.
class Parent extends React.Component {
constructor(props) {
super(props);
this.state = {
projectId: '',
dataForChildTwo: null,
};
}
getId = (proId) => {
this.setState({
projectId : proId,
dataForChildTwo: fetchData(proId)
})
}
render() {
return(
<div>
<CildOne sendId={this.getId} />
<CildTwo data={this.state.dataForChildTwo} />
</div>
)
}
}
案例2:
ChildTwo打算在projectId更改时对其中的某些内容进行一些更改.然后你可以使用componentDidUpdate钩子看看道具是否已经改变并做出反应.
class ChildTwo extends React.Component {
constructor(props) {
super(props);
this.state = {
projectId: '',
};
}
getProjectId = (this.props.sendOneId) => {
//Do something with this.props.sendOneId
}
componentDidUpdate(prevProps) {
if(this.props.projectId!==prevProps.projectId) {
// do something
}
}
render() {
return(
<div></div>
)
}
}
案例3:
如果上述任何一种情况都不适合您,则可以在projectId使用键属性更改时手动重新加载完整组件:
<CildTwo key={this.state.projectId} sendOneId={this.state.projectId} />
注意:这会非常不必要地重新加载整个组件.
内容总结
以上是互联网集市为您收集整理的javascript – 如何从父母中激活一个函数反应?全部内容,希望文章能够帮你解决javascript – 如何从父母中激活一个函数反应?所遇到的程序开发问题。 如果觉得互联网集市技术教程内容还不错,欢迎将互联网集市网站推荐给程序员好友。
内容备注
版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 gblab@vip.qq.com 举报,一经查实,本站将立刻删除。
内容手机端
扫描二维码推送至手机访问。