javascript – AngularJS使用ng-repeat过滤并显示日期范围

AngularJS-或整个Web开发场景的新手,

我甚至不确定这是否可行,或者我是否采用最有效的路径,但我目前需要使用两个输入框来过滤日期范围的方法,我使用jquery datepicker来始终格式化日期成为“YYYY-MM-DD”.

所以,我有以下两个输入框,

<label class="" for="DateFromFilter">
          Date From:
</label>
 <input date-picker type="text" id="DateFromFilter" 
    class="form-control" 
    title="Please enter in YYYY-MM-DD format."
    ng-model="search.dueDate" />

 <label class="" for="DatetoFilter">
           Date To:
 </label>
  <input date-picker type="text" id="DatetoFilter" 
     class="form-control"
     title="Please enter in YYYY-MM-DD format."
     ng-model="search.toDate" />

当然,我有一个带有ng-repeat指令的表,从本地JSON文件获取数据……只接收到dueDate.

<tr> ng-repeat="dateItem in dateItems | filter:search:strict | filter:datefilter" 
<td>{{dateItem.dueDate}}</td></tr>

我需要一种方式来说,

>如果用户仅在dueDate字段上选择日期,则ng-repeat
列表将过滤并列出该日期及之后的所有日期.
>如果用户仅在toDate字段上选择日期,则ng-repeat
列表将过滤并列出所有日期,包括该日期
某个约会.
>如果用户在两个字段上选择日期,则列表将全部显示
这两个日期之间的日期.

我迷失在哪条路上,我一直在想我必须编写一个自定义过滤器函数并将日期与if语句进行比较等等,但我没有足够的代码来说明这里. ..

任何帮助或指导将不胜感激!

谢谢!

——————————————— UPDATE —- —————————

所以我最终试图尽我所能写出一个自定义过滤器功能..虽然不起作用……;(如果我拿出粗体条件语句,它有点起作用……

$scope.datefilter = function (item) {

  /*
   * When the display starts,the inputs are undefined. also need to
   * account for when the inputs are empty to return everything.
   */
if ((!angular.isUndefined($scope.dueDate) && $scope.dueDate != "" ) **&&
      (angular.isUndefined($scope.toDate) || $scope.toDate == "" )**)
  {          
    var inputDate = new Date($scope.dueDate);
    var incomingDate = new Date(item.dueDate);
    if (inputDate <= incomingDate) 
    {
     return true;
    }
    else
    {
     return false;
    }
  }
else if ((!angular.isUndefined($scope.toDate) && $scope.toDate != "")**&&
          (angular.isUndefined($scope.dueDate) || $scope.dueDate == "" )**)
  {
    var inputDate = new Date($scope.toDate);
    var incomingDate = new Date(item.dueDate);
    if (inputDate >= incomingDate)
    {
      return true;
    }
    else
    {
      return false;
    }
  }
else if ((!angular.isUndefined($scope.dueDate) && $scope.dueDate != "" )&&
          (!angular.isUndefined($scope.toDate) && $scope.toDate != ""))
  {
    var inputDueDate = new Date($scope.dueDate);
    var inputToDate = new Date($scope.toDate);
    if (inputDueDate < item.dueDate && inputToDate > item.dueDate )
    {
      return true;
    }
    else
    {
     return false;
    }
  }
else
  {
   return true;
  }      
};

解决方法

你熟悉角度引导UI吗?
http://angular-ui.github.io/bootstrap/

你可以在这里找到一个扩展名:http://eternicode.github.io/bootstrap-datepicker/

您可以使用日期选择器显示可用日期,而不是使用重复的日期列表.我认为它可能更容易被植入.

编辑:

否则,您可以编写日期范围过滤器来处理此功能.这可能是一个很好的起点
https://gist.github.com/Voles/5459410

用法:ng-repeat =“… | daterage:start:end”

我在电话上,所以此时无法给你实施.另一个用户可能有责任.

相关文章

前言 做过web项目开发的人对layer弹层组件肯定不陌生,作为l...
前言 前端表单校验是过滤无效数据、假数据、有毒数据的第一步...
前言 图片上传是web项目常见的需求,我基于之前的博客的代码...
前言 导出Excel文件这个功能,通常都是在后端实现返回前端一...
前言 众所周知,js是单线程的,从上往下,从左往右依次执行,...
前言 项目开发中,我们可能会碰到这样的需求:select标签,禁...