AngularJS sets the CSS classes ng-pristine
and ng-dirty
on any input field you've used ng-model on, and your FormController has the properties $pristine
and $dirty
which you can check to see if the form is dirty or not. So yes, it's possible.
Could you provide some code that shows what you're trying to do? That would make it easier to help you.
EDIT
Here's a simple example of how to detect a pristine/dirty state, and how to revert to a pristine state:
<!doctype html>
<html ng-app>
<head>
<script src="http://code.angularjs.org/1.1.2/angular.min.js"></script>
<script type="text/javascript">
function Ctrl($scope) {
var initial = {text: 'initial value'};
$scope.myModel = angular.copy(initial);
$scope.revert = function() {
$scope.myModel = angular.copy(initial);
$scope.myForm.$setPristine();
}
}
</script>
</head>
<body>
<form name="myForm" ng-controller="Ctrl">
myModel.text: <input name="input" ng-model="myModel.text">
<p>myModel.text = {{myModel.text}}</p>
<p>$pristine = {{myForm.$pristine}}</p>
<p>$dirty = {{myForm.$dirty}}</p>
<button ng-click="revert()">Set pristine</button>
</form>
</body>
</html>