在我的页面中,我有一个包含添加,编辑和删除操作的表。表中的一列是审核日期。对日期的限制是日期值可以是从表格填充前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
非常感谢任何帮助
答案 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。