检入控制器哪个输入元素已被修改

时间:2017-03-29 04:42:57

标签: angularjs input updatemodel angularjs-forms

我需要检查哪个输入元素已在更新形式中修改过。

    <form name="utilizationForm" role="form" novalidate>
    <div class="row" data-ng-repeat="i in [1,2,3,4]">
            <div class="col-md-3"> 
                <div asterick class="form-group" ng-class="{'form-group has-success': !error['resource_type'] && (submitted), 'form-group has-error': (error['resource_type']) && (submitted)}"> 
                    <label for="resourceType">Resource Type</label>
                    <input type="hidden" name="id" id="id" class="form-control" ng-model="data['id' + i]" value="">
                                        <select name="resourceType" id="resourceType" ng-model="data['resource_type' + i]" class="form-control" ng-required="true"  >
                                            <option ng-repeat="option in resourceTypeJson" value="{{option}}">{{option}}</option>
                                        </select>
                    <span class="er-block" ng-show="utilizationForm.resourceType.$touched && utilizationForm.resourceType.$error.required">Please provide Resource type.</span>
                    <span ng-show="error.resource_type1" class="er-block">{{error.resource_type1}}</span>
                </div>    
            </div>
            <div class="col-md-3">
                <label for="efforts">Efforts (in hours)</label>
                <input type="hidden" name="id" id="id" class="form-control" ng-model="data['id' + i]" value="">
                <input type="text"  test-change name="efforts" id="efforts" class="form-control" ng-model="data['efforts' + i]"  value="">
            </div>
        </div>
        <div class="text-right" ng-class="{'col-md-6 mt25': showCompletion}">
            <button class="btn btn-primary" ng-disabled="utilizationForm.$invalid" ng-click="addUtilizationReport()">{{buttonText}}</button>
        </div>

    </form>

现在,当我点击更新按钮时,我需要检查哪个输入元素已在控制器中以更新形式进行了修改。请帮忙。

2 个答案:

答案 0 :(得分:2)

如果您将输入放在具有name属性的表单中,然后为输入提供name属性,您还可以访问输入的$dirty属性。

<div ng-controller="MyController">
  <form name="myForm">
    <input type="text" name="first" ng-model="firstName">
    <input type="text" name="last" ng-model="lastName">
  </form>
</div>
app.controller('MyController', function($scope) {
  // Here you have access to the inputs' `$dirty` property
  console.log($scope.myForm.first.$dirty);
  console.log($scope.myForm.last.$dirty);
});

您可以使用$scope.myForm.$dirty查看是否有任何字段已更改,以及表单上每个输入属性的$dirty属性,以查看该输入是否已更改。您甚至可以迭代myForm对象(非输入字段对象的前缀为$的键):

angular.forEach($scope.myForm, function(value, key) {
  if(key[0] == '$') return;
  console.log(key, value.$dirty)
});

答案 1 :(得分:1)

以下是在控制器中使用$ watch的最简单示例:

var app = angular.module('myApp', []);
app.controller('appCtrl', function($scope, $location) {
    $scope.$watch('abc', function(newVal,oldVal) {
      if(oldVal != newVal){
        alert("value changed!");
      }    
    });
});
<script src="https://ajax.googleapis.com/ajax/libs/angularjs/1.2.23/angular.min.js"></script>
<script src="https://ajax.googleapis.com/ajax/libs/jquery/2.1.1/jquery.min.js"></script>
<div ng-app="myApp" ng-controller="appCtrl">
 <input type="text" name="first" ng-model="abc">
</div>