【发布时间】:2015-03-30 09:11:58
【问题描述】:
我有一个 React 组件可以管理列表中的多个手风琴,但是当我更新子组件时,在 React 开发工具上,它显示了更新的文本,但在视图/ui 上,它没有更新。请指教。
var AccordionComponent = React.createClass({
getInitialState: function() {
var self = this;
var accordions = this.props.children.map(function(accordion, i) {
return clone(accordion, {
onClick: self.handleClick,
key: i
});
});
return {
accordions: accordions
}
},
handleClick: function(i) {
var accordions = this.state.accordions;
accordions = accordions.map(function(accordion) {
if (!accordion.props.open && accordion.props.index === i) {
accordion.props.open = true;
} else {
accordion.props.open = false;
}
return accordion;
});
this.setState({
accordions: accordions
});
},
componentWillReceiveProps: function(nextProps) {
var accordions = this.state.accordions.map(function(accordion, i) {
var newProp = nextProps.children[i].props;
accordion.props = assign(accordion.props, {
title: newProp.title,
children: newProp.children
});
return accordion;
});
this.setState({
accordions: accordions
});
},
render: function() {
return (
<div>
{this.state.accordions}
</div>
);
}
编辑:
该组件确实触发了componentWillReceiveProps 事件,但它仍然永远不会更新。
谢谢
【问题讨论】:
标签: javascript node.js reactjs