javascript - Angular JS比较两个日期是否相等

标签 javascript angularjs date angular-ng-if

我已经使用这个 Angular 代码来比较两个日期是否相等。

代码:

<div class="batchPlannings">
  <div ng-repeat="batchPlanning in batchPlannings"
    ng-animate="'animate'">
    <div ng-switch="batchPlanning.status">
      <div ng-switch-when="MAPPED" class="my-switch-animation">
        <p>start date: {{batchPlanning.startDate}}</p>
        <p>placement date: {{placementDate}}</p>
        <div ng-if="batchPlanning.startDate === {{placementDate}}"
          class="my-switch-animation">
          <a th:href="@{/placement}" class="list-group-item"
            sec:authorize="hasAnyRole('ROLE_SYSTEM_ADMIN', 'ROLE_CENTER_ADMIN')">Batch
            with batch code '{{batchPlanning.batchCode}}' is ready for
            placements</a>

        </div>
      </div>
    </div>
  </div>
</div>

我想检查这两个日期是否相等 我正在使那些日期完美无缺,并且这些日期也相等,但无法使该条件为真。 我也用 == 检查了它,但没有结果。

如有任何帮助或建议,我们将不胜感激。

最佳答案

JavaScript 使用对象来存储日期值。如果您想比较两个日期是否相等,请不要这样做 date1 === date2。这只会告诉您这两个变量是否引用同一个对象。

要检查两个日期是否相等,请使用日期对象的 getTime() 方法。像这样:

date1.getTime() == date2.getTime()

请小心,因为秒数的任何差异都将与日期不匹配。

现在 ng-if 将接受 AngularJS 表达式。您的示例 batchPlanning.startDate === {{placementDate}} 中有这个。这是一个无效的表达。 {{placementDate}} 是用于创建绑定(bind)的语法。

你想要做的是 batchPlanning.startDate.getTime() == placementDate.getTime()

确保两个变量都是有效的 JavaScript 日期对象。

我建议您使用 moment javascript 库进行日期处理。它使处理日期变得更加容易。

http://momentjs.com/

关于javascript - Angular JS比较两个日期是否相等,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27547644/

相关文章:

javascript - 为什么订阅在首次订阅热门可观察对象后没有触发

angularjs - Jasmine 2.0 : Asynchronous test case

sql - 如何比较 Postgresql 中日期时间字段中的日期?

javascript - 为什么 "exact"不是 react 路由器中的默认行为

javascript - 使用 Array.prototype.map 时将变量名称分配为对象属性

javascript - 在异步等待中的try-catch中处理 'throw error'是否有问题?

javascript - 迭代多个数组元素

javascript - Angular 理解链接函数

c# - 获取给定某一天的一周中的天数范围

javascript - 在 JS 中将字符串格式化为日期