我正在开发一个应用程序,当用户更改某些内容时会自动保存更改,例如输入字段的值。我编写了一个autosave
指令,该指令被添加到所有应该自动触发保存事件的表单字段中。
模板:
<input ng-model="fooCtrl.name" autosave>
<input ng-model="fooCtrl.email" autosave>
指示:
.directive('autosave', ['$parse', function ($parse) {
return {
restrict: 'A',
require: 'ngModel',
link: function (scope, element, attrs, ngModel) {
function saveIfModelChanged () {
// save object containing name and email to server ...
}
ngModel.$viewChangeListeners.push(function () {
saveIfModelChanged();
});
}
};
}]);
到目前为止,这一切对我来说都很好。但是,当我将验证添加到组合中时,例如验证输入字段是有效的电子邮件地址,undefined
一旦 viewValue 更改为无效的电子邮件地址,modelValue 就会设置为。
我想做的是:记住最后一个有效的模型值并在自动保存时使用它。如果用户将电子邮件地址更改为无效,则包含name
和的对象email
仍应保存到服务器。使用当前有效name
和最后有效email
。
我开始保存最后一个有效的模型值,如下所示:
添加了验证的模板:
<input type="email" ng-model="fooCtrl.name" autosave required>
<input ng-model="fooCtrl.email" autosave required>
保存 lastModelValue 的指令:
.directive('autosave', ['$parse', function ($parse) {
return {
restrict: 'A',
require: 'ngModel',
link: function (scope, element, attrs, ngModel) {
var lastModelValue;
function saveIfModelChanged () {
// remeber last valid modelValue
if (ngModel.$valid) {
lastModelValue = ngModel.$modelValue;
}
// save object containing current or last valid
// name and email to server ...
}
ngModel.$viewChangeListeners.push(function () {
saveIfModelChanged();
});
}
};
}]);
我的问题是,如何lastModelValue
在保存的同时使用,但在视图中保留无效值?
编辑:
正如下面 Jugnu 所建议的,另一种可能性是包装和操作验证器中的构建。
我试图遵循:包装所有现有的验证器并记住最后一个有效值,以在验证失败时恢复它:
Object.keys(ngModel.$validators).forEach(function(validatorName, index) {
var validator = ngModel.$validators[validatorName];
ngModel.$validators[validatorName] = createWrapper(validatorName, validator, ngModel);
});
function createWrapper(validatorName, validator, ngModel){
var lastValid;
return function (modelValue){
var result = validator(modelValue);
if(result) {
lastValid = modelValue;
}else{
// what to do here? maybe asign the value like this:
// $parse(attrs.ngModel).assign(scope, lastValid);
}
return result;
};
}
但我也不确定如何继续使用这种方法。我可以在没有 AngularJS 的情况下设置模型值并尝试验证新设置的值吗?