我想创建一个允许用户以各种格式输入日期的指令。当基础模型发生变化时(无论是通过直接用户输入还是以编程方式),我希望它以标准化格式显示日期。
“野外”的一个例子是Google Flights上的出发和返回日期输入。
这是我的代码(根本不起作用)。
查看
<input type="text" ng-model="params.departDate"
date-input display-format="{Weekday} {d} {Month}, {yyyy}">
CONTROLLER
app.controller('MainCtrl', function($scope) {
$scope.params = {
departDate: new Date()
};
$scope.isDate = function() {
return $scope.params.departDate instanceof Date;
}
});
指令
app.directive("dateInput", function() {
return {
require: 'ngModel',
scope: {
displayFormat: '@'
},
link: function (scope, element, attrs, ngModel) {
ngModel.$parsers.push(function (viewVal) {
if (viewVal) {
// Using sugar.js for date parsing
var parsedValue = Date.create(viewVal);
if (parsedValue.isValid()) {
ngModel.$setValidity("date", true);
return parsedValue;
}
}
ngModel.$setValidity("date", false);
return viewVal;
});
ngModel.$formatters.unshift(function (modelVal) {
if (modelVal){
// Using sugar.js for date formatting
var date = Date.create(modelVal);
if (date.isValid()) {
return date.format(scope.displayFormat || '{Weekday} {d} {Month}, {yyyy}')
}
}
return modelVal;
});
}
};
})
这甚至没有像我预期的那样接近工作。我做错了什么?
这是一个PLUNKR:http://plnkr.co/edit/583yOD6aRhRD8Y2bA5gU?p=preview
答案 0 :(得分:3)
如评论中所述,ng-model和隔离范围不能很好地混合,请参阅Can I use ng-model with isolated scope?。
我建议不要在你的指令中创建任何范围,并使用attrs访问display-format属性:
var displayFormat = attrs.displayFormat;
答案 1 :(得分:1)
我也更喜欢具有可重复使用指令的隔离范围,在这种情况下,必须为ng-model提供父范围的正确路径:ng-model =&#34; $ parent.params.departDate&#34;
更新了plunker: http://plnkr.co/edit/DuR6Om2kyzWD67hYExSh?p=preview