diff options
| author | Misko Hevery | 2011-07-14 13:54:34 -0700 | 
|---|---|---|
| committer | Misko Hevery | 2011-07-26 09:41:44 -0700 | 
| commit | 3237f8b9950ab0dbf3c80f6bef40217ea7cf96ae (patch) | |
| tree | c04e4c6ae97a2e6fbfd4b9e47c7ba993c3561afc /src/widgets.js | |
| parent | 7802c90e139a36d37b9d3c8cd6b6fcfee042dd71 (diff) | |
| download | angular.js-3237f8b9950ab0dbf3c80f6bef40217ea7cf96ae.tar.bz2 | |
fix(directive): ng:options to support ng:change
Closes #463
Diffstat (limited to 'src/widgets.js')
| -rw-r--r-- | src/widgets.js | 6 | 
1 files changed, 5 insertions, 1 deletions
diff --git a/src/widgets.js b/src/widgets.js index bdd68804..17a14741 100644 --- a/src/widgets.js +++ b/src/widgets.js @@ -674,6 +674,7 @@ angularWidget('select', function(element){    this.directives(true);    var isMultiselect = element.attr('multiple');    var expression = element.attr('ng:options'); +  var onChange = expressionCompile(element.attr('ng:change') || "").fnSelf;    var match;    if (!expression) {      return inputWidgetSelector.call(this, element); @@ -729,7 +730,10 @@ angularWidget('select', function(element){              value = valueFn(tempScope);            }          } -        if (!isUndefined(value)) model.set(value); +        if (!isUndefined(value) && model.get() !== value) { +          onChange(scope); +          model.set(value); +        }          scope.$tryEval(function(){            scope.$root.$eval();          });  | 
