diff options
| author | Misko Hevery | 2010-07-15 13:13:21 -0700 | 
|---|---|---|
| committer | Misko Hevery | 2010-07-15 13:13:21 -0700 | 
| commit | 9abd10e7b8a34b9dcd1a6af5ff37f57bd27cf920 (patch) | |
| tree | 1dac2305341b58cb595ebc4b71ea5debf121e37b /src/directives.js | |
| parent | 09e2295975b5bb8dfc067303fee86a9f2ebb433d (diff) | |
| download | angular.js-9abd10e7b8a34b9dcd1a6af5ff37f57bd27cf920.tar.bz2 | |
proper handlig of $element in filters
Diffstat (limited to 'src/directives.js')
| -rw-r--r-- | src/directives.js | 18 | 
1 files changed, 11 insertions, 7 deletions
diff --git a/src/directives.js b/src/directives.js index bcc427e8..b57e5ecd 100644 --- a/src/directives.js +++ b/src/directives.js @@ -26,12 +26,13 @@ angularDirective("ng:bind", function(expression){    return function(element) {      var lastValue = noop, lastError = noop;      this.$onEval(function() { -      var error, -          value = this.$tryEval(expression, function(e){ -            error = toJson(e); -          }), -          isHtml, -          isDomElement; +      var error, value, isHtml, isDomElement, +          oldElement = this.hasOwnProperty('$element') ? this.$element : undefined; +      this.$element = element; +      value = this.$tryEval(expression, function(e){ +        error = toJson(e); +      }); +      this.$element = oldElement;        if (lastValue === value && lastError == error) return;        isHtml = value instanceof HTML,        isDomElement = isElement(value); @@ -74,7 +75,9 @@ function compileBindTemplate(template){        });      });      bindTemplateCache[template] = fn = function(element){ -      var parts = [], self = this; +      var parts = [], self = this, +         oldElement = this.hasOwnProperty('$element') ? this.$element : undefined; +      this.$element = element;        for ( var i = 0; i < bindings.length; i++) {          var value = bindings[i].call(self, element);          if (isElement(value)) @@ -83,6 +86,7 @@ function compileBindTemplate(template){            value = toJson(value, true);          parts.push(value);        }; +      this.$element = oldElement;        return parts.join('');      };    }  | 
