繁体   English   中英

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

[英]React : How to reset state value in ReactJS

我正在整理。 实际上它可以正常工作,我可以按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' ))

最好对所有五个数据都具有状态。

//在构造函数中

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

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

暂无
暂无

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM