我正在整理。实际上,它可以正常工作,我可以在asc
和desc
中对数据进行排序。我正在对不同的字段进行排序。例如,如果用户要对字段1的数据进行排序,然后单击“下一步”(我也使用分页),则我在表中有5个字段,现在假设用户在第5页上,并且用户要在此处对字段2的数据进行排序将状态值重置为初始值(状态val1=5
和val2=0
的初始值)。我将如何做到这一点,我是ReactJS的新手,有人可以帮助我如何解决此问题。
对不起,如果我因为不讲英语而在英语语法上弄错了。
代码
sortingData= (ascValue,desValue) => {
this.setState(
{
dataSort:
this.state.sortedData === ascValue? desValue: ascValue
},
() => {
this.loadData();
}
);
}
**Full Component Code**
class Example extends React.Component {
constructor(props) {
super(props);
this.state = {
Item: 5,
skip: 0
}
this.handleClick = this.handleClick.bind(this);
}
urlParams() {
return `http://localhost:8001/meetups?filter[limit]=${(this.state.Item)}&&filter[skip]=${this.state.skip}`
}
handleClick() {
this.setState({skip: this.state.skip + 1})
}
render() {
return (
<div>
<a href={this.urlParams()}>Example link</a>
<pre>{this.urlParams()}</pre>
<button onClick={this.handleClick}>Change link</button>
</div>
)
}
}
ReactDOM.render(<Example/>, document.querySelector('div#my-example' ))
答案 0 :(得分:1)
要做的是使所有五个数据都具有状态。
//在构造函数中
state = {
dataSort: {
data1: {sortedBy: asc, pagination: 1},
data2: {sortedBy: asc, pagination: 1},
data3: {sortedBy: asc, pagination: 1},
data4: {sortedBy: asc, pagination: 1},
data5: {sortedBy: asc, pagination: 1}
}
}
//当更新特定数据的排序逻辑时
this.setState({
dataSort: {
...dataSort,
data1: {
sortBy: this.state.dataSort.data1 === val1? val2 : val1;
pagination: 5
}
}
})
现在,如果要重置,则只需更改特定数据的分页值或排序值。