Don't cache non-html strings in buildFragment to avoid possible collision with the names of Object methods like toString. Also makes the unit tests 0.5% to 8% faster. Fixes #6779.
This commit is contained in:
parent
64ee5581af
commit
5fd21fc02b
2 changed files with 19 additions and 2 deletions
|
@ -1247,3 +1247,20 @@ test("jQuery.cleanData", function() {
|
|||
return div;
|
||||
}
|
||||
});
|
||||
|
||||
test("jQuery.buildFragment - no plain-text caching (Bug #6779)", function() {
|
||||
expect(1);
|
||||
|
||||
// DOM manipulation fails if added text matches an Object method
|
||||
var $f = jQuery( "<div />" ).appendTo( "#main" ),
|
||||
bad = [ "start-", "toString", "hasOwnProperty", "append", "here&there!", "-end" ];
|
||||
|
||||
for ( var i=0; i < bad.length; i++ ) {
|
||||
try {
|
||||
$f.append( bad[i] );
|
||||
}
|
||||
catch(e) {}
|
||||
}
|
||||
equals($f.text(), bad.join(''), "Cached strings that match Object properties");
|
||||
$f.remove();
|
||||
});
|
||||
|
|
Loading…
Add table
Add a link
Reference in a new issue