diff options
| author | Michał Gołębiowski | 2013-04-30 11:29:07 +0200 | 
|---|---|---|
| committer | Vojta Jina | 2013-05-23 12:05:55 -0700 | 
| commit | da5f537ccdb0a7b4155f13f7a70ca7981ad6f689 (patch) | |
| tree | 30fc4349dc22289d110f1bfdea0db076121a89c0 /src/jqLite.js | |
| parent | 041f118b01933fa07098f1333be8e2cf1a28f248 (diff) | |
| download | angular.js-da5f537ccdb0a7b4155f13f7a70ca7981ad6f689.tar.bz2 | |
fix(jqLite): correctly monkey-patch core jQuery methods
When real jQuery is present, Angular monkey patch it to fire `$destroy` event.
This commit fixes two issues in the jQuery patch:
- passing a selector to the $.fn.remove method (only fire `$destroy` on the matched elements)
- using `$.fn.html` without parameters as a getter (do not fire `$destroy`)
Diffstat (limited to 'src/jqLite.js')
| -rw-r--r-- | src/jqLite.js | 41 | 
1 files changed, 21 insertions, 20 deletions
diff --git a/src/jqLite.js b/src/jqLite.js index 6809da74..218b9683 100644 --- a/src/jqLite.js +++ b/src/jqLite.js @@ -107,37 +107,38 @@ function camelCase(name) {  /////////////////////////////////////////////  // jQuery mutation patch  // -//  In conjunction with bindJQuery intercepts all jQuery's DOM destruction apis and fires a +// In conjunction with bindJQuery intercepts all jQuery's DOM destruction apis and fires a  // $destroy event on all DOM nodes being removed.  //  ///////////////////////////////////////////// -function JQLitePatchJQueryRemove(name, dispatchThis) { +function JQLitePatchJQueryRemove(name, dispatchThis, filterElems, getterIfNoArguments) {    var originalJqFn = jQuery.fn[name];    originalJqFn = originalJqFn.$original || originalJqFn;    removePatch.$original = originalJqFn;    jQuery.fn[name] = removePatch; -  function removePatch() { -    var list = [this], +  function removePatch(param) { +    var list = filterElems && param ? [this.filter(param)] : [this],          fireEvent = dispatchThis,          set, setIndex, setLength, -        element, childIndex, childLength, children, -        fns, events; - -    while(list.length) { -      set = list.shift(); -      for(setIndex = 0, setLength = set.length; setIndex < setLength; setIndex++) { -        element = jqLite(set[setIndex]); -        if (fireEvent) { -          element.triggerHandler('$destroy'); -        } else { -          fireEvent = !fireEvent; -        } -        for(childIndex = 0, childLength = (children = element.children()).length; -            childIndex < childLength; -            childIndex++) { -          list.push(jQuery(children[childIndex])); +        element, childIndex, childLength, children; + +    if (!getterIfNoArguments || param != null) { +      while(list.length) { +        set = list.shift(); +        for(setIndex = 0, setLength = set.length; setIndex < setLength; setIndex++) { +          element = jqLite(set[setIndex]); +          if (fireEvent) { +            element.triggerHandler('$destroy'); +          } else { +            fireEvent = !fireEvent; +          } +          for(childIndex = 0, childLength = (children = element.children()).length; +              childIndex < childLength; +              childIndex++) { +            list.push(jQuery(children[childIndex])); +          }          }        }      }  | 
