The input is the following:
The action()
is exe
ngChange is just for the input, if you want to listen the model do like this
$scope.$watch('repair.test', function(newvalue,oldvalue) {
});
You can use a watcher-function in your controller
$scope.$watch('repair.test', function() {
$scope.action();
});
The ngChange expression is only evaluated when a change in the input value causes a new value to be committed to the model.
It will not be evaluated:
$parsers
transformation pipeline has
not changedTry to create a watcher using $scope.$watch - $watch(watchExpression, listener, [objectEquality]);
Example
$scope.$watch('repair.test', function(newValue, oldValue) {
// ...
});
Another solution would be to use a directive that watched the model for any changes instead of using ng-change
.
app.directive('onModelChange', function($parse){
return {
restrict: "A",
require: "?ngModel",
link: function(scope, elem, attrs, ctrl) {
scope.$watch(attrs['ngModel'], function (newValue, oldValue) {
if (typeof(newValue) === "undefined" || newValue == oldValue) {
return;
}
var changeExpr = $parse(attrs['onModelChange']);
if (changeExpr) {
changeExpr(scope);
}
});
}
};
});
Then you would use it like so:
<input class="value" type="text" ng-model="myVar" on-model-change="doSomething(myVar)"/>