为了账号安全,请及时绑定邮箱和手机立即绑定

比较并过滤对象中的日期属性

比较并过滤对象中的日期属性

桃花长相依 2023-12-14 17:10:26
我有一个看起来像这样的对象:    myObject = {      publishedDate: string;      Url: string;      Title: string;  }属性“publishedDate”是格式为“19/01/2021”的字符串。例如,它可以有一个未来的日期,即大于今天的值。换句话说,我想保留 PublicationDate 等于或小于今天的所有对象(并删除所有已结束的对象)。对象保存在我的状态(数组)中:this.state.data我首先为今天的值创建一个日期变量,以便将其与publishedDate 进行比较。我还使用 moment() 将其格式化为与对象相同的日期格式:let today = moment().format("DD/MM/YYYY");然后我使用过滤方法来比较并过滤掉数据:  this.state.data.filter(item => new Date(item.publishedDate) >= new Date(today))而且我也尝试过:  this.state.data.filter(function(item) {          if (new Date(item.publishedDate) >= new Date(today)) {        return false;      }    return true;  });它不仅不起作用,而且我仍然拥有数组中的所有对象,并且没有任何内容被过滤掉。代码有什么问题吗?
查看完整描述

6 回答

?
阿晨1998

TA贡献2037条经验 获得超6个赞

您可以moment像这样简单地使用 的内置比较器

this.state.data.filter(item => moment(item.publishedDate,'DD/MM/YYYY').isSameOrAfter(today))




查看完整回答
反对 回复 2023-12-14
?
米脂

TA贡献1836条经验 获得超3个赞

构造函数Date不会接受您当前使用的格式,但它会识别MM/DD/YYYY格式。此外,filter保留函数返回 true 的元素,因此您应该检查 是否Date小于或等于当前Date。


const today = new Date;

this.state.data = this.state.data.filter(({publishedDate})=>{

    const [d, m, y] = publishedDate.split("/");

    return new Date(m + "/" + d + "/" + y) <= today;

});


查看完整回答
反对 回复 2023-12-14
?
慕田峪4524236

TA贡献1875条经验 获得超5个赞

使用 moment 的String + Format 初始值设定项和Is Same Or After:

this.state.data.filter(item => moment(item.publishedDate, 'DD/MM/YYYY').isSameOrAfter())


查看完整回答
反对 回复 2023-12-14
?
狐的传说

TA贡献1804条经验 获得超3个赞

一种可能性是使用辅助函数notAfterToday,它接受一个属性名称(在我们的例子中'publishedDate')并返回一个函数,该函数接受具有该属性名称的对象并报告该日期是在当前日期之前还是在当前日期。

例如,它通过将 2020 年 12 月 18 日转换为“20201218”,并使用该字符串进行比较来实现此目的。请注意,这样做的一个优点是它只调用一次 Date 构造函数,用于初始计算今天的日期。

const data = [{publishedDate: '18/12/2020', Url: 'http://example.com/1', Title: 'abc'}, {publishedDate: '19/01/2021', Url: 'http://example.com/2', Title: 'def'}, {publishedDate: '07/04/2014', Url: 'http://example.com/3', Title: 'ghi'}, {publishedDate: '19/07/2023', Url: 'http://example.com/4', Title: 'jkl'}, {publishedDate: '05/01/1966', Url: 'http://example.com/5', Title: 'mno'}, {publishedDate: '01/07/2041', Url: 'http://example.com/6', Title: 'pqr'}, {publishedDate: '08/05/2061', Url: 'http://example.com/7', Title: 'stu'}, {publishedDate: '10/08/1999', Url: 'http://example.com/8', Title: 'vwx'}]


const notAfterToday = (prop) => {

  const reorg = (date, [d, m, y] = date.split('/')) => y + m + d 

  const today = new Date()

  const compare = today .getFullYear() + 

                  String ((today .getMonth () + 1)) .padStart (2, '0') +

                  String (today .getDate ()) .padStart (2, '0')

  return (d) => compare >= reorg (d [prop])

}


console .log (data .filter (notAfterToday ('publishedDate')))

.as-console-wrapper {max-height: 100% !important; top: 0}


查看完整回答
反对 回复 2023-12-14
?
不负相思意

TA贡献1777条经验 获得超10个赞

在与今天进行比较之前,您必须对日期字符串进行一些微调。你可以试试这个——


const data = [

  {

    publishedDate: "19/01/2021",

    url: '',

    title: 'date1'

  },

  {

    publishedDate: "19/05/2021",

    url: '',

    title: 'date2'

  },

  {

    publishedDate: "13/01/2020",

    url: '',

    title: 'date3'

  },

  {

    publishedDate: "16/09/2009",

    url: '',

    title: 'date4'

  },

];


const parseDate = (dateString) => new Date(...dateString.split('/').reverse());



const result = data.filter(item => parseDate(item.publishedDate) <= new Date());


console.log(result);


查看完整回答
反对 回复 2023-12-14
?
拉莫斯之舞

TA贡献1820条经验 获得超10个赞

将日期存储为字符串是一种代码味道。与将它们存储为 JS 原生日期格式或 Moment.JS 日期对象等替代方案相比,比较、存储和转换它们更加困难。


这是一个简单的示例,说明如果您将对象存储为日期,您可以如何做到这一点。


请注意,第三个对象已被过滤掉。


const myObject1 = {

  publishedDate: new Date("2019-01-01"), // NEW

  Url: "whatever",

  Title: "sample",

}


const myObject2 = {

  publishedDate: new Date("2020-01-01"), // NEW

  Url: "whatever",

  Title: "sample",

}


const myObject3 = {

  publishedDate: new Date("2099-01-01"), // NEW

  Url: "whatever",

  Title: "sample",

}


const arr = [myObject1, myObject2, myObject3];


const today = new Date();


const filtered = arr.filter((obj) => obj.publishedDate < today);


console.log(filtered);


查看完整回答
反对 回复 2023-12-14
  • 6 回答
  • 0 关注
  • 221 浏览
慕课专栏
更多

添加回答

举报

0/150
提交
取消
意见反馈 帮助中心 APP下载
官方微信