提交表单后如何重置表单和验证(AngularJS)

How reset form and validation after submitting form (AngularJS)

本文关键字:表单 AngularJS 验证 何重置 提交      更新时间:2023-09-26

我想在提交表单后重置表单和所有验证消息。这是plunker:http://plnkr.co/edit/992RP8gemIjgc3KxzLvQ?p =

预览

我的代码如下:

控制器:

app.controller('MainCtrl', function($scope) {
  $scope.data={fullName:''};
  $scope.submit=function(){
    console.log('submit')
    $scope.myForm.$setPristine();
    $scope.myForm.$setUntouched();
    $scope.data={fullName:''};
  }
});
HTML:

<body ng-controller="MainCtrl">
<form name="myForm" novalidate>
<div>
    <label class="control-label">Name</label>
    <input
            name="full_name"
            type="text"
            ng-model="data.fullName"
            ng-required="true">
    <p ng-if="myForm.$submitted && myForm.$invalid">Validation message</p>
</div>
<button ng-click="submit()" type="submit">
    Submit
</button>
</form>
</body>

我的问题是:当用户在输入中输入名称并单击Submit按钮时,不应该显示验证消息,因为模型、表单和验证应该被重置。我该怎么做呢?

我尝试使用$ set质朴()和$ setuntouch(),但它不适合我。

在AngularJS中可以做到吗?谢谢!

我很惊讶,但是$setpristine()没有更新$submitted

这可能不是最漂亮的解决方案,但似乎有效:

app.controller('MainCtrl', function($scope, $timeout) {
  $scope.data = {
    fullName: ''
  };
  $scope.submit = function() {
    console.log('submit')
     $scope.data = {
      fullName: ''
    };
    $timeout(function() {
      $scope.myForm.$setPristine();
      $scope.myForm.$setUntouched();
      $scope.myForm.$submitted = false;
    });   
  }
});
演示