无法从控制器重置 Angular Material 设计表单

Unable to reset an Angular Material design Form from controller

我有一个 Angular Material 设计表单,其中有 3 个输入字段,其中有 required 选项。单击提交按钮后,我无法将表单重置为默认状态。我正在使用 $setPristine 将表单更改为原始状态,但在提交后出现红色错误行。提交表格后有什么办法可以消除这些错误。

谢谢。

Codepen Link: http://codepen.io/sateesh2499/pen/pbkjVV

查看:

<div ng-controller="AppCtrl" layout="column" ng-cloak="" class="inputdemoErrors" ng-app="MyApp">

  <form name="careersForm">
        <div class="careersContainer">
            <md-content>
                <div layout-gt-sm="row">
                    <md-input-container class="md-block" flex-gt-sm>
                        <label>Job Title</label>
                        <input type="text" name="jobTitle" ng-model="careers.jobTitle" required>
                    </md-input-container>
                    <md-input-container class="md-block" flex-gt-sm>
                        <label>Job Location</label>
                        <input type="text" name="jobLocation" ng-model="careers.jobLocation" required>
                    </md-input-container>
                    <md-input-container class="md-block" flex-gt-sm>
                        <label>Job Category</label>
                        <input type="text" name="jobCategory" ng-model="careers.jobCategory" required>
                    </md-input-container>
                </div>

            </md-content>
        </div>
        <div class="row text-center">
            <div class="col-sm-12">
                <md-button class="md-raised" style="width: 200px"
                           ng-click="postJob()">Submit</md-button>

            </div>
        </div>
    </form>
Pristine: {{careersForm.$pristine}}
</div>

控制器:

angular.module('MyApp',['ngMaterial', 'ngMessages', 'material.svgAssetsCache'])

.controller('AppCtrl', function($scope) {
  $scope.careers = {};
  $scope.postJob = function(){
    // after successful posting
    $scope.careers = {};
    $scope.careersForm.$setPristine();
  }
});

调用$setPristine后加上$scope.careersForm.$setUntouched();即可解决。

I've forked your plunker, where you can see it working. Plunker here

$scope.postJob = function(){
    // after successful posting
    $scope.careers = {};
    $scope.careersForm.$setPristine();
    $scope.careersForm.$setUntouched();
  }

无论如何,我认为您的代码应该可以工作...所以这可能是一个错误。

希望对您有所帮助