首页
学习
活动
专区
圈层
工具
发布
社区首页 >问答首页 >点击表头,只有sortDirection总是ASC,怎么改成DESC,react-virtualized

点击表头,只有sortDirection总是ASC,怎么改成DESC,react-virtualized
EN

Stack Overflow用户
提问于 2019-02-01 21:49:43
回答 2查看 359关注 0票数 1
代码语言:javascript
复制
//this function sort table data in ASC and DESC order
_sortTable({ sortBy, sortDirection }) {
   //console.log(event)
   console.log('sortBy='+sortBy+', sortDirection='+sortDirection);
   const tempList = _.sortBy(currentTableData , item => item[sortBy]);
   const sortedListData = sortDirection === SortDirection.DESC ? tempList.reverse() : tempList;
   this.setState({ sortBy, sortDirection, sortedListData });
   rowRendererData = sortedListData;
   this.tableRef.forceUpdateGrid();
}

表列表头单击会调用此函数

代码语言:javascript
复制
sort={this._sortTable}
sortBy={this.state.sortBy}
sortDirection={this.state.sortDirection} 

<Table/>上。

但在单击表的标题时,sortDirection始终为ASCENDING(ASC)。

如何将sortDirection更改为DESCENDING(DESC)?

EN

回答 2

Stack Overflow用户

发布于 2019-02-01 21:53:46

似乎该函数将sortDirection作为对象的属性获取,那么您应该传递该参数:

代码语言:javascript
复制
sort={this._sortTable({sortDirection: SortDirection.DESC})}
 sortBy={this.state.sortBy}
 sortDirection={this.state.sortDirection}
票数 0
EN

Stack Overflow用户

发布于 2019-02-01 23:35:31

代码语言:javascript
复制
 _sortTable({ sortBy, sortDirection }) {

        this.setState(function(prevState) {
          return { sortDirection: prevState.sortDirection === SortDirection.ASC ? SortDirection.DESC : SortDirection.ASC } 
        });
       // console.log('sortBy='+sortBy+', sortDirection='+sortDirection);
       const tempList = _.sortBy(currentTableData , item => item[sortBy]);
       const sortedListData = this.state.sortDirection === SortDirection.DESC ? tempList.reverse() : tempList;
       this.setState({ sortBy, sortedListData });
       rowRendererData = sortedListData;
        this.tableRef.forceUpdateGrid();
     }
票数 0
EN
页面原文内容由Stack Overflow提供。腾讯云小微IT领域专用引擎提供翻译支持
原文链接:

https://stackoverflow.com/questions/54480872

复制
相关文章

相似问题

领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档