React:如何在ReactJS中重置状态值

时间:2019-03-21 17:26:50

标签: javascript arrays reactjs ecmascript-6 es6-promise

我正在整理。实际上,它可以正常工作,我可以在ascdesc中对数据进行排序。我正在对不同的字段进行排序。例如,如果用户要对字段1的数据进行排序,然后单击“下一步”(我也使用分页),则我在表中有5个字段,现在假设用户在第5页上,并且用户要在此处对字段2的数据进行排序将状态值重置为初始值(状态val1=5val2=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' ))

1 个答案:

答案 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
        }
    }
})

现在,如果要重置,则只需更改特定数据的分页值或排序值。