]> source.dussan.org Git - jquery.git/commitdiff
Landing pull request 550. IE6,7,8 cannot use cached fragments from unknown elems...
authortimmywil <timmywillisn@gmail.com>
Sun, 23 Oct 2011 20:07:07 +0000 (16:07 -0400)
committertimmywil <timmywillisn@gmail.com>
Sun, 23 Oct 2011 20:08:10 +0000 (16:08 -0400)
More Details:
- https://github.com/jquery/jquery/pull/550
- http://bugs.jquery.com/ticket/10501

src/manipulation.js
test/data/testsuite.css
test/unit/manipulation.js

index 11dca31000dc63b700dbb341570d7292ed8a458f..9a662aca4522cf79f7e9ada44088abd5050e09ff 100644 (file)
@@ -1,23 +1,22 @@
 (function( jQuery ) {
 
 function createSafeFragment( document ) {
-       var nodeNames = (
-               "abbr article aside audio canvas datalist details figcaption figure footer " +
-               "header hgroup mark meter nav output progress section summary time video"
-       ).split( " " ),
+       var list = nodeNames.split( " " ),
        safeFrag = document.createDocumentFragment();
 
        if ( safeFrag.createElement ) {
-               while ( nodeNames.length ) {
+               while ( list.length ) {
                        safeFrag.createElement(
-                               nodeNames.pop()
+                               list.pop()
                        );
                }
        }
        return safeFrag;
 }
 
-var rinlinejQuery = / jQuery\d+="(?:\d+|null)"/g,
+var nodeNames = "abbr article aside audio canvas datalist details figcaption figure footer " +
+               "header hgroup mark meter nav output progress section summary time video",
+       rinlinejQuery = / jQuery\d+="(?:\d+|null)"/g,
        rleadingWhitespace = /^\s+/,
        rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/ig,
        rtagName = /<([\w:]+)/,
@@ -25,6 +24,7 @@ var rinlinejQuery = / jQuery\d+="(?:\d+|null)"/g,
        rhtml = /<|&#?\w+;/,
        rnoInnerhtml = /<(?:script|style)/i,
        rnocache = /<(?:script|object|embed|option|style)/i,
+       rnoshimcache = new RegExp("<(?:" + nodeNames.replace(" ", "|") + ")", "i"),
        // checked="checked" or checked
        rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i,
        rscriptType = /\/(java|ecma)script/i,
@@ -456,7 +456,8 @@ function cloneFixAttributes( src, dest ) {
 }
 
 jQuery.buildFragment = function( args, nodes, scripts ) {
-       var fragment, cacheable, cacheresults, doc;
+       var fragment, cacheable, cacheresults, doc,
+       first = args[ 0 ];
 
   // nodes may contain either an explicit document object,
   // a jQuery collection or context object.
@@ -476,12 +477,15 @@ jQuery.buildFragment = function( args, nodes, scripts ) {
        // Cloning options loses the selected state, so don't cache them
        // IE 6 doesn't like it when you put <object> or <embed> elements in a fragment
        // Also, WebKit does not clone 'checked' attributes on cloneNode, so don't cache
-       if ( args.length === 1 && typeof args[0] === "string" && args[0].length < 512 && doc === document &&
-               args[0].charAt(0) === "<" && !rnocache.test( args[0] ) && (jQuery.support.checkClone || !rchecked.test( args[0] )) ) {
+       // Lastly, IE6,7,8 will not correctly reuse cached fragments that were created from unknown elems #10501
+       if ( args.length === 1 && typeof first === "string" && first.length < 512 && doc === document &&
+               first.charAt(0) === "<" && !rnocache.test( first ) &&
+               (jQuery.support.checkClone || !rchecked.test( first )) &&
+               (!jQuery.support.unknownElems && rnoshimcache.test( first )) ) {
 
                cacheable = true;
 
-               cacheresults = jQuery.fragments[ args[0] ];
+               cacheresults = jQuery.fragments[ first ];
                if ( cacheresults && cacheresults !== 1 ) {
                        fragment = cacheresults;
                }
@@ -493,7 +497,7 @@ jQuery.buildFragment = function( args, nodes, scripts ) {
        }
 
        if ( cacheable ) {
-               jQuery.fragments[ args[0] ] = cacheresults ? fragment : 1;
+               jQuery.fragments[ first ] = cacheresults ? fragment : 1;
        }
 
        return { fragment: fragment, cacheable: cacheable };
@@ -735,7 +739,7 @@ jQuery.extend({
        },
 
        cleanData: function( elems ) {
-               var data, id, 
+               var data, id,
                        cache = jQuery.cache,
                        special = jQuery.event.special,
                        deleteExpando = jQuery.support.deleteExpando;
index 8c88a9334863448dba1a9fedad063d9f2d48cb06..d3e4b4e40a949620186c59fdf199779dd8bced52 100644 (file)
@@ -123,3 +123,6 @@ body, div { background: url(http://static.jquery.com/files/rocker/images/logo_jq
 
 /* #6652 REMOVE FILTER:ALPHA(OPACITY=100) AFTER ANIMATION */
 #t6652 div { filter: alpha(opacity=50); }
+
+/* #10501 */
+section { background:#f0f; display:block; }
\ No newline at end of file
index 0b1a1e66a2fe3274ddb6911e58e10b73c6c1491a..e8c7cd72a8a4f6f5533475f49bd4c9face3cd15b 100644 (file)
@@ -472,8 +472,18 @@ test("append HTML5 sectioning elements (Bug #6485)", function () {
        var article = jQuery("article"),
        aside = jQuery("aside");
 
-       equal( article.css("fontSize"), "10px", 'HTML5 elements are styleable');
-       equal( aside.length, 1, 'HTML5 elements do not collapse their children')
+       equal( article.css("fontSize"), "10px", "HTML5 elements are styleable");
+       equal( aside.length, 1, "HTML5 elements do not collapse their children")
+});
+
+test("HTML5 Elements inherit styles from style rules (Bug #10501)", function () {
+       expect(1);
+
+       jQuery("#qunit-fixture").append("<article id='article'></article>");
+       jQuery("#article").append("<section>This section should have a pink background.</section>");
+
+       // In IE, the missing background color will claim its value is "transparent"
+       notEqual( jQuery("section").css("background-color"), "transparent", "HTML5 elements inherit styles");
 });
 
 test("clone() (#6485)", function () {