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(); }); |
