表格中的最小和最大日期jquery datepicker与ng-repeat

时间:2017-12-01 15:43:17

标签: javascript jquery angularjs asp.net-mvc datepicker

在我的页面中,我有一个包含添加,编辑和删除操作的表。表中的一列是审核日期。对日期的限制是日期值可以是从表格填充前10分钟到任何一天的任何地方。

当我在表外添加最小和最大日期限制时,它工作正常 但是我在表格中添加它的那一刻它不起作用

Date Outside Table (Works Perfectly)
<input type="text" datepicker="" ng-model="auditDate" id="AddAudit" /> 

$("#AddAudit").datepicker({
    maxDate: '-1',
    minDate: '-10M'
});


Date in Table  (does not work :-( )
<table ng-repeat="i in list">
    <tr>
        <td>
            <input type="text" datepicker="" ng-model="i.startDate" ng-change="dateChanged(i)" id="EditAuditDate_{{i.id}}" />
        </td>
    </tr>    
</table>

$scope.dateChanged = function(item) {
var inpAuditDate = "#EditAuditDate_" + item.id;
    $(inpAuditDate).datepicker({
        maxDate: '-1',
        minDate: '-10M'
    });
};

I have created an example to show the issue

非常感谢任何帮助

1 个答案:

答案 0 :(得分:0)

您可以将min / max选项移动到指令代码,而不是从多个位置加载 datepicker 插件。您最终清理控制器并将选择逻辑保留在指令中:

var app = angular.module('app', []);
app.controller('TestController', function ($scope, $window) {
    $scope.list = [{
            id: 1
        },
        {
            id: 2
        },
        {
            id: 3
        }];
});

app.directive('datepicker', function() {
  return {
    require: 'ngModel',
    link: function(scope, el, attr, ngModel) {
      $(el).datepicker({
        maxDate: '-1',
        minDate: '-10M',
        onSelect: function(dateText) {
          scope.$apply(function() {
            ngModel.$setViewValue(dateText);
          });
        }
      });
    }
  };
});

工作sample