javascript - 如何在reactjs中对数据进行排序并显示?

标签 javascript reactjs

当用户单击按资金排序时,我想以排序的方式显示项目,那么它应该以按资金排序的方式显示项目,但我的代码无法正常工作,为什么会这样?我正在导入 sortBy() 函数并在用户单击按钮时使用它。

home.js:

import React, { Component } from 'react';
import Card from '../common/card';
import Projects from '../../data/projects';
import { sortBy } from './helper';

    export default class Home extends Component {

      constructor(props) {
        super(props);
        this.state = {
          projects: Projects
        }
      }

      render() {

        return (
          <div>
              <div className="header">
                <div className="buttonContainer">
                  <div>
                      <button className="btn btn-primary mycustom dropdown-toggle mr-4" type="button" data-toggle="dropdown" aria-haspopup="true"
                      aria-expanded="false">Sort by </button>

                      <div className="dropdown-menu">
                          <a className="dropdown-item" href="#" onClick={() => sortBy('funded')}>Percentage fund</a>
                          <a className="dropdown-item" href="#" onClick={() => sortBy('backers')}>Number of backers</a>
                      </div>
                  </div>
                </div>
              </div>
              <div class="container-fluid">
                <div class="row">
                  {this.state.projects.map( (val,index) => (
                    <div class="col-3">
                      <Card title={val.title} by={val.by} blurb={val.blurb} 
                      url={val.url} funded={val.funded} backers={val.backers} imgurl={index}/>
                    </div>
                  ))}
                </div>
              </div>
          </div>
        )
      }
    }

helper.js:

import projects from '../../data/projects';

export function sortBy (searchTerm) {
    if(searchTerm === 'funded'){
        return projects.sort((a,b) => a.funded - b.funded);
    }else if(searchTerm === 'backers'){
        return projects.sort((a,b) => a.backers - b.backers);
    }
}

projects.js:

http://jsfiddle.net/0z8xcf1o/

最佳答案

  1. 在渲染函数中,您应该迭代 this.state.projects 而不是 Projects
  2. 您需要在每次排序时更新您的状态
  3. 您的 sortBy 函数可以简化,它应该为您设置状态,并且最好将其添加到组件中:

-

sortBy(searchTerm) {
  this.setState({ projects: [...Projects].sort((a, b) => a[searchTerm] - b[searchTerm]) });
}

然后用

调用它
onClick={() => this.sortBy('funded')}

关于javascript - 如何在reactjs中对数据进行排序并显示?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53940299/

相关文章:

css - 每条路线不同的背景图片

javascript - React - 未处理的拒绝(TypeError): _this4. getNotes 不是函数

javascript - 在 React 中突出显示搜索到的文本

javascript - React - 当另一个 React-Select 更改时如何清除 React-Select 的值

javascript - 如何在函数内部传递参数?

javascript - d3 堆叠条形图中工具提示的 x 位置不起作用

javascript - 选择地点的传单

javascript - 如何使用另一个对象访问 JavaScript 对象?

javascript - 使用 Math.max 和 Math.min 从数组中删除最大和最小数字

javascript - 如何映射使用联合和片段在页面上呈现的 graphql 查询