web-dev-qa-db-fra.com

AngularJs ng-if comparant les dates

Je cherche à comparer deux dates en ng-si c'est à quoi ressemble mon fichier jade.

li.list-group-item(ng-if="app.Segments[0].StartDate.getTime() > date.getTime()")
    div.row
        div.col-xs-12
            span
                i.fa.fa-plus-square

J'espère que ce code ajoutera un li à mon interface utilisateur si la date de début du premier segment est postérieure à aujourd'hui.

$scope.date = new Date();
$scope.app = {
    Segments: [{
       StartDate: 2014-11-15T04:00:00.000Z
       EndDate: 2014-11-20T04:00:00.000Z
    },
    {
        StartDate: 2014-11-21T04:00:00.000Z
        EndDate: 2014-11-25T04:00:00.000Z
    }]

}

Y a-t-il un moyen de faire fonctionner cela?

13
Dalton Shehan

S'ils sont des objets de date, il suffit de les comparer directement sans .getTime()

$scope.date2005 = new Date('2005/01/01');
$scope.date2006 = new Date('2006-01-01T04:00:00.000Z');
<div ng-if="date2005 > date2006">date2005 > date2006</div> <!-- won't show -->
<div ng-if="date2006 > date2005">date2006 > date2005</div> <!-- will show -->

http://plnkr.co/edit/fNB11U6KmFszdV3lMAPJ?p=preview

13
laggingreflex

Angular peut comparer directement la date si elle est bien formatée:

vue

li.list-group-item(ng-if="app.Segments[0].StartDate > now")

manette

$scope.now = new Date();
$scope.now.toISOString();
8
Sebastien Horin