我有一系列数据,这些数据在一个数组(json文件)中包含一些对象,它将在React中显示。主要问题是为什么不显示<span class="text" key={index}>{this.state.text[index]}</span>
的文本?我必须在renderDetail
中调用DetailsInfo
函数,而不是在渲染时间上进行设置。我无法在渲染时将其称为renderDetail
函数。
class App extends React.Component {
constructor(props) {
super(props);
this.state = {
data: [],
DetailsInfo: {},
text: {}
};
}
render() {
const { data } = this.state;
const renderInfo = data.map((item, i) => {
return (
<div class="item">
<div class="moreInfo" onClick={e => this.showDiv(e, item, i)}>
<span>show more data</span>
</div>
<div class="table">{this.state.DetailsInfo[i]}</div>
</div>
);
});
return <div>{renderInfo}</div>;
}
showDiv = (e, element, i) => {
this.setState(prevState => ({
DetailsInfo: {
...prevState.DetailsInfo,
[i]: this.renderDetails(element, i)
}
}));
};
renderDetails(element, i) {
let lenfamilies = element.families.length;
var indents = [];
var index = 0;
for (var j = 0; j < lenfamilies; j++) {
var numF = i;
var numS = j;
var stingF = numF.toString();
var stingS = numS.toString();
index = stingF + stingS;
indents.push(
<div>
<span
key={index}
onClick={e => this.handelrule(e, element.families[j], index)}
>
Click
</span>
<span class="text" key={index}>
{this.state.text[index]}
</span>
</div>
);
}
return indents;
}
handelrule = (e, element, index) => {
console.log(index);
this.setState(prevState => ({
text: { ...prevState.text, [index]: "test" }
})); ////In this part 'test' should be set in div by class="text"
};
}
ReactDOM.render(<App />, document.getElementById("Result"));