reactjs - react : How to filter events according to date

标签 reactjs filter

我在 js 文件中的表格中显示事件,如下所示:

 // index.component.js

import React, { Component } from 'react';
import axios from 'axios';
import TableRow from './TableRow';
import moment from 'moment';
export default class Index extends Component {

constructor(props) {
  super(props);
  this.state = {event: []};
}
componentDidMount(){
  axios.get('http://localhost:4000/event')
    .then(response => {
      this.setState({ event: response.data });

    })
    .catch(function (error) {
      console.log(error);
    })
}


tabRow(){
  var events = this.state.event
  events.sort((a,b) => {return new Date(a.startDate) - new 
Date(b.startDate)} ) ;
  return events.map(function(object, i){
  return <TableRow obj={object} key={i} />;
});
}


render() {
  return (
    <div>
      <table className="table table-striped" style={{ marginTop: 20 , width:700}}>
        <tbody>
          { this.tabRow() }
        </tbody>
      </table>
    </div>
  );
}

}

My table.js

// TableRow.js


class TableRow extends Component {
constructor(props) {
    super(props);
 }

render() {
return (

    <tr>
      <td>
        {this.props.obj.event_name} 
      </td>
      <td>{ moment(this.props.obj.startDate).format("MMMM D, Y") }</td>
      <td>
        <button onClick={this.delete} className="btn btn- 
      danger">Delete</button>
      </td>
     </tr>
     );
     }
      }
   export default TableRow;

现在,我正在使用事件的排序功能,如您在上面提供的代码中所见,根据日期对事件进行排序,最旧的事件是第一个列出的事件。那没问题。我想过滤数组,以便已经过去的事件不会出现在我的决赛 table 中。如何将其与当前日期进行比较并过滤掉旧事件?

最佳答案

您需要从您的事件日期中减去当前日期,并检查它是否小于 0。如果是,则它是过去的,您可以忽略它。所以过滤器函数应该是这样的:

const dates = ["2018-09-12", "2018-10-18", "2018-12-30"];
const filteredDates = dates.filter(d => new Date(d) - new Date() > 0);

这就是你的情况:

events = events.filter(a => new Date(a.startDate) - new Date > 0);

关于reactjs - react : How to filter events according to date,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/53772417/

相关文章:

filter - 我可以在 kafka 流应用程序的 peek 或过滤器或分支中执行一些状态操作吗?

java - 如何使用 JPA 分页应用基于 java 的过滤器?

python - 使用 Django 模板过滤器做数学?

java - java中的身份验证过滤器,帮我消除这个错误

javascript - 固定数据表中的悬停工具提示内容

node.js - eslint-插件-导入 : for js files not svg or css

configuration - PHPUnit:仅过滤一个测试套件

javascript - 将数组的元素作为 React 中对象的一部分推送

REST (HATEOAS) 和 ReactJS

javascript - 带有状态组件的reactjs + styled-components - 我的样式看不到 Prop