簡體   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