]> source.dussan.org Git - jquery.git/commitdiff
jQuery.buildFragment, ensure doc is a document; Includes comments; Adds unit test... 365/head
authorRick Waldron <waldron.rick@gmail.com>
Sat, 30 Apr 2011 14:42:36 +0000 (10:42 -0400)
committerRick Waldron <waldron.rick@gmail.com>
Sat, 30 Apr 2011 14:42:36 +0000 (10:42 -0400)
src/manipulation.js
test/unit/manipulation.js

index 610d19b7ad0db25130fa3b896ac19bfe5eb8dba7..aeea083a908135961495748339de6404549ecad3 100644 (file)
@@ -437,8 +437,21 @@ function cloneFixAttributes( src, dest ) {
 }
 
 jQuery.buildFragment = function( args, nodes, scripts ) {
-       var fragment, cacheable, cacheresults,
-               doc = (nodes && nodes[0] ? nodes[0].ownerDocument || nodes[0] : document);
+       var fragment, cacheable, cacheresults, doc;
+
+  // nodes may contain either an explicit document object,
+  // a jQuery collection or context object.
+  // If nodes[0] contains a valid object to assign to doc
+  if ( nodes && nodes[0] ) {
+    doc = nodes[0].ownerDocument || nodes[0];
+  }
+
+  // Ensure that an attr object doesn't incorrectly stand in as a document object
+       // Chrome and Firefox seem to allow this to occur and will throw exception
+       // Fixes #8950
+       if ( !doc.createDocumentFragment ) {
+               doc = document;
+       }
 
        // Only cache "small" (1/2 KB) HTML strings that are associated with the main document
        // Cloning options loses the selected state, so don't cache them
@@ -500,7 +513,7 @@ jQuery.each({
 function getAll( elem ) {
        if ( "getElementsByTagName" in elem ) {
                return elem.getElementsByTagName( "*" );
-       
+
        } else if ( "querySelectorAll" in elem ) {
                return elem.querySelectorAll( "*" );
 
@@ -746,4 +759,4 @@ function evalScript( i, elem ) {
        }
 }
 
-})( jQuery );
+})( jQuery );
\ No newline at end of file
index b71b6962eac3ac8091df6469a6a900c48ce6ba94..a2b5c2e59dd78e8bdfee9055ad5ea902914acce6 100644 (file)
@@ -1382,6 +1382,15 @@ test("jQuery.buildFragment - no plain-text caching (Bug #6779)", function() {
                }
                catch(e) {}
        }
-    equals($f.text(), bad.join(""), "Cached strings that match Object properties");
+       equals($f.text(), bad.join(""), "Cached strings that match Object properties");
        $f.remove();
 });
+
+test("jQuery.buildFragment - plain objects are not a document #8950", function() {
+       expect(1);
+
+       try {
+               jQuery('<input type="hidden">', {});
+               ok( true, "Does not allow attribute object to be treated like a doc object");
+       } catch (e) {}
+});