作者热门文章
- Java 双重比较
- java - 比较器与 Apache BeanComparator
- Objective-C 完成 block 导致额外的方法调用?
- database - RESTful URI 是否应该公开数据库主键?
我有以下 React.js 应用程序结构:
<App />
<BreadcrumbList>
<BreadcrumbItem />
<BreadcrumbList/>
<App />
问题是,当我点击 <BreadcrumbItem />
时, 我想改变 <App />
中的状态
我使用回调将 Prop 传递给 <BreadcrumbList/>
但这就是我得到的。是否有任何 pattaren 如何轻松地将 Prop 传递给组件树?
如何将 prop 传递给 <App />
, 没有做任何回调链?
最佳答案
如果您正在做一些简单的事情,那么通常最好通过组件层次结构向上传递状态的变化,而不是专门为此目的创建一个商店(无论它是什么)。我会做以下事情:
面包屑导航项
var React = require('react/addons');
var BreadcrumbItem = React.createClass({
embiggenMenu: function() {
this.props.embiggenToggle();
},
render: function() {
return (
<div id="embiggen-sidemenu" onClick={this.embiggenMenu} />
);
}
});
module.exports = BreadcrumbItem ;
然后通过 BreadcrumbList 组件将其传递给父级......
<BreadcrumbItem embiggenToggle={this.props.embiggenToggle}>
...和UP到App,然后用它来设置状态....
var React = require('react/addons');
var App = React.createClass({
embiggenMenu: function() {
this.setState({
menuBig: !this.state.menuBig
});
},
render: function() {
return (
<div>
<BreadcrumbList embiggenToggle={this.embiggenMenu} />
</div>
)
}
});
module.exports = BreadcrumbItem;
这个例子切换了一个简单的 bool 值,但是你可以放弃任何你喜欢的东西。我希望这会有所帮助。
我没有对此进行测试,但它是(快速)从一个实时工作示例中提取的。
编辑:按照要求,我将对含糊的内容进行扩展:“你可以放弃任何东西”。
如果您正在制作一个基于数组的导航菜单并且需要将所选项目传递给父项,那么您将执行以下操作
var React = require('react/addons');
var ChildMenu = React.createClass({
getDefaultProps: function () {
return {
widgets : [
["MenuItem1"],
["MenuItem2"],
["MenuItem3"],
["MenuItem4"],
["MenuItem5"],
["MenuItem6"],
["MenuItem7"]
]
}
},
handleClick: function(i) {
console.log('You clicked: ' + this.props.widgets[i]);
this.props.onClick(this.props.widgets[i]);
},
render: function() {
return (
<nav>
<ul>
{this.props.widgets.map(function(item, i) {
var Label = item[0];
return (
<li
onClick={this.handleClick.bind(this, i)}
key={i}>
{Label}
</li>
);
}, this)}
</ul>
</nav>
);
}
});
module.exports = ChildMenu;
然后您将在父级中执行以下操作:
var React = require('react/addons');
var ChildMenuBar = require('./app/top-bar.jsx');
var ParentApp = React.createClass({
widgetSelectedClick: function(selection) {
//LOGGING
//console.log('THE APP LOGS: ' + selection);
//VARIABLE SETTING
var widgetName = selection[0];
//YOU CAN THEN USE THIS "selection"
//THIS SETS THE APP STATE
this.setState({
currentWidget: widgetName
});
},
render: function() {
return (
<ChildMenu onClick={this.widgetSelectedClick} />
);
}
});
module.exports = ParentApp;
希望对您有所帮助。感谢您的支持。
关于javascript - 将 Prop 从孙辈传递给 parent ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/30530731/
我是一名优秀的程序员,十分优秀!