我有一个角度的形式。这些字段使用ng-pattern
属性进行验证。我也有一个重置按钮。我使用的是3210处理reset
事件,像这样:如何重置表单,包括删除所有验证错误?
<form name="searchForm" id="searchForm" ui-event="{reset: 'reset(searchForm)'}" ng-submit="search()">
<div>
<label>
Area Code
<input type="tel" name="areaCode" ng-model="areaCode" ng-pattern="/^([0-9]{3})?$/">
</label>
<div ng-messages="searchForm.areaCode.$error">
<div class="error" ng-message="pattern">The area code must be three digits</div>
</div>
</div>
<div>
<label>
Phone Number
<input type="tel" name="phoneNumber" ng-model="phoneNumber" ng-pattern="/^([0-9]{7})?$/">
</label>
<div ng-messages="searchForm.phoneNumber.$error">
<div class="error" ng-message="pattern">The phone number must be seven digits</div>
</div>
</div>
<br>
<div>
<button type="reset">Reset</button>
<button type="submit" ng-disabled="searchForm.$invalid">Search</button>
</div>
</form>
正如你所看到的,当表单被重置它呼吁$scope
的reset
方法。这里是整个控制器的样子:
angular.module('app').controller('mainController', function($scope) {
$scope.resetCount = 0;
$scope.reset = function(form) {
form.$setPristine();
form.$setUntouched();
$scope.resetCount++;
};
$scope.search = function() {
alert('Searching');
};
});
我打电话form.$setPristine()
和form.$setUntouched
,以下从another question这里对堆栈溢出的意见。我添加计数器的唯一原因是要证明代码正在被调用(它是什么)。
问题是,即使重新设置窗体后,验证消息也不会消失。您可以在Plunker上看到完整的代码。下面是显示该错误不会消失截图:
只有似乎事为我工作是手动重置每个表单变量(即'form.areaCode ='';'和'form.phoneNumber ='';')。这就是你通常会这样做的方式。 – Brett