gpt4 book ai didi

javascript - 另一个组件中的 React JS 引用函数

转载 作者:数据小太阳 更新时间:2023-10-29 04:09:07 24 4
gpt4 key购买 nike

我正在尝试通过另一个组件呈现一个按钮,以引用和/或影响不同组件的状态。

var Inputs = React.createClass({
getInitialState: function(){
return {count: 1};
},
add: function(){
this.setState({
count: this.state.count + 1
});
},
render: function(){
var items = [];
var inputs;
for (var i = 0; i < this.state.count; i++){
items.push(<input type="text" name={[i]} />);
items.push(<br />);
}
return (
<div className="col-md-9">
<form action="/" method="post" name="form1">
{items}
<input type="submit" className="btn btn-success" value="Submit Form" />
</form>
</div>
);
}
});

我想编写一个新组件,该组件将能够访问 Inputs 中的 add 函数。我尝试像这样用 Inputs.add 直接引用它:

var Add = React.createClass({
render: function(){
return (
<input type="button" className="btn" value="Add an Input" onClick={Inputs.add} />
);
}
});

但这没有用。我怎样才能通过另一个组件访问一个组件的功能,或者通过另一个组件影响一个组件的状态?谢谢。

最佳答案

您可以通过创建一个负责管理状态的父组件来实现这一点,然后将状态作为 props 向下推送到子组件。

/** @jsx React.DOM */

var Inputs = React.createClass({

render: function () {
var items = [];
var inputs;
for (var i = 0; i < this.props.count; i++) {
items.push( <input type="text" name={[i]} />);
items.push(<br />);
}
return (
<div className = "col-md-9">
<form action = "/" method = "post" name = "form1">
{items}
<input type="submit" className="btn btn-success" value = "Submit Form" />
</form>
</div>
);
}
});

var Add = React.createClass({
render: function () {
return (<input type = "button" className="btn" value="Add an Input" onClick={this.props.fnClick}/> );
}
});

var Parent = React.createClass({
getInitialState: function(){
return {count:1}
},
addInput: function(){
var newCount = this.state.count + 1;
this.setState({count: newCount});
},
render: function(){
return (
<div>
<Inputs count={this.state.count}></Inputs>
<Add fnClick={this.addInput}/>
</div>
);
}
});

React.renderComponent(<Parent></Parent> , document.body);

jsFiddle

关于javascript - 另一个组件中的 React JS 引用函数,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/21054955/

24 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com