diff options
135 files changed, 8857 insertions, 8084 deletions
@@ -1,6 +1,13 @@ { "preset": "jquery", - "excludeFiles": [ "external", "src/intro.js", "src/outro.js", - "test/node_smoke_tests/lib/ensure_iterability.js" ] + // remove after https://github.com/jscs-dev/node-jscs/issues/1685 + // and https://github.com/jscs-dev/node-jscs/issues/1686 + "requireCapitalizedComments": null, + + "excludeFiles": [ + "external", "src/intro.js", "src/outro.js", + "node_modules", + "test/node_smoke_tests/lib/ensure_iterability.js" + ] } diff --git a/Gruntfile.js b/Gruntfile.js index eaf0cf7bb..d5611904a 100644 --- a/Gruntfile.js +++ b/Gruntfile.js @@ -20,7 +20,7 @@ module.exports = function( grunt ) { // But our modules can delete srcHintOptions.onevar; - grunt.initConfig({ + grunt.initConfig( { pkg: grunt.file.readJSON( "package.json" ), dst: readOptionalJSON( "dist/.destination.json" ), "compare_size": { @@ -107,7 +107,12 @@ module.exports = function( grunt ) { gruntfile: "Gruntfile.js", // Check parts of tests that pass - test: [ "test/data/testrunner.js", "test/unit/animation.js", "test/unit/tween.js" ], + test: [ + "test/data/testrunner.js", + "test/unit/animation.js", + "test/unit/tween.js", + "test/unit/wrap.js" + ], build: "build" }, testswarm: { @@ -160,7 +165,7 @@ module.exports = function( grunt ) { } } } - }); + } ); // Load grunt tasks from NPM packages require( "load-grunt-tasks" )( grunt ); diff --git a/build/release.js b/build/release.js index 81d46a3b8..9e31e80d6 100644 --- a/build/release.js +++ b/build/release.js @@ -10,7 +10,7 @@ module.exports = function( Release ) { npmTags = Release.npmTags, createTag = Release._createTag; - Release.define({ + Release.define( { npmPublish: true, issueTracker: "github", /** @@ -48,6 +48,7 @@ module.exports = function( Release ) { * for publishing the distribution repo instead */ npmTags: function() { + // origRepo is not defined if dist was skipped Release.dir.repo = Release.dir.origRepo || Release.dir.repo; return npmTags(); @@ -59,9 +60,9 @@ module.exports = function( Release ) { dist: function( callback ) { cdn.makeArchives( Release, function() { dist( Release, callback ); - }); + } ); } - }); + } ); }; module.exports.dependencies = [ diff --git a/build/release/cdn.js b/build/release/cdn.js index 5a45a629d..67bcd73fc 100644 --- a/build/release/cdn.js +++ b/build/release/cdn.js @@ -33,13 +33,14 @@ function makeReleaseCopies( Release ) { var version = Release.newVersion.replace( "-compat", "" ); shell.mkdir( "-p", cdnFolder ); - Object.keys( releaseFiles ).forEach(function( key ) { + Object.keys( releaseFiles ).forEach( function( key ) { var text, builtFile = releaseFiles[ key ], unpathedFile = key.replace( /VER/g, version ), releaseFile = cdnFolder + "/" + unpathedFile; if ( /\.map$/.test( releaseFile ) ) { + // Map files need to reference the new uncompressed name; // assume that all files reside in the same directory. // "file":"jquery.min.js","sources":["jquery.js"] @@ -51,7 +52,7 @@ function makeReleaseCopies( Release ) { } else if ( builtFile !== releaseFile ) { shell.cp( "-f", builtFile, releaseFile ); } - }); + } ); } function makeArchives( Release, callback ) { @@ -80,16 +81,17 @@ function makeArchives( Release, callback ) { output.on( "error", function( err ) { throw err; - }); + } ); archiver.pipe( output ); - files = files.map(function( item ) { + files = files.map( function( item ) { return "dist" + ( rver.test( item ) ? "/cdn" : "" ) + "/" + item.replace( rver, version ); - }); + } ); sum = Release.exec( + // Read jQuery files "md5sum " + files.join( " " ).replace( rcompat, "." ), "Error retrieving md5sum" @@ -97,11 +99,12 @@ function makeArchives( Release, callback ) { fs.writeFileSync( "./" + md5file, sum ); files.push( md5file ); - files.forEach(function( file ) { + files.forEach( function( file ) { + // For Google, read jquery.js, write jquery-compat.js archiver.append( fs.createReadStream( file.replace( rcompat, "." ) ), { name: path.basename( file ) } ); - }); + } ); archiver.finalize(); } @@ -114,9 +117,9 @@ function makeArchives( Release, callback ) { makeArchive( "mscdn", msFilesCDN, callback ); } - buildGoogleCDN(function() { + buildGoogleCDN( function() { buildMicrosoftCDN( callback ); - }); + } ); } module.exports = { diff --git a/build/release/dist.js b/build/release/dist.js index 56bd19509..0faa8aab0 100644 --- a/build/release/dist.js +++ b/build/release/dist.js @@ -5,6 +5,7 @@ module.exports = function( Release, complete ) { shell = require( "shelljs" ), pkg = require( Release.dir.repo + "/package.json" ), distRemote = Release.remote.replace( "jquery.git", "jquery-compat-dist.git" ), + // These files are included with the distribution files = [ "src", @@ -34,7 +35,7 @@ module.exports = function( Release, complete ) { * Generate bower file for jquery-compat-dist */ function generateBower() { - return JSON.stringify({ + return JSON.stringify( { name: pkg.name, main: pkg.main, license: "MIT", @@ -42,7 +43,7 @@ module.exports = function( Release, complete ) { "package.json" ], keywords: pkg.keywords - }, null, 2); + }, null, 2 ); } /** @@ -57,14 +58,14 @@ module.exports = function( Release, complete ) { "dist/jquery.js", "dist/jquery.min.js", "dist/jquery.min.map" - ].forEach(function( file ) { + ].forEach( function( file ) { shell.cp( Release.dir.repo + "/" + file, distFolder ); - }); + } ); // Copy other files - files.forEach(function( file ) { + files.forEach( function( file ) { shell.cp( "-r", Release.dir.repo + "/" + file, Release.dir.dist ); - }); + } ); // Write generated bower file fs.writeFileSync( Release.dir.dist + "/bower.json", generateBower() ); diff --git a/build/release/ensure-sizzle.js b/build/release/ensure-sizzle.js index c3e4ed159..795760643 100644 --- a/build/release/ensure-sizzle.js +++ b/build/release/ensure-sizzle.js @@ -8,7 +8,7 @@ var fs = require( "fs" ), * @param {Function(string)} callback */ function getLatestSizzle( callback ) { - npm.load(function( err, npm ) { + npm.load( function( err, npm ) { if ( err ) { throw err; } @@ -17,8 +17,8 @@ function getLatestSizzle( callback ) { throw err; } callback( Object.keys( info )[ 0 ] ); - }); - }); + } ); + } ); } /** @@ -29,11 +29,12 @@ function getLatestSizzle( callback ) { function ensureSizzle( Release, callback ) { console.log(); console.log( "Checking Sizzle version..." ); - getLatestSizzle(function( latest ) { + getLatestSizzle( function( latest ) { var match = rversion.exec( fs.readFileSync( sizzleLoc, "utf8" ) ), version = match ? match[ 1 ] : "Not Found"; if ( version !== latest ) { + // colors is inherited from jquery-release console.log( "The Sizzle version in the src folder (" + version.red + @@ -44,7 +45,7 @@ function ensureSizzle( Release, callback ) { console.log( "Sizzle is latest (" + latest.green + ")" ); callback(); } - }); + } ); } module.exports = ensureSizzle; diff --git a/build/release/release-notes.js b/build/release/release-notes.js index 00cdc8659..f3f6a6ff2 100644 --- a/build/release/release-notes.js +++ b/build/release/release-notes.js @@ -3,16 +3,16 @@ * jQuery Release Note Generator */ -var http = require("http"), +var http = require( "http" ), extract = /<a href="\/ticket\/(\d+)" title="View ticket">(.*?)<[^"]+"component">\s*(\S+)/g, - version = process.argv[2]; + version = process.argv[ 2 ]; if ( !/^\d+\.\d+/.test( version ) ) { console.error( "Invalid version number: " + version ); process.exit( 1 ); } -http.request({ +http.request( { host: "bugs.jquery.com", port: 80, method: "GET", @@ -23,34 +23,36 @@ http.request({ res.on( "data", function( chunk ) { data.push( chunk ); - }); + } ); res.on( "end", function() { var match, cur, cat, - file = data.join(""); + file = data.join( "" ); - while ( (match = extract.exec( file )) ) { - if ( "#" + match[1] !== match[2] ) { - cat = match[3]; + while ( ( match = extract.exec( file ) ) ) { + if ( "#" + match[ 1 ] !== match[ 2 ] ) { + cat = match[ 3 ]; if ( !cur || cur !== cat ) { if ( cur ) { - console.log("</ul>"); + console.log( "</ul>" ); } cur = cat; - console.log( "<h3>" + cat.charAt(0).toUpperCase() + cat.slice(1) + "</h3>" ); - console.log("<ul>"); + console.log( + "<h3>" + cat.charAt( 0 ).toUpperCase() + cat.slice( 1 ) + "</h3>" + ); + console.log( "<ul>" ); } console.log( - " <li><a href=\"http://bugs.jquery.com/ticket/" + match[1] + "\">#" + - match[1] + ": " + match[2] + "</a></li>" + " <li><a href=\"http://bugs.jquery.com/ticket/" + match[ 1 ] + "\">#" + + match[ 1 ] + ": " + match[ 2 ] + "</a></li>" ); } } if ( cur ) { - console.log("</ul>"); + console.log( "</ul>" ); } - }); -}).end(); + } ); +} ).end(); diff --git a/build/tasks/build.js b/build/tasks/build.js index 1c76f6eff..5ddba17df 100644 --- a/build/tasks/build.js +++ b/build/tasks/build.js @@ -16,12 +16,16 @@ module.exports = function( grunt ) { baseUrl: "src", name: "jquery", out: "dist/jquery.js", + // We have multiple minify steps optimize: "none", + // Include dependencies loaded with require findNestedDependencies: true, + // Avoid inserting define() placeholder skipModuleInsertion: true, + // Avoid breaking semicolons inserted by r.js skipSemiColonInsertion: true, wrap: { @@ -47,15 +51,17 @@ module.exports = function( grunt ) { */ function convert( name, path, contents ) { var amdName; + // Convert var modules if ( /.\/var\//.test( path ) ) { contents = contents - .replace( /define\([\w\W]*?return/, "var " + (/var\/([\w-]+)/.exec(name)[1]) + " =" ) + .replace( /define\([\w\W]*?return/, "var " + ( /var\/([\w-]+)/.exec( name )[ 1 ] ) + " =" ) .replace( rdefineEnd, "" ); // Sizzle treatment } else if ( /^sizzle$/.test( name ) ) { contents = "var Sizzle =\n" + contents + // Remove EXPOSE lines from Sizzle .replace( /\/\/\s*EXPOSE[\w\W]*\/\/\s*EXPOSE/, "return Sizzle;" ); @@ -63,6 +69,7 @@ module.exports = function( grunt ) { contents = contents .replace( /\s*return\s+[^\}]+(\}\);[^\w\}]*)$/, "$1" ) + // Multiple exports .replace( /\s*exports\.\w+\s*=\s*\w+;/g, "" ); @@ -82,13 +89,15 @@ module.exports = function( grunt ) { contents = contents .replace( /define\(\[[^\]]*\]\)[\W\n]+$/, "" ); } + // AMD Name - if ( (amdName = grunt.option( "amd" )) != null && /^exports\/amd$/.test( name ) ) { - if (amdName) { + if ( ( amdName = grunt.option( "amd" ) ) != null && /^exports\/amd$/.test( name ) ) { + if ( amdName ) { grunt.log.writeln( "Naming jQuery with AMD name: " + amdName ); } else { grunt.log.writeln( "AMD name now anonymous" ); } + // Remove the comma for anonymous defines contents = contents .replace( /(\s*)"jquery"(\,\s*)/, amdName ? "$1\"" + amdName + "\"$2" : "" ); @@ -121,7 +130,8 @@ module.exports = function( grunt ) { excludeList = function( list, prepend ) { if ( list ) { prepend = prepend ? prepend + "/" : ""; - list.forEach(function( module ) { + list.forEach( function( module ) { + // Exclude var modules as well if ( module === "var" ) { excludeList( @@ -130,20 +140,22 @@ module.exports = function( grunt ) { return; } if ( prepend ) { + // Skip if this is not a js file and we're walking files in a dir - if ( !(module = /([\w-\/]+)\.js$/.exec( module )) ) { + if ( !( module = /([\w-\/]+)\.js$/.exec( module ) ) ) { return; } + // Prepend folder name if passed // Remove .js extension - module = prepend + module[1]; + module = prepend + module[ 1 ]; } // Avoid infinite recursion if ( excluded.indexOf( module ) === -1 ) { excluder( "-" + module ); } - }); + } ); } }, /** @@ -158,16 +170,19 @@ module.exports = function( grunt ) { module = m[ 2 ]; if ( exclude ) { + // Can't exclude sizzle on this branch if ( module === "sizzle" ) { grunt.log.error( "Sizzle cannot be excluded on the compat branch." ); // Can't exclude certain modules } else if ( minimum.indexOf( module ) === -1 ) { + // Add to excluded if ( excluded.indexOf( module ) === -1 ) { grunt.log.writeln( flag ); excluded.push( module ); + // Exclude all files in the folder of the same name // These are the removable dependencies // It's fine if the directory is not there @@ -177,10 +192,11 @@ module.exports = function( grunt ) { grunt.verbose.writeln( e ); } } + // Check removeWith list excludeList( removeWith[ module ] ); } else { - grunt.log.error( "Module \"" + module + "\" is a minimum requirement."); + grunt.log.error( "Module \"" + module + "\" is a minimum requirement." ); } } else { grunt.log.writeln( flag ); @@ -213,7 +229,7 @@ module.exports = function( grunt ) { } // Replace exports/global with a noop noConflict - if ( (index = excluded.indexOf( "exports/global" )) > -1 ) { + if ( ( index = excluded.indexOf( "exports/global" ) ) > -1 ) { config.rawText[ "exports/global" ] = "define(['../core']," + "function( jQuery ) {\njQuery.noConflict = function() {};\n});"; excluded.splice( index, 1 ); @@ -225,9 +241,11 @@ module.exports = function( grunt ) { // append excluded modules to version if ( excluded.length ) { version += " -" + excluded.join( ",-" ); + // set pkg.version to version with excludes, so minified file picks it up grunt.config.set( "pkg.version", version ); grunt.verbose.writeln( "Version changed to " + version ); + // Have to use shallow or core will get excluded since it is a dependency config.excludeShallow = excluded; } @@ -239,8 +257,10 @@ module.exports = function( grunt ) { */ config.out = function( compiled ) { compiled = compiled + // Embed Version .replace( /@VERSION/g, version ) + // Embed Date // yyyy-mm-ddThh:mmZ .replace( /@DATE/g, ( new Date() ).toISOString().replace( /:\d+\.\d+Z$/, "Z" ) ); @@ -251,9 +271,10 @@ module.exports = function( grunt ) { // Turn off opt-in if necessary if ( !optIn ) { + // Overwrite the default inclusions with the explicit ones provided config.rawText.jquery = "define([" + - (included.length ? included.join(",") : "") + + ( included.length ? included.join( "," ) : "" ) + "]);"; } @@ -264,8 +285,8 @@ module.exports = function( grunt ) { done(); }, function( err ) { done( err ); - }); - }); + } ); + } ); // Special "alias" task to make custom build creation less grawlix-y // Translation example @@ -281,6 +302,6 @@ module.exports = function( grunt ) { grunt.log.writeln( "Creating custom build...\n" ); - grunt.task.run([ "build:*:*" + (modules ? ":" + modules : ""), "uglify", "dist" ]); - }); + grunt.task.run( [ "build:*:*" + ( modules ? ":" + modules : "" ), "uglify", "dist" ] ); + } ); }; diff --git a/build/tasks/dist.js b/build/tasks/dist.js index 13e56336a..78ce2f254 100644 --- a/build/tasks/dist.js +++ b/build/tasks/dist.js @@ -21,14 +21,14 @@ module.exports = function( grunt ) { flags = Object.keys( this.flags ); // Combine all output target paths - paths = [].concat( stored, flags ).filter(function( path ) { + paths = [].concat( stored, flags ).filter( function( path ) { return path !== "*"; - }); + } ); // Ensure the dist files are pure ASCII nonascii = false; - distpaths.forEach(function( filename ) { + distpaths.forEach( function( filename ) { var i, c, text = fs.readFileSync( filename, "utf8" ); @@ -53,7 +53,7 @@ module.exports = function( grunt ) { } // Optionally copy dist files to other locations - paths.forEach(function( path ) { + paths.forEach( function( path ) { var created; if ( !/\/$/.test( path ) ) { @@ -63,9 +63,9 @@ module.exports = function( grunt ) { created = path + filename.replace( "dist/", "" ); grunt.file.write( created, text ); grunt.log.writeln( "File '" + created + "' created." ); - }); - }); + } ); + } ); return !nonascii; - }); + } ); }; diff --git a/build/tasks/install_jsdom.js b/build/tasks/install_jsdom.js index 21d67eb0e..73142b654 100644 --- a/build/tasks/install_jsdom.js +++ b/build/tasks/install_jsdom.js @@ -23,5 +23,5 @@ module.exports = function( grunt ) { args: [ "install", "jsdom@" + version ], opts: { stdio: "inherit" } }, this.async() ); - }); + } ); }; diff --git a/build/tasks/promises-aplus-tests.js b/build/tasks/promises-aplus-tests.js index 458ae1be0..d6d6f7781 100644 --- a/build/tasks/promises-aplus-tests.js +++ b/build/tasks/promises-aplus-tests.js @@ -15,6 +15,6 @@ module.exports = function( grunt ) { { stdio: "inherit" } ).on( "close", function( code ) { done( code === 0 ); - }); - }); + } ); + } ); }; diff --git a/build/tasks/sourcemap.js b/build/tasks/sourcemap.js index 5f4d5232f..3e4144de0 100644 --- a/build/tasks/sourcemap.js +++ b/build/tasks/sourcemap.js @@ -3,11 +3,12 @@ var fs = require( "fs" ); module.exports = function( grunt ) { var minLoc = Object.keys( grunt.config( "uglify.all.files" ) )[ 0 ]; grunt.registerTask( "remove_map_comment", function() { + // Remove the source map comment; it causes way too many problems. // The map file is still generated for manual associations // https://github.com/jquery/jquery/issues/1707 var text = fs.readFileSync( minLoc, "utf8" ) .replace( /\/\/# sourceMappingURL=\S+/, "" ); fs.writeFileSync( minLoc, text ); - }); + } ); }; diff --git a/build/tasks/testswarm.js b/build/tasks/testswarm.js index 473bc9e72..902b33428 100644 --- a/build/tasks/testswarm.js +++ b/build/tasks/testswarm.js @@ -14,11 +14,12 @@ module.exports = function( grunt ) { config = grunt.file.readJSON( configFile )[ projectName ]; browserSets = browserSets || config.browserSets; if ( browserSets[ 0 ] === "[" ) { + // We got an array, parse it browserSets = JSON.parse( browserSets ); } timeout = timeout || 1000 * 60 * 15; - tests = grunt.config([ this.name, "tests" ]); + tests = grunt.config( [ this.name, "tests" ] ); if ( pull ) { jobName = "Pull <a href='https://github.com/jquery/jquery/pull/" + @@ -28,18 +29,18 @@ module.exports = function( grunt ) { commit + "'>" + commit.substr( 0, 10 ) + "</a>"; } - tests.forEach(function( test ) { + tests.forEach( function( test ) { runs[ test ] = config.testUrl + commit + "/test/index.html?module=" + test; - }); + } ); - testswarm.createClient({ + testswarm.createClient( { url: config.swarmUrl } ) .addReporter( testswarm.reporters.cli ) .auth( { id: config.authUsername, token: config.authToken - }) + } ) .addjob( { name: jobName, @@ -54,5 +55,5 @@ module.exports = function( grunt ) { done( passed ); } ); - }); + } ); }; diff --git a/package.json b/package.json index a8178ea7d..7cacc6582 100644 --- a/package.json +++ b/package.json @@ -35,7 +35,7 @@ "grunt-contrib-uglify": "0.7.0", "grunt-contrib-watch": "0.6.1", "grunt-git-authors": "2.0.1", - "grunt-jscs-checker": "0.8.1", + "grunt-jscs": "2.1.0", "grunt-jsonlint": "1.0.4", "grunt-npmcopy": "0.1.0", "gzip-js": "0.3.2", diff --git a/src/ajax.js b/src/ajax.js index 8357d6420..c8706aae6 100644 --- a/src/ajax.js +++ b/src/ajax.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/document", "./var/rnotwhite", @@ -15,6 +15,7 @@ var rhash = /#.*$/, rts = /([?&])_=[^&]*/, rheaders = /^(.*?):[ \t]*([^\r\n]*)$/mg, + // #7653, #8125, #8152: local protocol detection rlocalProtocol = /^(?:about|app|app-storage|.+-extension|file|res|widget):$/, rnoContent = /^(?:GET|HEAD)$/, @@ -62,16 +63,18 @@ function addToPrefiltersOrTransports( structure ) { dataTypes = dataTypeExpression.toLowerCase().match( rnotwhite ) || []; if ( jQuery.isFunction( func ) ) { + // For each dataType in the dataTypeExpression - while ( (dataType = dataTypes[i++]) ) { + while ( ( dataType = dataTypes[ i++ ] ) ) { + // Prepend if requested if ( dataType[ 0 ] === "+" ) { dataType = dataType.slice( 1 ) || "*"; - (structure[ dataType ] = structure[ dataType ] || []).unshift( func ); + ( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func ); // Otherwise append } else { - (structure[ dataType ] = structure[ dataType ] || []).push( func ); + ( structure[ dataType ] = structure[ dataType ] || [] ).push( func ); } } } @@ -98,7 +101,7 @@ function inspectPrefiltersOrTransports( structure, options, originalOptions, jqX } else if ( seekingTransport ) { return !( selected = dataTypeOrTransport ); } - }); + } ); return selected; } @@ -114,7 +117,7 @@ function ajaxExtend( target, src ) { for ( key in src ) { if ( src[ key ] !== undefined ) { - ( flatOptions[ key ] ? target : ( deep || (deep = {}) ) )[ key ] = src[ key ]; + ( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ]; } } if ( deep ) { @@ -137,7 +140,7 @@ function ajaxHandleResponses( s, jqXHR, responses ) { while ( dataTypes[ 0 ] === "*" ) { dataTypes.shift(); if ( ct === undefined ) { - ct = s.mimeType || jqXHR.getResponseHeader("Content-Type"); + ct = s.mimeType || jqXHR.getResponseHeader( "Content-Type" ); } } @@ -155,9 +158,10 @@ function ajaxHandleResponses( s, jqXHR, responses ) { if ( dataTypes[ 0 ] in responses ) { finalDataType = dataTypes[ 0 ]; } else { + // Try convertible dataTypes for ( type in responses ) { - if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[0] ] ) { + if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[ 0 ] ] ) { finalDataType = type; break; } @@ -165,6 +169,7 @@ function ajaxHandleResponses( s, jqXHR, responses ) { firstDataType = type; } } + // Or just use first one finalDataType = finalDataType || firstDataType; } @@ -186,6 +191,7 @@ function ajaxHandleResponses( s, jqXHR, responses ) { function ajaxConvert( s, response, jqXHR, isSuccess ) { var conv2, current, conv, tmp, prev, converters = {}, + // Work with a copy of dataTypes in case we need to modify it for conversion dataTypes = s.dataTypes.slice(); @@ -238,6 +244,7 @@ function ajaxConvert( s, response, jqXHR, isSuccess ) { conv = converters[ prev + " " + tmp[ 0 ] ] || converters[ "* " + tmp[ 0 ] ]; if ( conv ) { + // Condense equivalence converters if ( conv === true ) { conv = converters[ conv2 ]; @@ -257,7 +264,7 @@ function ajaxConvert( s, response, jqXHR, isSuccess ) { if ( conv !== true ) { // Unless errors are allowed to bubble, catch and return them - if ( conv && s[ "throws" ] ) { + if ( conv && s[ "throws" ] ) { // jscs:ignore requireDotNotation response = conv( response ); } else { try { @@ -277,7 +284,7 @@ function ajaxConvert( s, response, jqXHR, isSuccess ) { return { state: "success", data: response }; } -jQuery.extend({ +jQuery.extend( { // Counter for holding the number of active queries active: 0, @@ -382,43 +389,59 @@ jQuery.extend({ options = options || {}; var + // Loop variable i, + // URL without anti-cache param cacheURL, + // Response headers as string responseHeadersString, + // timeout handle timeoutTimer, + // Url cleanup var urlAnchor, + // To know if global events are to be dispatched fireGlobals, transport, + // Response headers responseHeaders, + // Create the final options object s = jQuery.ajaxSetup( {}, options ), + // Callbacks context callbackContext = s.context || s, + // Context for global events is callbackContext if it is a DOM node or jQuery collection globalEventContext = s.context && ( callbackContext.nodeType || callbackContext.jquery ) ? jQuery( callbackContext ) : jQuery.event, + // Deferreds deferred = jQuery.Deferred(), - completeDeferred = jQuery.Callbacks("once memory"), + completeDeferred = jQuery.Callbacks( "once memory" ), + // Status-dependent callbacks statusCode = s.statusCode || {}, + // Headers (they are sent all at once) requestHeaders = {}, requestHeadersNames = {}, + // The jqXHR state state = 0, + // Default abort message strAbort = "canceled", + // Fake xhr jqXHR = { readyState: 0, @@ -429,8 +452,8 @@ jQuery.extend({ if ( state === 2 ) { if ( !responseHeaders ) { responseHeaders = {}; - while ( (match = rheaders.exec( responseHeadersString )) ) { - responseHeaders[ match[1].toLowerCase() ] = match[ 2 ]; + while ( ( match = rheaders.exec( responseHeadersString ) ) ) { + responseHeaders[ match[ 1 ].toLowerCase() ] = match[ 2 ]; } } match = responseHeaders[ key.toLowerCase() ]; @@ -467,10 +490,12 @@ jQuery.extend({ if ( map ) { if ( state < 2 ) { for ( code in map ) { + // Lazy-add the new callback in a way that preserves old ones statusCode[ code ] = [ statusCode[ code ], map[ code ] ]; } } else { + // Execute the appropriate callbacks jqXHR.always( map[ jqXHR.status ] ); } @@ -513,12 +538,14 @@ jQuery.extend({ // IE throws exception if url is malformed, e.g. http://example.com:80x/ try { urlAnchor.href = s.url; + // Support: IE8-11+ // Anchor's host property isn't correctly set when s.url is relative urlAnchor.href = urlAnchor.href; s.crossDomain = originAnchor.protocol + "//" + originAnchor.host !== urlAnchor.protocol + "//" + urlAnchor.host; } catch ( e ) { + // If there is an error parsing the URL, assume it is crossDomain, // it can be rejected by the transport if it is invalid s.crossDomain = true; @@ -544,7 +571,7 @@ jQuery.extend({ // Watch for a new set of requests if ( fireGlobals && jQuery.active++ === 0 ) { - jQuery.event.trigger("ajaxStart"); + jQuery.event.trigger( "ajaxStart" ); } // Uppercase the type @@ -563,6 +590,7 @@ jQuery.extend({ // If data is available, append data to url if ( s.data ) { cacheURL = ( s.url += ( rquery.test( cacheURL ) ? "&" : "?" ) + s.data ); + // #9682: remove data so that it's not used in an eventual retry delete s.data; } @@ -597,8 +625,8 @@ jQuery.extend({ // Set the Accepts header for the server, depending on the dataType jqXHR.setRequestHeader( "Accept", - s.dataTypes[ 0 ] && s.accepts[ s.dataTypes[0] ] ? - s.accepts[ s.dataTypes[0] ] + + s.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ? + s.accepts[ s.dataTypes[ 0 ] ] + ( s.dataTypes[ 0 ] !== "*" ? ", " + allTypes + "; q=0.01" : "" ) : s.accepts[ "*" ] ); @@ -645,8 +673,8 @@ jQuery.extend({ // Timeout if ( s.async && s.timeout > 0 ) { - timeoutTimer = window.setTimeout(function() { - jqXHR.abort("timeout"); + timeoutTimer = window.setTimeout( function() { + jqXHR.abort( "timeout" ); }, s.timeout ); } @@ -654,9 +682,11 @@ jQuery.extend({ state = 1; transport.send( requestHeaders, done ); } catch ( e ) { + // Propagate exception as error if not done if ( state < 2 ) { done( -1, e ); + // Simply rethrow otherwise } else { throw e; @@ -708,11 +738,11 @@ jQuery.extend({ // Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode. if ( s.ifModified ) { - modified = jqXHR.getResponseHeader("Last-Modified"); + modified = jqXHR.getResponseHeader( "Last-Modified" ); if ( modified ) { jQuery.lastModified[ cacheURL ] = modified; } - modified = jqXHR.getResponseHeader("etag"); + modified = jqXHR.getResponseHeader( "etag" ); if ( modified ) { jQuery.etag[ cacheURL ] = modified; } @@ -734,6 +764,7 @@ jQuery.extend({ isSuccess = !error; } } else { + // We extract error from statusText // then normalize statusText and status for non-aborts error = statusText; @@ -770,9 +801,10 @@ jQuery.extend({ if ( fireGlobals ) { globalEventContext.trigger( "ajaxComplete", [ jqXHR, s ] ); + // Handle the global AJAX counter if ( !( --jQuery.active ) ) { - jQuery.event.trigger("ajaxStop"); + jQuery.event.trigger( "ajaxStop" ); } } } @@ -787,10 +819,11 @@ jQuery.extend({ getScript: function( url, callback ) { return jQuery.get( url, undefined, callback, "script" ); } -}); +} ); jQuery.each( [ "get", "post" ], function( i, method ) { jQuery[ method ] = function( url, data, callback, type ) { + // shift arguments if data argument was omitted if ( jQuery.isFunction( data ) ) { type = type || callback; @@ -799,7 +832,7 @@ jQuery.each( [ "get", "post" ], function( i, method ) { } // The url can be an options object (which then must have .url) - return jQuery.ajax( jQuery.extend({ + return jQuery.ajax( jQuery.extend( { url: url, type: method, dataType: type, @@ -807,7 +840,7 @@ jQuery.each( [ "get", "post" ], function( i, method ) { success: callback }, jQuery.isPlainObject( url ) && url ) ); }; -}); +} ); return jQuery; -}); +} ); diff --git a/src/ajax/jsonp.js b/src/ajax/jsonp.js index f469344e0..89ce44d11 100644 --- a/src/ajax/jsonp.js +++ b/src/ajax/jsonp.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "./var/nonce", "./var/rquery", @@ -9,14 +9,14 @@ var oldCallbacks = [], rjsonp = /(=)\?(?=&|$)|\?\?/; // Default jsonp settings -jQuery.ajaxSetup({ +jQuery.ajaxSetup( { jsonp: "callback", jsonpCallback: function() { var callback = oldCallbacks.pop() || ( jQuery.expando + "_" + ( nonce++ ) ); this[ callback ] = true; return callback; } -}); +} ); // Detect, normalize options and install callbacks for jsonp requests jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { @@ -26,7 +26,7 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { "url" : typeof s.data === "string" && ( s.contentType || "" ) - .indexOf("application/x-www-form-urlencoded") === 0 && + .indexOf( "application/x-www-form-urlencoded" ) === 0 && rjsonp.test( s.data ) && "data" ); @@ -46,7 +46,7 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { } // Use data converter to retrieve json after script execution - s.converters["script json"] = function() { + s.converters[ "script json" ] = function() { if ( !responseContainer ) { jQuery.error( callbackName + " was not called" ); } @@ -63,7 +63,8 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { }; // Clean-up function (fires after converters) - jqXHR.always(function() { + jqXHR.always( function() { + // If previous value didn't exist - remove it if ( overwritten === undefined ) { jQuery( window ).removeProp( callbackName ); @@ -75,6 +76,7 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { // Save back as free if ( s[ callbackName ] ) { + // make sure that re-using the options doesn't screw things around s.jsonpCallback = originalSettings.jsonpCallback; @@ -88,11 +90,11 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { } responseContainer = overwritten = undefined; - }); + } ); // Delegate to script return "script"; } -}); +} ); -}); +} ); diff --git a/src/ajax/load.js b/src/ajax/load.js index 1b3ebcfc9..743fe22e6 100644 --- a/src/ajax/load.js +++ b/src/ajax/load.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../core/parseHTML", "../ajax", @@ -13,7 +13,7 @@ define([ jQuery.fn.load = function( url, params, callback ) { var selector, response, type, self = this, - off = url.indexOf(" "); + off = url.indexOf( " " ); if ( off > -1 ) { selector = jQuery.trim( url.slice( off, url.length ) ); @@ -34,7 +34,7 @@ jQuery.fn.load = function( url, params, callback ) { // If we have elements to modify, make the request if ( self.length > 0 ) { - jQuery.ajax({ + jQuery.ajax( { url: url, // If "type" variable is undefined, then "GET" method will be used. @@ -43,7 +43,7 @@ jQuery.fn.load = function( url, params, callback ) { type: type || "GET", dataType: "html", data: params - }).done(function( responseText ) { + } ).done( function( responseText ) { // Save response for use in complete callback response = arguments; @@ -52,7 +52,7 @@ jQuery.fn.load = function( url, params, callback ) { // If a selector was specified, locate the right elements in a dummy div // Exclude scripts to avoid IE 'Permission Denied' errors - jQuery("<div>").append( jQuery.parseHTML( responseText ) ).find( selector ) : + jQuery( "<div>" ).append( jQuery.parseHTML( responseText ) ).find( selector ) : // Otherwise use the full result responseText ); @@ -60,14 +60,14 @@ jQuery.fn.load = function( url, params, callback ) { // If the request succeeds, this function gets "data", "status", "jqXHR" // but they are ignored because response was set above. // If it fails, this function gets "jqXHR", "status", "error" - }).always( callback && function( jqXHR, status ) { + } ).always( callback && function( jqXHR, status ) { self.each( function() { callback.apply( self, response || [ jqXHR.responseText, status, jqXHR ] ); - }); - }); + } ); + } ); } return this; }; -}); +} ); diff --git a/src/ajax/parseJSON.js b/src/ajax/parseJSON.js index 3a96d15b9..11918b06d 100644 --- a/src/ajax/parseJSON.js +++ b/src/ajax/parseJSON.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core" ], function( jQuery ) { @@ -10,4 +10,4 @@ jQuery.parseJSON = function( data ) { return jQuery.parseJSON; -}); +} ); diff --git a/src/ajax/parseXML.js b/src/ajax/parseXML.js index e0b248513..a05e8002e 100644 --- a/src/ajax/parseXML.js +++ b/src/ajax/parseXML.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core" ], function( jQuery ) { @@ -28,4 +28,4 @@ jQuery.parseXML = function( data ) { return jQuery.parseXML; -}); +} ); diff --git a/src/ajax/script.js b/src/ajax/script.js index 1af0963f3..4c810f0a0 100644 --- a/src/ajax/script.js +++ b/src/ajax/script.js @@ -1,11 +1,11 @@ -define([ +define( [ "../core", "../var/document", "../ajax" ], function( jQuery, document ) { // Install script dataType -jQuery.ajaxSetup({ +jQuery.ajaxSetup( { accepts: { script: "text/javascript, application/javascript, " + "application/ecmascript, application/x-ecmascript" @@ -19,7 +19,7 @@ jQuery.ajaxSetup({ return text; } } -}); +} ); // Handle cache's special case and global jQuery.ajaxPrefilter( "script", function( s ) { @@ -30,22 +30,22 @@ jQuery.ajaxPrefilter( "script", function( s ) { s.type = "GET"; s.global = false; } -}); +} ); // Bind script tag hack transport -jQuery.ajaxTransport( "script", function(s) { +jQuery.ajaxTransport( "script", function( s ) { // This transport only deals with cross domain requests if ( s.crossDomain ) { var script, - head = document.head || jQuery("head")[0] || document.documentElement; + head = document.head || jQuery( "head" )[ 0 ] || document.documentElement; return { send: function( _, callback ) { - script = document.createElement("script"); + script = document.createElement( "script" ); if ( s.scriptCharset ) { script.charset = s.scriptCharset; @@ -87,6 +87,6 @@ jQuery.ajaxTransport( "script", function(s) { } }; } -}); +} ); -}); +} ); diff --git a/src/ajax/var/location.js b/src/ajax/var/location.js index 4c9cf4a4c..ff9578e99 100644 --- a/src/ajax/var/location.js +++ b/src/ajax/var/location.js @@ -1,3 +1,3 @@ -define(function() { +define( function() { return window.location; -}); +} ); diff --git a/src/ajax/var/nonce.js b/src/ajax/var/nonce.js index 0871aae88..83fd557c8 100644 --- a/src/ajax/var/nonce.js +++ b/src/ajax/var/nonce.js @@ -1,5 +1,5 @@ -define([ +define( [ "../../core" ], function( jQuery ) { return jQuery.now(); -}); +} ); diff --git a/src/ajax/var/rquery.js b/src/ajax/var/rquery.js index 500a77a08..0502146ca 100644 --- a/src/ajax/var/rquery.js +++ b/src/ajax/var/rquery.js @@ -1,3 +1,3 @@ -define(function() { - return (/\?/); -}); +define( function() { + return ( /\?/ ); +} ); diff --git a/src/ajax/xhr.js b/src/ajax/xhr.js index ef68ef4c0..313f24a04 100644 --- a/src/ajax/xhr.js +++ b/src/ajax/xhr.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../var/document", "../var/support", @@ -8,6 +8,7 @@ define([ // Create the request object // (This is still attached to ajaxSettings for backward compatibility) jQuery.ajaxSettings.xhr = window.ActiveXObject !== undefined ? + // Support: IE8 function() { @@ -35,6 +36,7 @@ jQuery.ajaxSettings.xhr = window.ActiveXObject !== undefined ? return /^(get|post|head|put|delete|options)$/i.test( this.type ) && createStandardXHR() || createActiveXHR(); } : + // For all other browsers, use the standard XMLHttpRequest object createStandardXHR; @@ -47,7 +49,8 @@ xhrSupported = support.ajax = !!xhrSupported; // Create transport if the browser can provide an xhr if ( xhrSupported ) { - jQuery.ajaxTransport(function( options ) { + jQuery.ajaxTransport( function( options ) { + // Cross domain only allowed if supported through XMLHttpRequest if ( !options.crossDomain || support.cors ) { @@ -84,12 +87,13 @@ if ( xhrSupported ) { // akin to a jigsaw puzzle, we simply never set it to be sure. // (it can always be set on a per-request basis or even using ajaxSetup) // For same-domain requests, won't change header if already provided. - if ( !options.crossDomain && !headers["X-Requested-With"] ) { - headers["X-Requested-With"] = "XMLHttpRequest"; + if ( !options.crossDomain && !headers[ "X-Requested-With" ] ) { + headers[ "X-Requested-With" ] = "XMLHttpRequest"; } // Set headers for ( i in headers ) { + // Support: IE<9 // IE's ActiveXObject throws a 'Type Mismatch' exception when setting // request header to a null-value. @@ -112,6 +116,7 @@ if ( xhrSupported ) { // Was never called and is aborted or complete if ( callback && ( isAbort || xhr.readyState === 4 ) ) { + // Clean up callback = undefined; xhr.onreadystatechange = jQuery.noop; @@ -137,6 +142,7 @@ if ( xhrSupported ) { try { statusText = xhr.statusText; } catch ( e ) { + // We normalize with Webkit giving an empty statusText statusText = ""; } @@ -148,6 +154,7 @@ if ( xhrSupported ) { // can do given current implementations) if ( !status && options.isLocal && !options.crossDomain ) { status = responses.text ? 200 : 404; + // IE - #1450: sometimes returns 1223 when it should be 204 } else if ( status === 1223 ) { status = 204; @@ -162,9 +169,11 @@ if ( xhrSupported ) { }; if ( !options.async ) { + // if we're in sync mode we fire the callback callback(); } else { + // Add to the list of active xhr callbacks xhr.onreadystatechange = callback; } @@ -177,7 +186,7 @@ if ( xhrSupported ) { } }; } - }); + } ); } // Functions to create xhrs @@ -193,4 +202,4 @@ function createActiveXHR() { } catch ( e ) {} } -}); +} ); diff --git a/src/attributes.js b/src/attributes.js index 0569013d4..4a1097457 100644 --- a/src/attributes.js +++ b/src/attributes.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./attributes/val", "./attributes/attr", @@ -8,4 +8,4 @@ define([ // Return jQuery for attributes-only inclusion return jQuery; -}); +} ); diff --git a/src/attributes/attr.js b/src/attributes/attr.js index 689b567cb..125e094d9 100644 --- a/src/attributes/attr.js +++ b/src/attributes/attr.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../core/access", "./support", @@ -12,7 +12,7 @@ var boolHook, ruseDefault = /^(?:checked|selected)$/i, getSetInput = support.input; -jQuery.fn.extend({ +jQuery.fn.extend( { attr: function( name, value ) { return access( this, jQuery.attr, name, value, arguments.length > 1 ); }, @@ -20,11 +20,11 @@ jQuery.fn.extend({ removeAttr: function( name ) { return this.each( function() { jQuery.removeAttr( this, name ); - }); + } ); } -}); +} ); -jQuery.extend({ +jQuery.extend( { attr: function( elem, name, value ) { var ret, hooks, nType = elem.nodeType; @@ -97,7 +97,7 @@ jQuery.extend({ attrNames = value && value.match( rnotwhite ); if ( attrNames && elem.nodeType === 1 ) { - while ( ( name = attrNames[i++] ) ) { + while ( ( name = attrNames[ i++ ] ) ) { propName = jQuery.propFix[ name ] || name; // Boolean attributes get special treatment (#10870) @@ -119,7 +119,7 @@ jQuery.extend({ } } } -}); +} ); // Hooks for boolean attributes boolHook = { @@ -168,7 +168,7 @@ jQuery.each( jQuery.expr.match.bool.source.match( /\w+/g ), function( i, name ) } }; } -}); +} ); // fix oldIE attroperties if ( !getSetInput ) { @@ -198,4 +198,4 @@ if ( !support.style ) { }; } -}); +} ); diff --git a/src/attributes/classes.js b/src/attributes/classes.js index f08a1a142..4e2d2adf3 100644 --- a/src/attributes/classes.js +++ b/src/attributes/classes.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../var/rnotwhite", "../core/init" @@ -10,7 +10,7 @@ function getClass( elem ) { return elem.getAttribute && elem.getAttribute( "class" ) || ""; } -jQuery.fn.extend({ +jQuery.fn.extend( { addClass: function( value ) { var classes, elem, cur, curValue, clazz, j, finalValue, i = 0, @@ -18,12 +18,13 @@ jQuery.fn.extend({ proceed = typeof value === "string" && value; if ( jQuery.isFunction( value ) ) { - return this.each(function( j ) { + return this.each( function( j ) { jQuery( this ).addClass( value.call( this, j, getClass( this ) ) ); - }); + } ); } if ( proceed ) { + // The disjunction here is for better compressibility (see removeClass) classes = ( value || "" ).match( rnotwhite ) || []; @@ -35,7 +36,7 @@ jQuery.fn.extend({ if ( cur ) { j = 0; - while ( (clazz = classes[j++]) ) { + while ( ( clazz = classes[ j++ ] ) ) { if ( cur.indexOf( " " + clazz + " " ) < 0 ) { cur += clazz + " "; } @@ -60,9 +61,9 @@ jQuery.fn.extend({ proceed = arguments.length === 0 || typeof value === "string" && value; if ( jQuery.isFunction( value ) ) { - return this.each(function( j ) { + return this.each( function( j ) { jQuery( this ).removeClass( value.call( this, j, getClass( this ) ) ); - }); + } ); } if ( proceed ) { classes = ( value || "" ).match( rnotwhite ) || []; @@ -77,7 +78,8 @@ jQuery.fn.extend({ if ( cur ) { j = 0; - while ( (clazz = classes[j++]) ) { + while ( ( clazz = classes[ j++ ] ) ) { + // Remove *all* instances while ( cur.indexOf( " " + clazz + " " ) > -1 ) { cur = cur.replace( " " + clazz + " ", " " ); @@ -104,15 +106,15 @@ jQuery.fn.extend({ } if ( jQuery.isFunction( value ) ) { - return this.each(function( i ) { + return this.each( function( i ) { jQuery( this ).toggleClass( value.call( this, i, getClass( this ), stateVal ), stateVal ); - }); + } ); } - return this.each(function() { + return this.each( function() { var className, i, self, classNames; if ( type === "string" ) { @@ -153,7 +155,7 @@ jQuery.fn.extend({ ); } } - }); + } ); }, hasClass: function( selector ) { @@ -161,8 +163,8 @@ jQuery.fn.extend({ i = 0, l = this.length; for ( ; i < l; i++ ) { - if ( this[i].nodeType === 1 && - ( " " + getClass( this[i] ) + " " ).replace( rclass, " " ) + if ( this[ i ].nodeType === 1 && + ( " " + getClass( this[ i ] ) + " " ).replace( rclass, " " ) .indexOf( className ) > -1 ) { return true; @@ -171,6 +173,6 @@ jQuery.fn.extend({ return false; } -}); +} ); -}); +} ); diff --git a/src/attributes/prop.js b/src/attributes/prop.js index 9fad50e41..3eb5d8261 100644 --- a/src/attributes/prop.js +++ b/src/attributes/prop.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../core/access", "./support", @@ -8,24 +8,25 @@ define([ var rfocusable = /^(?:input|select|textarea|button|object)$/i, rclickable = /^(?:a|area)$/i; -jQuery.fn.extend({ +jQuery.fn.extend( { prop: function( name, value ) { return access( this, jQuery.prop, name, value, arguments.length > 1 ); }, removeProp: function( name ) { name = jQuery.propFix[ name ] || name; - return this.each(function() { + return this.each( function() { + // try/catch handles cases where IE balks (such as removing a property on window) try { this[ name ] = undefined; delete this[ name ]; } catch ( e ) {} - }); + } ); } -}); +} ); -jQuery.extend({ +jQuery.extend( { prop: function( elem, name, value ) { var ret, hooks, nType = elem.nodeType; @@ -61,6 +62,7 @@ jQuery.extend({ propHooks: { tabIndex: { get: function( elem ) { + // elem.tabIndex doesn't always return the // correct value when it hasn't been explicitly set // http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/ @@ -81,7 +83,7 @@ jQuery.extend({ "for": "htmlFor", "class": "className" } -}); +} ); if ( !support.optSelected ) { jQuery.propHooks.selected = { @@ -101,7 +103,7 @@ if ( !support.optSelected ) { }; } -jQuery.each([ +jQuery.each( [ "tabIndex", "readOnly", "maxLength", @@ -114,6 +116,6 @@ jQuery.each([ "contentEditable" ], function() { jQuery.propFix[ this.toLowerCase() ] = this; -}); +} ); -}); +} ); diff --git a/src/attributes/support.js b/src/attributes/support.js index 6fd6827f4..5e2de2ae2 100644 --- a/src/attributes/support.js +++ b/src/attributes/support.js @@ -1,9 +1,9 @@ -define([ +define( [ "../var/document", "../var/support" ], function( document, support ) { -(function() { +( function() { var a, input = document.createElement( "input" ), div = document.createElement( "div" ), @@ -12,6 +12,7 @@ define([ // Setup div.innerHTML = " <link/><a href='/a'>a</a>"; + // Support: Windows Web Apps (WWA) // `type` must use .setAttribute for WWA (#14901) input.setAttribute( "type", "checkbox" ); @@ -24,7 +25,7 @@ define([ // Get the style information from getAttribute // (IE uses .cssText instead) - support.style = /top/.test( a.getAttribute("style") ); + support.style = /top/.test( a.getAttribute( "style" ) ); // Check the default checkbox/radio value ("" on WebKit; "on" elsewhere) support.checkOn = !!input.value; @@ -49,8 +50,8 @@ define([ input.value = "t"; input.setAttribute( "type", "radio" ); support.radioValue = input.value === "t"; -})(); +} )(); return support; -}); +} ); diff --git a/src/attributes/val.js b/src/attributes/val.js index 2a6ccab3d..7af79cfef 100644 --- a/src/attributes/val.js +++ b/src/attributes/val.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "./support", "../core/init" @@ -6,25 +6,31 @@ define([ var rreturn = /\r/g; -jQuery.fn.extend({ +jQuery.fn.extend( { val: function( value ) { var hooks, ret, isFunction, - elem = this[0]; + elem = this[ 0 ]; if ( !arguments.length ) { if ( elem ) { hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ]; - if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) { + if ( + hooks && + "get" in hooks && + ( ret = hooks.get( elem, "value" ) ) !== undefined + ) { return ret; } ret = elem.value; return typeof ret === "string" ? + // handle most common string cases - ret.replace(rreturn, "") : + ret.replace( rreturn, "" ) : + // handle cases where value is null/undef or number ret == null ? "" : ret; } @@ -34,7 +40,7 @@ jQuery.fn.extend({ isFunction = jQuery.isFunction( value ); - return this.each(function( i ) { + return this.each( function( i ) { var val; if ( this.nodeType !== 1 ) { @@ -55,23 +61,24 @@ jQuery.fn.extend({ } else if ( jQuery.isArray( val ) ) { val = jQuery.map( val, function( value ) { return value == null ? "" : value + ""; - }); + } ); } hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; // If set returns undefined, fall back to normal setting - if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) { + if ( !hooks || !( "set" in hooks ) || hooks.set( this, val, "value" ) === undefined ) { this.value = val; } - }); + } ); } -}); +} ); -jQuery.extend({ +jQuery.extend( { valHooks: { option: { get: function( elem ) { + // Support: IE<11 // option.value not trimmed (#14858) return jQuery.trim( elem.value ); @@ -96,10 +103,11 @@ jQuery.extend({ // Support: IE<10 // IE8-9 doesn't update selected after form reset (#2551) if ( ( option.selected || i === index ) && + // Don't return options that are disabled or in a disabled optgroup ( support.optDisabled ? !option.disabled : - option.getAttribute("disabled") === null ) && + option.getAttribute( "disabled" ) === null ) && ( !option.parentNode.disabled || !jQuery.nodeName( option.parentNode, "optgroup" ) ) ) { @@ -127,8 +135,10 @@ jQuery.extend({ while ( i-- ) { option = options[ i ]; - if ( (option.selected = - jQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1) ) { + if ( + option.selected = + jQuery.inArray( jQuery.valHooks.option.get( option ), values ) > -1 + ) { optionSet = true; } } @@ -142,22 +152,22 @@ jQuery.extend({ } } } -}); +} ); // Radios and checkboxes getter/setter -jQuery.each([ "radio", "checkbox" ], function() { +jQuery.each( [ "radio", "checkbox" ], function() { jQuery.valHooks[ this ] = { set: function( elem, value ) { if ( jQuery.isArray( value ) ) { - return ( elem.checked = jQuery.inArray( jQuery(elem).val(), value ) > -1 ); + return ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) > -1 ); } } }; if ( !support.checkOn ) { jQuery.valHooks[ this ].get = function( elem ) { - return elem.getAttribute("value") === null ? "on" : elem.value; + return elem.getAttribute( "value" ) === null ? "on" : elem.value; }; } -}); +} ); -}); +} ); diff --git a/src/callbacks.js b/src/callbacks.js index bec37ef54..b032c8f1c 100644 --- a/src/callbacks.js +++ b/src/callbacks.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/rnotwhite" ], function( jQuery, rnotwhite ) { @@ -8,7 +8,7 @@ function createOptions( options ) { var object = {}; jQuery.each( options.match( rnotwhite ) || [], function( _, flag ) { object[ flag ] = true; - }); + } ); return object; } @@ -44,18 +44,25 @@ jQuery.Callbacks = function( options ) { var // Flag to know if list is currently firing firing, + // Last fire value for non-forgettable lists memory, + // Flag to know if list was already fired fired, + // Flag to prevent firing locked, + // Actual callback list list = [], + // Queue of execution data for repeatable lists queue = [], + // Index of currently firing callback (modified by add/remove as needed) firingIndex = -1, + // Fire callbacks fire = function() { @@ -114,18 +121,19 @@ jQuery.Callbacks = function( options ) { queue.push( memory ); } - (function add( args ) { + ( function add( args ) { jQuery.each( args, function( _, arg ) { if ( jQuery.isFunction( arg ) ) { if ( !options.unique || !self.has( arg ) ) { list.push( arg ); } } else if ( arg && arg.length && jQuery.type( arg ) !== "string" ) { + // Inspect recursively add( arg ); } - }); - })( arguments ); + } ); + } )( arguments ); if ( memory && !firing ) { fire(); @@ -146,7 +154,7 @@ jQuery.Callbacks = function( options ) { firingIndex--; } } - }); + } ); return this; }, @@ -221,4 +229,4 @@ jQuery.Callbacks = function( options ) { }; return jQuery; -}); +} ); diff --git a/src/core.js b/src/core.js index 0c21744e2..6bc8dc5ab 100644 --- a/src/core.js +++ b/src/core.js @@ -1,4 +1,4 @@ -define([ +define( [ "./var/deletedIds", "./var/document", "./var/slice", @@ -17,6 +17,7 @@ var // Define a local copy of jQuery jQuery = function( selector, context ) { + // The jQuery object is actually just the init constructor 'enhanced' // Need init if jQuery is called (just allow error to be thrown if not included) return new jQuery.fn.init( selector, context ); @@ -36,6 +37,7 @@ var }; jQuery.fn = jQuery.prototype = { + // The current version of jQuery being used jquery: version, @@ -80,9 +82,9 @@ jQuery.fn = jQuery.prototype = { }, map: function( callback ) { - return this.pushStack( jQuery.map(this, function( elem, i ) { + return this.pushStack( jQuery.map( this, function( elem, i ) { return callback.call( elem, i, elem ); - })); + } ) ); }, slice: function() { @@ -100,11 +102,11 @@ jQuery.fn = jQuery.prototype = { eq: function( i ) { var len = this.length, j = +i + ( i < 0 ? len : 0 ); - return this.pushStack( j >= 0 && j < len ? [ this[j] ] : [] ); + return this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] ); }, end: function() { - return this.prevObject || this.constructor(null); + return this.prevObject || this.constructor( null ); }, // For internal use only. @@ -116,7 +118,7 @@ jQuery.fn = jQuery.prototype = { jQuery.extend = jQuery.fn.extend = function() { var src, copyIsArray, copy, name, options, clone, - target = arguments[0] || {}, + target = arguments[ 0 ] || {}, i = 1, length = arguments.length, deep = false; @@ -131,7 +133,7 @@ jQuery.extend = jQuery.fn.extend = function() { } // Handle case when target is a string or something (possible in deep copy) - if ( typeof target !== "object" && !jQuery.isFunction(target) ) { + if ( typeof target !== "object" && !jQuery.isFunction( target ) ) { target = {}; } @@ -142,8 +144,10 @@ jQuery.extend = jQuery.fn.extend = function() { } for ( ; i < length; i++ ) { + // Only deal with non-null/undefined values - if ( (options = arguments[ i ]) != null ) { + if ( ( options = arguments[ i ] ) != null ) { + // Extend the base object for ( name in options ) { src = target[ name ]; @@ -155,15 +159,15 @@ jQuery.extend = jQuery.fn.extend = function() { } // Recurse if we're merging plain objects or arrays - if ( deep && copy && ( jQuery.isPlainObject(copy) || - (copyIsArray = jQuery.isArray(copy)) ) ) { + if ( deep && copy && ( jQuery.isPlainObject( copy ) || + ( copyIsArray = jQuery.isArray( copy ) ) ) ) { if ( copyIsArray ) { copyIsArray = false; - clone = src && jQuery.isArray(src) ? src : []; + clone = src && jQuery.isArray( src ) ? src : []; } else { - clone = src && jQuery.isPlainObject(src) ? src : {}; + clone = src && jQuery.isPlainObject( src ) ? src : {}; } // Never move original objects, clone them @@ -181,7 +185,8 @@ jQuery.extend = jQuery.fn.extend = function() { return target; }; -jQuery.extend({ +jQuery.extend( { + // Unique for each copy of jQuery on the page expando: "jQuery" + ( version + Math.random() ).replace( /\D/g, "" ), @@ -198,11 +203,11 @@ jQuery.extend({ // Since version 1.3, DOM methods and functions like alert // aren't supported. They return false on IE (#2968). isFunction: function( obj ) { - return jQuery.type(obj) === "function"; + return jQuery.type( obj ) === "function"; }, isArray: Array.isArray || function( obj ) { - return jQuery.type(obj) === "array"; + return jQuery.type( obj ) === "array"; }, isWindow: function( obj ) { @@ -211,11 +216,12 @@ jQuery.extend({ }, isNumeric: function( obj ) { + // parseFloat NaNs numeric-cast false positives (null|true|false|"") // ...but misinterprets leading-number strings, particularly hex literals ("0x...") // subtraction forces infinities to NaN // adding 1 corrects loss of precision from parseFloat (#15100) - return !jQuery.isArray( obj ) && (obj - parseFloat( obj ) + 1) >= 0; + return !jQuery.isArray( obj ) && ( obj - parseFloat( obj ) + 1 ) >= 0; }, isEmptyObject: function( obj ) { @@ -232,18 +238,20 @@ jQuery.extend({ // Must be an Object. // Because of IE, we also have to check the presence of the constructor property. // Make sure that DOM nodes and window objects don't pass through, as well - if ( !obj || jQuery.type(obj) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) { + if ( !obj || jQuery.type( obj ) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) { return false; } try { + // Not own constructor property must be Object if ( obj.constructor && - !hasOwn.call(obj, "constructor") && - !hasOwn.call(obj.constructor.prototype, "isPrototypeOf") ) { + !hasOwn.call( obj, "constructor" ) && + !hasOwn.call( obj.constructor.prototype, "isPrototypeOf" ) ) { return false; } } catch ( e ) { + // IE8,9 Will throw exceptions on certain host objects #9897 return false; } @@ -268,12 +276,13 @@ jQuery.extend({ return obj + ""; } return typeof obj === "object" || typeof obj === "function" ? - class2type[ toString.call(obj) ] || "object" : + class2type[ toString.call( obj ) ] || "object" : typeof obj; }, // Evaluates a script in a global context globalEval: function( data ) { + // Inspired by code by Andrea Giammarchi // http://webreflection.blogspot.com/2007/08/global-scope-evaluation-and-dom.html var head = document.head || jQuery( "head" )[ 0 ] || document.documentElement, @@ -353,6 +362,7 @@ jQuery.extend({ i = i ? i < 0 ? Math.max( 0, len + i ) : i : 0; for ( ; i < len; i++ ) { + // Skip accessing in sparse arrays if ( i in arr && arr[ i ] === elem ) { return i; @@ -375,7 +385,7 @@ jQuery.extend({ // Support: IE<9 // Workaround casting of .length to NaN on otherwise arraylike objects (e.g., NodeLists) if ( len !== len ) { - while ( second[j] !== undefined ) { + while ( second[ j ] !== undefined ) { first[ i++ ] = second[ j++ ]; } } @@ -475,7 +485,7 @@ jQuery.extend({ // jQuery.support is not used in Core but other projects attach their // properties to it so it needs to exist. support: support -}); +} ); // JSHint would error on this code due to the Symbol not being defined in ES5. // Defining this global in .jshintrc would create a danger of using the global @@ -488,10 +498,10 @@ if ( typeof Symbol === "function" ) { /* jshint ignore: end */ // Populate the class2type map -jQuery.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), -function(i, name) { +jQuery.each( "Boolean Number String Function Array Date RegExp Object Error".split( " " ), +function( i, name ) { class2type[ "[object " + name + "]" ] = name.toLowerCase(); -}); +} ); function isArrayLike( obj ) { @@ -511,4 +521,4 @@ function isArrayLike( obj ) { } return jQuery; -}); +} ); diff --git a/src/core/access.js b/src/core/access.js index 1e03cb8af..7fb3cd494 100644 --- a/src/core/access.js +++ b/src/core/access.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core" ], function( jQuery ) { @@ -13,7 +13,7 @@ var access = function( elems, fn, key, value, chainable, emptyGet, raw ) { if ( jQuery.type( key ) === "object" ) { chainable = true; for ( i in key ) { - access( elems, fn, i, key[i], true, emptyGet, raw ); + access( elems, fn, i, key[ i ], true, emptyGet, raw ); } // Sets one value @@ -25,6 +25,7 @@ var access = function( elems, fn, key, value, chainable, emptyGet, raw ) { } if ( bulk ) { + // Bulk operations run against the entire set if ( raw ) { fn.call( elems, value ); @@ -41,7 +42,11 @@ var access = function( elems, fn, key, value, chainable, emptyGet, raw ) { if ( fn ) { for ( ; i < length; i++ ) { - fn( elems[i], key, raw ? value : value.call( elems[i], i, fn( elems[i], key ) ) ); + fn( + elems[ i ], + key, + raw ? value : value.call( elems[ i ], i, fn( elems[ i ], key ) ) + ); } } } @@ -52,9 +57,9 @@ var access = function( elems, fn, key, value, chainable, emptyGet, raw ) { // Gets bulk ? fn.call( elems ) : - length ? fn( elems[0], key ) : emptyGet; + length ? fn( elems[ 0 ], key ) : emptyGet; }; return access; -}); +} ); diff --git a/src/core/init.js b/src/core/init.js index a438ea0db..5ce89e8a1 100644 --- a/src/core/init.js +++ b/src/core/init.js @@ -1,5 +1,5 @@ // Initialize a jQuery object -define([ +define( [ "../core", "../var/document", "./var/rsingleTag", @@ -41,23 +41,24 @@ var rootjQuery, } // Match html or make sure no context is specified for #id - if ( match && (match[1] || !context) ) { + if ( match && ( match[ 1 ] || !context ) ) { // HANDLE: $(html) -> $(array) - if ( match[1] ) { - context = context instanceof jQuery ? context[0] : context; + if ( match[ 1 ] ) { + context = context instanceof jQuery ? context[ 0 ] : context; // scripts is true for back-compat // Intentionally let the error be thrown if parseHTML is not present jQuery.merge( this, jQuery.parseHTML( - match[1], + match[ 1 ], context && context.nodeType ? context.ownerDocument || context : document, true ) ); // HANDLE: $(html, props) - if ( rsingleTag.test( match[1] ) && jQuery.isPlainObject( context ) ) { + if ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) { for ( match in context ) { + // Properties of context are called as methods if possible if ( jQuery.isFunction( this[ match ] ) ) { this[ match ]( context[ match ] ); @@ -73,11 +74,12 @@ var rootjQuery, // HANDLE: $(#id) } else { - elem = document.getElementById( match[2] ); + elem = document.getElementById( match[ 2 ] ); if ( elem ) { + // Inject the element directly into the jQuery object - this[0] = elem; + this[ 0 ] = elem; this.length = 1; } return this; @@ -95,7 +97,7 @@ var rootjQuery, // HANDLE: $(DOMElement) } else if ( selector.nodeType ) { - this[0] = selector; + this[ 0 ] = selector; this.length = 1; return this; @@ -104,6 +106,7 @@ var rootjQuery, } else if ( jQuery.isFunction( selector ) ) { return typeof root.ready !== "undefined" ? root.ready( selector ) : + // Execute immediately if ready is not present selector( jQuery ); } @@ -119,4 +122,4 @@ rootjQuery = jQuery( document ); return init; -}); +} ); diff --git a/src/core/parseHTML.js b/src/core/parseHTML.js index e7d7c63c8..f6eb7abb4 100644 --- a/src/core/parseHTML.js +++ b/src/core/parseHTML.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../var/document", "./var/rsingleTag", @@ -20,6 +20,7 @@ jQuery.parseHTML = function( data, context, keepScripts ) { keepScripts = context; context = false; } + // document.implementation stops scripts or inline event handlers from // being executed immediately context = context || ( support.createHTMLDocument ? @@ -31,7 +32,7 @@ jQuery.parseHTML = function( data, context, keepScripts ) { // Single tag if ( parsed ) { - return [ context.createElement( parsed[1] ) ]; + return [ context.createElement( parsed[ 1 ] ) ]; } parsed = buildFragment( [ data ], context, scripts ); @@ -45,4 +46,4 @@ jQuery.parseHTML = function( data, context, keepScripts ) { return jQuery.parseHTML; -}); +} ); diff --git a/src/core/ready.js b/src/core/ready.js index c5835a4a3..046f3abb1 100644 --- a/src/core/ready.js +++ b/src/core/ready.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../var/document", "../deferred" @@ -8,13 +8,15 @@ define([ var readyList; jQuery.fn.ready = function( fn ) { + // Add the callback jQuery.ready.promise().done( fn ); return this; }; -jQuery.extend({ +jQuery.extend( { + // Is the DOM ready to be used? Set to true once it occurs. isReady: false, @@ -50,7 +52,7 @@ jQuery.extend({ // If there are functions bound, to execute readyList.resolveWith( document, [ jQuery ] ); } -}); +} ); /** * Clean-up method for dom ready events @@ -71,6 +73,7 @@ function detach() { * The ready event handler and self cleanup method */ function completed() { + // readyState === "complete" is good enough for us to call the dom ready in oldIE if ( document.addEventListener || window.event.type === "load" || @@ -93,11 +96,13 @@ jQuery.ready.promise = function( obj ) { // discovered by ChrisS here: // http://bugs.jquery.com/ticket/12282#comment:15 if ( document.readyState === "complete" ) { + // Handle it asynchronously to allow scripts the opportunity to delay ready window.setTimeout( jQuery.ready ); // Standards-based browsers support DOMContentLoaded } else if ( document.addEventListener ) { + // Use the handy event callback document.addEventListener( "DOMContentLoaded", completed ); @@ -107,6 +112,7 @@ jQuery.ready.promise = function( obj ) { // Support: IE<9 // If IE event model is used } else { + // Ensure firing before onload, maybe late but safe also for iframes document.attachEvent( "onreadystatechange", completed ); @@ -120,4 +126,4 @@ jQuery.ready.promise = function( obj ) { // Kick off the DOM ready check even if the user does not jQuery.ready.promise(); -}); +} ); diff --git a/src/core/support.js b/src/core/support.js index 8348ab7e3..36d19715f 100644 --- a/src/core/support.js +++ b/src/core/support.js @@ -1,4 +1,4 @@ -define([ +define( [ "../var/document", "../var/support" ], function( document, support ) { @@ -8,14 +8,14 @@ define([ // collapse sibling forms: the second one becomes a child of the first one. // Because of that, this security measure has to be disabled in Safari 8. // https://bugs.webkit.org/show_bug.cgi?id=137337 -support.createHTMLDocument = (function() { +support.createHTMLDocument = ( function() { if ( !document.implementation.createHTMLDocument ) { return false; } var doc = document.implementation.createHTMLDocument( "" ); doc.body.innerHTML = "<form></form><form></form>"; return doc.body.childNodes.length === 2; -})(); +} )(); return support; -}); +} ); diff --git a/src/core/var/rsingleTag.js b/src/core/var/rsingleTag.js index a8176dc64..1a55ee39d 100644 --- a/src/core/var/rsingleTag.js +++ b/src/core/var/rsingleTag.js @@ -1,4 +1,5 @@ -define(function() { +define( function() { + // Match a standalone tag - return (/^<([\w-]+)\s*\/?>(?:<\/\1>|)$/); -}); + return ( /^<([\w-]+)\s*\/?>(?:<\/\1>|)$/ ); +} ); diff --git a/src/css.js b/src/css.js index 27c5ecf88..17c47453a 100644 --- a/src/css.js +++ b/src/css.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/pnum", "./core/access", @@ -22,6 +22,7 @@ define([ isHidden, swap, curCSS, adjustCSS, addGetHookIf, support, showHide ) { var + // BuildExclude getStyles = curCSS.getStyles, ralpha = /alpha\([^)]*\)/i, @@ -69,6 +70,7 @@ function vendorPropName( name ) { function setPositiveNumber( elem, value, subtract ) { var matches = rnumsplit.exec( value ); return matches ? + // Guard against undefined "subtract", e.g., when used as in cssHooks Math.max( 0, matches[ 1 ] - ( subtract || 0 ) ) + ( matches[ 2 ] || "px" ) : value; @@ -76,20 +78,24 @@ function setPositiveNumber( elem, value, subtract ) { function augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) { var i = extra === ( isBorderBox ? "border" : "content" ) ? + // If we already have the right measurement, avoid augmentation 4 : + // Otherwise initialize for horizontal or vertical properties name === "width" ? 1 : 0, val = 0; for ( ; i < 4; i += 2 ) { + // both box models exclude margin, so add it if we want it if ( extra === "margin" ) { val += jQuery.css( elem, extra + cssExpand[ i ], true, styles ); } if ( isBorderBox ) { + // border-box includes padding, so remove it if we want content if ( extra === "content" ) { val -= jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); @@ -100,6 +106,7 @@ function augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) { val -= jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); } } else { + // at this point, extra isn't content, so add padding val += jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); @@ -122,6 +129,7 @@ function getWidthOrHeight( elem, name, extra ) { isBorderBox = jQuery.css( elem, "boxSizing", false, styles ) === "border-box"; if ( support.gBCRDimensions() ) { + // Support: IE <= 11 only // Running getBoundingClientRect on a disconnected node // in IE throws an error. @@ -129,6 +137,7 @@ function getWidthOrHeight( elem, name, extra ) { val = elem.getBoundingClientRect()[ name ]; } } else { + // In IE8 gBCR doesn't report width & height; we need to fall back to offset*. val = name === "width" ? elem.offsetWidth : elem.offsetHeight; } @@ -144,6 +153,7 @@ function getWidthOrHeight( elem, name, extra ) { // svg - https://bugzilla.mozilla.org/show_bug.cgi?id=649285 // MathML - https://bugzilla.mozilla.org/show_bug.cgi?id=491668 if ( val <= 0 || val == null ) { + // Fall back to computed then uncomputed css if necessary val = curCSS( elem, name, styles ); if ( val < 0 || val == null ) { @@ -151,7 +161,7 @@ function getWidthOrHeight( elem, name, extra ) { } // Computed unit is not pixels. Stop here and return. - if ( rnumnonpx.test(val) ) { + if ( rnumnonpx.test( val ) ) { return val; } @@ -176,13 +186,15 @@ function getWidthOrHeight( elem, name, extra ) { ) + "px"; } -jQuery.extend({ +jQuery.extend( { + // Add in style property hooks for overriding the default // behavior of getting and setting a style property cssHooks: { opacity: { get: function( elem, computed ) { if ( computed ) { + // We should always get a number back from opacity var ret = curCSS( elem, "opacity" ); return ret === "" ? "1" : ret; @@ -210,12 +222,14 @@ jQuery.extend({ // Add in properties whose names you wish to fix before // setting or getting the value cssProps: { + // normalize float css property "float": support.cssFloat ? "cssFloat" : "styleFloat" }, // Get and set the style property on a DOM Node style: function( elem, name, value, extra ) { + // Don't set styles on text and comment nodes if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) { return; @@ -238,8 +252,9 @@ jQuery.extend({ type = typeof value; // Convert "+=" or "-=" to relative numbers (#7345) - if ( type === "string" && (ret = rcssNum.exec( value )) && ret[ 1 ] ) { + if ( type === "string" && ( ret = rcssNum.exec( value ) ) && ret[ 1 ] ) { value = adjustCSS( elem, name, ret ); + // Fixes bug #9237 type = "number"; } @@ -257,25 +272,26 @@ jQuery.extend({ // Fixes #8908, it can be done more correctly by specifing setters in cssHooks, // but it would mean to define eight // (for every problematic property) identical functions - if ( !support.clearCloneStyle && value === "" && name.indexOf("background") === 0 ) { + if ( !support.clearCloneStyle && value === "" && name.indexOf( "background" ) === 0 ) { style[ name ] = "inherit"; } // If a hook was provided, use that value, otherwise just set the specified value - if ( !hooks || !("set" in hooks) || - (value = hooks.set( elem, value, extra )) !== undefined ) { + if ( !hooks || !( "set" in hooks ) || + ( value = hooks.set( elem, value, extra ) ) !== undefined ) { // Support: IE<9 // Swallow errors from 'invalid' CSS values (#5509) try { style[ name ] = value; - } catch (e) {} + } catch ( e ) {} } } else { + // If a hook was provided get the non-computed value from there if ( hooks && "get" in hooks && - (ret = hooks.get( elem, false, extra )) !== undefined ) { + ( ret = hooks.get( elem, false, extra ) ) !== undefined ) { return ret; } @@ -319,15 +335,17 @@ jQuery.extend({ } return val; } -}); +} ); -jQuery.each([ "height", "width" ], function( i, name ) { +jQuery.each( [ "height", "width" ], function( i, name ) { jQuery.cssHooks[ name ] = { get: function( elem, computed, extra ) { if ( computed ) { + // certain elements can have dimension info if we invisibly show them // however, it must have a current display style that would benefit from this return rdisplayswap.test( jQuery.css( elem, "display" ) ) && + // Support: Safari 8+ // Table columns in Safari have non-zero offsetWidth & zero // getBoundingClientRect().width unless display is changed. @@ -337,7 +355,7 @@ jQuery.each([ "height", "width" ], function( i, name ) { ( !elem.getClientRects().length || !elem.getBoundingClientRect().width ) ? swap( elem, cssShow, function() { return getWidthOrHeight( elem, name, extra ); - }) : + } ) : getWidthOrHeight( elem, name, extra ); } }, @@ -355,15 +373,16 @@ jQuery.each([ "height", "width" ], function( i, name ) { ); } }; -}); +} ); if ( !support.opacity ) { jQuery.cssHooks.opacity = { get: function( elem, computed ) { + // IE uses filters for opacity - return ropacity.test( (computed && elem.currentStyle ? + return ropacity.test( ( computed && elem.currentStyle ? elem.currentStyle.filter : - elem.style.filter) || "" ) ? + elem.style.filter ) || "" ) ? ( 0.01 * parseFloat( RegExp.$1 ) ) + "" : computed ? "1" : ""; }, @@ -416,7 +435,7 @@ jQuery.cssHooks.marginRight = addGetHookIf( support.reliableMarginRight, ); // These hooks are used by animate to expand properties -jQuery.each({ +jQuery.each( { margin: "", padding: "", border: "Width" @@ -427,7 +446,7 @@ jQuery.each({ expanded = {}, // assumes a single number if not a string - parts = typeof value === "string" ? value.split(" ") : [ value ]; + parts = typeof value === "string" ? value.split( " " ) : [ value ]; for ( ; i < 4; i++ ) { expanded[ prefix + cssExpand[ i ] + suffix ] = @@ -441,9 +460,9 @@ jQuery.each({ if ( !rmargin.test( prefix ) ) { jQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber; } -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { css: function( name, value ) { return access( this, function( elem, name, value ) { var styles, len, @@ -477,15 +496,15 @@ jQuery.fn.extend({ return state ? this.show() : this.hide(); } - return this.each(function() { + return this.each( function() { if ( isHidden( this ) ) { jQuery( this ).show(); } else { jQuery( this ).hide(); } - }); + } ); } -}); +} ); return jQuery; -}); +} ); diff --git a/src/css/addGetHookIf.js b/src/css/addGetHookIf.js index e12f3598d..9cd21f683 100644 --- a/src/css/addGetHookIf.js +++ b/src/css/addGetHookIf.js @@ -1,10 +1,12 @@ -define(function() { +define( function() { function addGetHookIf( conditionFn, hookFn ) { + // Define the hook, we'll check on the first run if it's really needed. return { get: function() { if ( conditionFn() ) { + // Hook not needed (or it's not possible to use it due // to missing dependency), remove it. delete this.get; @@ -12,11 +14,11 @@ function addGetHookIf( conditionFn, hookFn ) { } // Hook needed; redefine it so that the support test is not executed again. - return (this.get = hookFn).apply( this, arguments ); + return ( this.get = hookFn ).apply( this, arguments ); } }; } return addGetHookIf; -}); +} ); diff --git a/src/css/adjustCSS.js b/src/css/adjustCSS.js index 05fddd15b..48fcfec05 100644 --- a/src/css/adjustCSS.js +++ b/src/css/adjustCSS.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../var/rcssNum" ], function( jQuery, rcssNum ) { @@ -12,11 +12,13 @@ function adjustCSS( elem, prop, valueParts, tween ) { function() { return jQuery.css( elem, prop, "" ); }, initial = currentValue(), unit = valueParts && valueParts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ), + // Starting value computation is required for potential unit mismatches initialInUnit = ( jQuery.cssNumber[ prop ] || unit !== "px" && +initial ) && rcssNum.exec( jQuery.css( elem, prop ) ); if ( initialInUnit && initialInUnit[ 3 ] !== unit ) { + // Trust units reported by jQuery.css unit = unit || initialInUnit[ 3 ]; @@ -27,6 +29,7 @@ function adjustCSS( elem, prop, valueParts, tween ) { initialInUnit = +initial || 1; do { + // If previous iteration zeroed out, double until we get *something*. // Use string for doubling so we don't accidentally see scale as unchanged below scale = scale || ".5"; @@ -38,12 +41,13 @@ function adjustCSS( elem, prop, valueParts, tween ) { // Update scale, tolerating zero or NaN from tween.cur() // Break the loop if scale is unchanged or perfect, or if we've just had enough. } while ( - scale !== (scale = currentValue() / initial) && scale !== 1 && --maxIterations + scale !== ( scale = currentValue() / initial ) && scale !== 1 && --maxIterations ); } if ( valueParts ) { initialInUnit = +initialInUnit || +initial || 0; + // Apply relative offset (+=/-=) if specified adjusted = valueParts[ 1 ] ? initialInUnit + ( valueParts[ 1 ] + 1 ) * valueParts[ 2 ] : @@ -58,4 +62,4 @@ function adjustCSS( elem, prop, valueParts, tween ) { } return adjustCSS; -}); +} ); diff --git a/src/css/curCSS.js b/src/css/curCSS.js index 967ce3e94..8acf49038 100644 --- a/src/css/curCSS.js +++ b/src/css/curCSS.js @@ -1,4 +1,4 @@ -define([ +define( [ "exports", "../core", "../var/documentElement", @@ -13,6 +13,7 @@ var getStyles, curCSS, if ( window.getComputedStyle ) { getStyles = function( elem ) { + // Support: IE<=11+, Firefox<=30+ (#15098, #14150) // IE throws on elements created in popups // FF meanwhile throws on frame elements through "defaultView.getComputedStyle" @@ -120,4 +121,4 @@ if ( window.getComputedStyle ) { exports.getStyles = getStyles; exports.curCSS = curCSS; -}); +} ); diff --git a/src/css/hiddenVisibleSelectors.js b/src/css/hiddenVisibleSelectors.js index e340b16e6..46c2cb827 100644 --- a/src/css/hiddenVisibleSelectors.js +++ b/src/css/hiddenVisibleSelectors.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "./support", "../selector", @@ -15,4 +15,4 @@ jQuery.expr.filters.visible = function( elem ) { ( ( elem.style && elem.style.display ) || jQuery.css( elem, "display" ) ) !== "none" ); }; -}); +} ); diff --git a/src/css/showHide.js b/src/css/showHide.js index f500f186f..efc1bdd3f 100644 --- a/src/css/showHide.js +++ b/src/css/showHide.js @@ -1,4 +1,4 @@ -define([], function() { +define( [], function() { function showHide( elements, show ) { var display, elem, @@ -16,6 +16,7 @@ function showHide( elements, show ) { display = elem.style.display; if ( show ) { if ( display === "none" ) { + // Restore a pre-hide() value if we have one values[ index ] = jQuery._data( elem, "display" ) || ""; } @@ -42,4 +43,4 @@ function showHide( elements, show ) { return showHide; -}); +} ); diff --git a/src/css/support.js b/src/css/support.js index 7eb3c7de4..96276a9e5 100644 --- a/src/css/support.js +++ b/src/css/support.js @@ -1,11 +1,11 @@ -define([ +define( [ "../core", "../var/document", "../var/documentElement", "../var/support" ], function( jQuery, document, documentElement, support ) { -(function() { +( function() { var pixelPositionVal, boxSizingReliableVal, gBCRDimensionsVal, pixelMarginRightVal, reliableHiddenOffsetsVal, reliableMarginRightVal, container = document.createElement( "div" ), @@ -36,7 +36,7 @@ define([ div.innerHTML = ""; container.appendChild( div ); - jQuery.extend(support, { + jQuery.extend( support, { reliableHiddenOffsets: function() { if ( pixelPositionVal == null ) { computeStyleTests(); @@ -45,6 +45,7 @@ define([ }, boxSizingReliable: function() { + // We're checking for pixelPositionVal here instead of boxSizingReliableVal // since that compresses better and they're computed together anyway. if ( pixelPositionVal == null ) { @@ -61,6 +62,7 @@ define([ }, pixelMarginRight: function() { + // Support: Android 4.0-4.3 if ( pixelPositionVal == null ) { computeStyleTests(); @@ -76,13 +78,14 @@ define([ }, reliableMarginRight: function() { + // Support: Android 2.3 if ( pixelPositionVal == null ) { computeStyleTests(); } return reliableMarginRightVal; } - }); + } ); function computeStyleTests() { var contents, divStyle, @@ -92,6 +95,7 @@ define([ documentElement.appendChild( container ); div.style.cssText = + // Support: Android 2.3 // Vendor-prefix box-sizing "-webkit-box-sizing:border-box;box-sizing:border-box;" + @@ -124,6 +128,7 @@ define([ // Reset CSS: box-sizing; display; margin; border; padding contents.style.cssText = div.style.cssText = + // Support: Android 2.3 // Vendor-prefix box-sizing "-webkit-box-sizing:content-box;box-sizing:content-box;" + @@ -158,8 +163,8 @@ define([ documentElement.removeChild( container ); } -})(); +} )(); return support; -}); +} ); diff --git a/src/css/var/cssExpand.js b/src/css/var/cssExpand.js index 91e90a88a..9f8194dc8 100644 --- a/src/css/var/cssExpand.js +++ b/src/css/var/cssExpand.js @@ -1,3 +1,3 @@ -define(function() { +define( function() { return [ "Top", "Right", "Bottom", "Left" ]; -}); +} ); diff --git a/src/css/var/isHidden.js b/src/css/var/isHidden.js index c29f527ae..7997efff1 100644 --- a/src/css/var/isHidden.js +++ b/src/css/var/isHidden.js @@ -1,14 +1,16 @@ -define([ +define( [ "../../core", "../../selector" + // css is assumed ], function( jQuery ) { return function( elem, el ) { + // isHidden might be called from jQuery#filter function; // in that case, element will be second argument elem = el || elem; return jQuery.css( elem, "display" ) === "none" || !jQuery.contains( elem.ownerDocument, elem ); }; -}); +} ); diff --git a/src/css/var/rmargin.js b/src/css/var/rmargin.js index da0438db6..9be221243 100644 --- a/src/css/var/rmargin.js +++ b/src/css/var/rmargin.js @@ -1,3 +1,3 @@ -define(function() { - return (/^margin/); -}); +define( function() { + return ( /^margin/ ); +} ); diff --git a/src/css/var/rnumnonpx.js b/src/css/var/rnumnonpx.js index c93be2850..ed13f0b98 100644 --- a/src/css/var/rnumnonpx.js +++ b/src/css/var/rnumnonpx.js @@ -1,5 +1,5 @@ -define([ +define( [ "../../var/pnum" ], function( pnum ) { return new RegExp( "^(" + pnum + ")(?!px)[a-z%]+$", "i" ); -}); +} ); diff --git a/src/css/var/swap.js b/src/css/var/swap.js index dbf639729..b6d3b679f 100644 --- a/src/css/var/swap.js +++ b/src/css/var/swap.js @@ -1,4 +1,4 @@ -define(function() { +define( function() { // A method for quickly swapping in/out CSS properties to get correct calculations. return function( elem, options, callback, args ) { @@ -21,4 +21,4 @@ return function( elem, options, callback, args ) { return ret; }; -}); +} ); diff --git a/src/data.js b/src/data.js index 30acce094..f5ed1e34f 100644 --- a/src/data.js +++ b/src/data.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/deletedIds", "./data/support", @@ -9,6 +9,7 @@ var rbrace = /^(?:\{[\w\W]*\}|\[[\w\W]*\])$/, rmultiDash = /([A-Z])/g; function dataAttr( elem, key, data ) { + // If nothing was found internally, try to fetch any // data from the HTML5 data-* attribute if ( data === undefined && elem.nodeType === 1 ) { @@ -22,6 +23,7 @@ function dataAttr( elem, key, data ) { data = data === "true" ? true : data === "false" ? false : data === "null" ? null : + // Only convert to a number if it doesn't change the string +data + "" === data ? +data : rbrace.test( data ) ? jQuery.parseJSON( data ) : @@ -78,12 +80,13 @@ function internalData( elem, key, data, pvt /* Internal Use Only */ ) { // Avoid doing any more work than we need to when trying to get data on an // object that has no data at all - if ( (!id || !cache[id] || (!pvt && !cache[id].data)) && + if ( ( !id || !cache[ id ] || ( !pvt && !cache[ id ].data ) ) && data === undefined && typeof key === "string" ) { return; } if ( !id ) { + // Only DOM nodes need a new unique ID for each element since their data // ends up in the global cache if ( isNode ) { @@ -94,6 +97,7 @@ function internalData( elem, key, data, pvt /* Internal Use Only */ ) { } if ( !cache[ id ] ) { + // Avoid exposing jQuery metadata on plain JS objects when the object // is serialized using JSON.stringify cache[ id ] = isNode ? {} : { toJSON: jQuery.noop }; @@ -118,6 +122,7 @@ function internalData( elem, key, data, pvt /* Internal Use Only */ ) { for ( prop in key ) { thisCache[ jQuery.camelCase( prop ) ] = key[ prop ]; } + // Stop here, ignore other arguments return thisCache; } @@ -129,6 +134,7 @@ function internalData( elem, key, data, pvt /* Internal Use Only */ ) { // We always set camelCased properties (gh-2257) return typeof key === "string" ? thisCache[ jQuery.camelCase( key ) ] : + // Return the whole cache if no key was specified thisCache; } @@ -178,7 +184,7 @@ function internalRemoveData( elem, key, pvt ) { // If there is no data left in the cache, we want to continue // and let the cache object itself get destroyed - if ( pvt ? !isEmptyDataObject(thisCache) : !jQuery.isEmptyObject(thisCache) ) { + if ( pvt ? !isEmptyDataObject( thisCache ) : !jQuery.isEmptyObject( thisCache ) ) { return; } } @@ -211,7 +217,7 @@ function internalRemoveData( elem, key, pvt ) { } } -jQuery.extend({ +jQuery.extend( { cache: {}, // The following elements (space-suffixed to avoid Object.prototype collisions) @@ -219,12 +225,13 @@ jQuery.extend({ noData: { "applet ": true, "embed ": true, + // ...but Flash objects (which have this classid) *can* handle expandos "object ": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000" }, hasData: function( elem ) { - elem = elem.nodeType ? jQuery.cache[ elem[jQuery.expando] ] : elem[ jQuery.expando ]; + elem = elem.nodeType ? jQuery.cache[ elem[ jQuery.expando ] ] : elem[ jQuery.expando ]; return !!elem && !isEmptyDataObject( elem ); }, @@ -244,12 +251,12 @@ jQuery.extend({ _removeData: function( elem, name ) { return internalRemoveData( elem, name, true ); } -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { data: function( key, value ) { var i, name, data, - elem = this[0], + elem = this[ 0 ], attrs = elem && elem.attributes; // Special expections of .data basically thwart jQuery.access, @@ -269,7 +276,7 @@ jQuery.fn.extend({ if ( attrs[ i ] ) { name = attrs[ i ].name; if ( name.indexOf( "data-" ) === 0 ) { - name = jQuery.camelCase( name.slice(5) ); + name = jQuery.camelCase( name.slice( 5 ) ); dataAttr( elem, name, data[ name ] ); } } @@ -283,16 +290,17 @@ jQuery.fn.extend({ // Sets multiple values if ( typeof key === "object" ) { - return this.each(function() { + return this.each( function() { jQuery.data( this, key ); - }); + } ); } return arguments.length > 1 ? + // Sets one value - this.each(function() { + this.each( function() { jQuery.data( this, key, value ); - }) : + } ) : // Gets one value // Try to fetch any internally stored data first @@ -300,11 +308,11 @@ jQuery.fn.extend({ }, removeData: function( key ) { - return this.each(function() { + return this.each( function() { jQuery.removeData( this, key ); - }); + } ); } -}); +} ); return jQuery; -}); +} ); diff --git a/src/data/accepts.js b/src/data/accepts.js index 6e0b1b518..ea1b013c7 100644 --- a/src/data/accepts.js +++ b/src/data/accepts.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core" ], function( jQuery ) { @@ -6,7 +6,7 @@ define([ * Determines whether an object can have data */ jQuery.acceptData = function( elem ) { - var noData = jQuery.noData[ (elem.nodeName + " ").toLowerCase() ], + var noData = jQuery.noData[ ( elem.nodeName + " " ).toLowerCase() ], nodeType = +elem.nodeType || 1; // Do not set data on non-element DOM nodes because it will not be cleared (#8335). @@ -14,8 +14,8 @@ jQuery.acceptData = function( elem ) { false : // Nodes accept data unless otherwise specified; rejection can be conditional - !noData || noData !== true && elem.getAttribute("classid") === noData; + !noData || noData !== true && elem.getAttribute( "classid" ) === noData; }; return jQuery.acceptData; -}); +} ); diff --git a/src/data/support.js b/src/data/support.js index df17c5c40..f796ab574 100644 --- a/src/data/support.js +++ b/src/data/support.js @@ -1,9 +1,9 @@ -define([ +define( [ "../var/document", "../var/support" ], function( document, support ) { -(function() { +( function() { var div = document.createElement( "div" ); // Support: IE<9 @@ -16,8 +16,8 @@ define([ // Null elements to avoid leaks in IE. div = null; -})(); +} )(); return support; -}); +} ); diff --git a/src/deferred.js b/src/deferred.js index 050ad765e..10e59a571 100644 --- a/src/deferred.js +++ b/src/deferred.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/slice", "./callbacks" @@ -11,18 +11,19 @@ function Thrower( ex ) { throw ex; } -jQuery.extend({ +jQuery.extend( { Deferred: function( func ) { var tuples = [ + // action, add listener, callbacks, // ... .then handlers, argument index, [final state] - [ "notify", "progress", jQuery.Callbacks("memory"), - jQuery.Callbacks("memory"), 2 ], - [ "resolve", "done", jQuery.Callbacks("once memory"), - jQuery.Callbacks("once memory"), 0, "resolved" ], - [ "reject", "fail", jQuery.Callbacks("once memory"), - jQuery.Callbacks("once memory"), 1, "rejected" ] + [ "notify", "progress", jQuery.Callbacks( "memory" ), + jQuery.Callbacks( "memory" ), 2 ], + [ "resolve", "done", jQuery.Callbacks( "once memory" ), + jQuery.Callbacks( "once memory" ), 0, "resolved" ], + [ "reject", "fail", jQuery.Callbacks( "once memory" ), + jQuery.Callbacks( "once memory" ), 1, "rejected" ] ], state = "pending", promise = { @@ -36,19 +37,21 @@ jQuery.extend({ "catch": function( fn ) { return promise.then( null, fn ); }, + // Keep pipe for back-compat pipe: function( /* fnDone, fnFail, fnProgress */ ) { var fns = arguments; - return jQuery.Deferred(function( newDefer ) { + return jQuery.Deferred( function( newDefer ) { jQuery.each( tuples, function( i, tuple ) { + // Map tuples (progress, done, fail) to arguments (done, fail, progress) var fn = jQuery.isFunction( fns[ tuple[ 4 ] ] ) && fns[ tuple[ 4 ] ]; // deferred.progress(function() { bind to newDefer or newDefer.notify }) // deferred.done(function() { bind to newDefer or newDefer.resolve }) // deferred.fail(function() { bind to newDefer or newDefer.reject }) - deferred[ tuple[1] ](function() { + deferred[ tuple[ 1 ] ]( function() { var returned = fn && fn.apply( this, arguments ); if ( returned && jQuery.isFunction( returned.promise ) ) { returned.promise() @@ -61,10 +64,10 @@ jQuery.extend({ fn ? [ returned ] : arguments ); } - }); - }); + } ); + } ); fns = null; - }).promise(); + } ).promise(); }, then: function( onFulfilled, onRejected, onProgress ) { var maxDepth = 0; @@ -105,6 +108,7 @@ jQuery.extend({ // Handle a returned thenable if ( jQuery.isFunction( then ) ) { + // Special processors (notify) just wait for resolution if ( special ) { then.call( @@ -130,6 +134,7 @@ jQuery.extend({ // Handle all other returned values } else { + // Only substitue handlers pass on context // and multiple values (non-spec behavior) if ( handler !== Identity ) { @@ -156,6 +161,7 @@ jQuery.extend({ // https://promisesaplus.com/#point-61 // Ignore post-resolution exceptions if ( depth + 1 >= maxDepth ) { + // Only substitue handlers pass on context // and multiple values (non-spec behavior) if ( handler !== Thrower ) { @@ -181,7 +187,8 @@ jQuery.extend({ }; } - return jQuery.Deferred(function( newDefer ) { + return jQuery.Deferred( function( newDefer ) { + // progress_handlers.add( ... ) tuples[ 0 ][ 3 ].add( resolve( @@ -215,8 +222,9 @@ jQuery.extend({ Thrower ) ); - }).promise(); + } ).promise(); }, + // Get a promise for this deferred // If obj is provided, the promise aspect is added to the object promise: function( obj ) { @@ -233,12 +241,13 @@ jQuery.extend({ // promise.progress = list.add // promise.done = list.add // promise.fail = list.add - promise[ tuple[1] ] = list.add; + promise[ tuple[ 1 ] ] = list.add; // Handle state if ( stateString ) { list.add( function() { + // state = "resolved" (i.e., fulfilled) // state = "rejected" state = stateString; @@ -261,16 +270,16 @@ jQuery.extend({ // deferred.notify = function() { deferred.notifyWith(...) } // deferred.resolve = function() { deferred.resolveWith(...) } // deferred.reject = function() { deferred.rejectWith(...) } - deferred[ tuple[0] ] = function() { - deferred[ tuple[0] + "With" ]( this === deferred ? promise : this, arguments ); + deferred[ tuple[ 0 ] ] = function() { + deferred[ tuple[ 0 ] + "With" ]( this === deferred ? promise : this, arguments ); return this; }; // deferred.notifyWith = list.fireWith // deferred.resolveWith = list.fireWith // deferred.rejectWith = list.fireWith - deferred[ tuple[0] + "With" ] = list.fireWith; - }); + deferred[ tuple[ 0 ] + "With" ] = list.fireWith; + } ); // Make the deferred a promise promise.promise( deferred ); @@ -320,14 +329,14 @@ jQuery.extend({ resolveContexts = new Array( length ); for ( ; i < length; i++ ) { if ( resolveValues[ i ] && - jQuery.isFunction( (method = resolveValues[ i ].promise) ) ) { + jQuery.isFunction( ( method = resolveValues[ i ].promise ) ) ) { method.call( resolveValues[ i ] ) .progress( updateFunc( i, progressContexts, progressValues ) ) .done( updateFunc( i, resolveContexts, resolveValues ) ) .fail( master.reject ); } else if ( resolveValues[ i ] && - jQuery.isFunction( (method = resolveValues[ i ].then) ) ) { + jQuery.isFunction( ( method = resolveValues[ i ].then ) ) ) { method.call( resolveValues[ i ], @@ -348,7 +357,7 @@ jQuery.extend({ return master.promise(); } -}); +} ); return jQuery; -}); +} ); diff --git a/src/deprecated.js b/src/deprecated.js index 994b22848..dfb13e4ae 100644 --- a/src/deprecated.js +++ b/src/deprecated.js @@ -1,2 +1,2 @@ -define(function() { -}); +define( function() { +} ); diff --git a/src/dimensions.js b/src/dimensions.js index 08bf60ee0..24ab4e921 100644 --- a/src/dimensions.js +++ b/src/dimensions.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./core/access", "./css" @@ -8,6 +8,7 @@ define([ jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { jQuery.each( { padding: "inner" + name, content: type, "": "outer" + name }, function( defaultExtra, funcName ) { + // margin is only for outerHeight, outerWidth jQuery.fn[ funcName ] = function( margin, value ) { var chainable = arguments.length && ( defaultExtra || typeof margin !== "boolean" ), @@ -17,6 +18,7 @@ jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { var doc; if ( jQuery.isWindow( elem ) ) { + // As of 5/8/2012 this will yield incorrect results for Mobile Safari, but there // isn't a whole lot we can do. See pull request at this URL for discussion: // https://github.com/jquery/jquery/pull/764 @@ -39,6 +41,7 @@ jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { } return value === undefined ? + // Get width or height on the element, requesting but not forcing parseFloat jQuery.css( elem, type, extra ) : @@ -46,8 +49,8 @@ jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { jQuery.style( elem, type, value, extra ); }, type, chainable ? margin : undefined, chainable, null ); }; - }); -}); + } ); +} ); return jQuery; -}); +} ); diff --git a/src/effects.js b/src/effects.js index 9a0e4e0f1..64ec4ae15 100644 --- a/src/effects.js +++ b/src/effects.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/document", "./var/rcssNum", @@ -33,9 +33,9 @@ function raf() { // Animations created synchronously will run synchronously function createFxNow() { - window.setTimeout(function() { + window.setTimeout( function() { fxNow = undefined; - }); + } ); return ( fxNow = jQuery.now() ); } @@ -66,7 +66,7 @@ function createTween( value, prop, animation ) { index = 0, length = collection.length; for ( ; index < length; index++ ) { - if ( (tween = collection[ index ].call( animation, prop, value )) ) { + if ( ( tween = collection[ index ].call( animation, prop, value ) ) ) { // we're done with this property return tween; @@ -98,16 +98,17 @@ function defaultPrefilter( elem, props, opts ) { } hooks.unqueued++; - anim.always(function() { + anim.always( function() { + // doing this makes sure that the complete handler will be called // before this completes - anim.always(function() { + anim.always( function() { hooks.unqueued--; if ( !jQuery.queue( elem, "fx" ).length ) { hooks.empty.fire(); } - }); - }); + } ); + } ); } // Detect show/hide animations @@ -140,6 +141,7 @@ function defaultPrefilter( elem, props, opts ) { // Restrict "overflow" and "display" styles during box animations if ( isBox && elem.nodeType === 1 ) { + // Support: IE 9 - 11 // Record all 3 overflow attributes because IE does not infer the shorthand // from identically-valued overflowX and overflowY @@ -163,9 +165,9 @@ function defaultPrefilter( elem, props, opts ) { // Restore the original display value at the end of pure show/hide animations if ( !propTween ) { - anim.done(function() { + anim.done( function() { style.display = restoreDisplay; - }); + } ); if ( restoreDisplay == null ) { display = style.display; restoreDisplay = display === "none" ? "" : display; @@ -178,11 +180,11 @@ function defaultPrefilter( elem, props, opts ) { if ( opts.overflow ) { style.overflow = "hidden"; - anim.always(function() { + anim.always( function() { style.overflow = opts.overflow[ 0 ]; style.overflowX = opts.overflow[ 1 ]; style.overflowY = opts.overflow[ 2 ]; - }); + } ); } // Implement show/hide animations @@ -210,7 +212,8 @@ function defaultPrefilter( elem, props, opts ) { } /* jshint -W083 */ - anim.done(function() { + anim.done( function() { + // The final step of a "hide" animation is actually hiding the element if ( !hidden ) { showHide( [ elem ] ); @@ -219,7 +222,7 @@ function defaultPrefilter( elem, props, opts ) { for ( prop in orig ) { jQuery.style( elem, prop, orig[ prop ] ); } - }); + } ); } // Per-property setup @@ -277,15 +280,17 @@ function Animation( elem, properties, options ) { index = 0, length = Animation.prefilters.length, deferred = jQuery.Deferred().always( function() { + // don't match elem in the :animated selector delete tick.elem; - }), + } ), tick = function() { if ( stopped ) { return false; } var currentTime = fxNow || createFxNow(), remaining = Math.max( 0, animation.startTime + animation.duration - currentTime ), + // Support: Android 2.3 // Archaic crash bug won't allow us to use `1 - ( 0.5 || 0 )` (#12497) temp = remaining / animation.duration || 0, @@ -297,7 +302,7 @@ function Animation( elem, properties, options ) { animation.tweens[ index ].run( percent ); } - deferred.notifyWith( elem, [ animation, percent, remaining ]); + deferred.notifyWith( elem, [ animation, percent, remaining ] ); if ( percent < 1 && length ) { return remaining; @@ -306,7 +311,7 @@ function Animation( elem, properties, options ) { return false; } }, - animation = deferred.promise({ + animation = deferred.promise( { elem: elem, props: jQuery.extend( {}, properties ), opts: jQuery.extend( true, { @@ -326,6 +331,7 @@ function Animation( elem, properties, options ) { }, stop: function( gotoEnd ) { var index = 0, + // if we are going to the end, we want to run all the tweens // otherwise we skip this part length = gotoEnd ? animation.tweens.length : 0; @@ -346,7 +352,7 @@ function Animation( elem, properties, options ) { } return this; } - }), + } ), props = animation.props; propFilter( props, animation.opts.specialEasing ); @@ -373,7 +379,7 @@ function Animation( elem, properties, options ) { elem: elem, anim: animation, queue: animation.opts.queue - }) + } ) ); // attach callbacks from options @@ -421,7 +427,7 @@ jQuery.Animation = jQuery.extend( Animation, { Animation.prefilters.push( callback ); } } -}); +} ); jQuery.speed = function( speed, easing, fn ) { var opt = speed && typeof speed === "object" ? jQuery.extend( {}, speed ) : { @@ -462,18 +468,20 @@ jQuery.speed = function( speed, easing, fn ) { return opt; }; -jQuery.fn.extend({ +jQuery.fn.extend( { fadeTo: function( speed, to, easing, callback ) { + // show any hidden elements after setting opacity to 0 return this.filter( isHidden ).css( "opacity", 0 ).show() // animate to the value specified - .end().animate({ opacity: to }, speed, easing, callback ); + .end().animate( { opacity: to }, speed, easing, callback ); }, animate: function( prop, speed, easing, callback ) { var empty = jQuery.isEmptyObject( prop ), optall = jQuery.speed( speed, easing, callback ), doAnimation = function() { + // Operate on a copy of prop so per-property easing won't be lost var anim = Animation( this, jQuery.extend( {}, prop ), optall ); @@ -504,7 +512,7 @@ jQuery.fn.extend({ this.queue( type || "fx", [] ); } - return this.each(function() { + return this.each( function() { var dequeue = true, index = type != null && type + "queueHooks", timers = jQuery.timers, @@ -524,7 +532,7 @@ jQuery.fn.extend({ for ( index = timers.length; index--; ) { if ( timers[ index ].elem === this && - (type == null || timers[ index ].queue === type) ) { + ( type == null || timers[ index ].queue === type ) ) { timers[ index ].anim.stop( gotoEnd ); dequeue = false; @@ -538,13 +546,13 @@ jQuery.fn.extend({ if ( dequeue || !gotoEnd ) { jQuery.dequeue( this, type ); } - }); + } ); }, finish: function( type ) { if ( type !== false ) { type = type || "fx"; } - return this.each(function() { + return this.each( function() { var index, data = jQuery._data( this ), queue = data[ type + "queue" ], @@ -579,24 +587,24 @@ jQuery.fn.extend({ // turn off finishing flag delete data.finish; - }); + } ); } -}); +} ); -jQuery.each([ "toggle", "show", "hide" ], function( i, name ) { +jQuery.each( [ "toggle", "show", "hide" ], function( i, name ) { var cssFn = jQuery.fn[ name ]; jQuery.fn[ name ] = function( speed, easing, callback ) { return speed == null || typeof speed === "boolean" ? cssFn.apply( this, arguments ) : this.animate( genFx( name, true ), speed, easing, callback ); }; -}); +} ); // Generate shortcuts for custom animations -jQuery.each({ - slideDown: genFx("show"), - slideUp: genFx("hide"), - slideToggle: genFx("toggle"), +jQuery.each( { + slideDown: genFx( "show" ), + slideUp: genFx( "hide" ), + slideToggle: genFx( "toggle" ), fadeIn: { opacity: "show" }, fadeOut: { opacity: "hide" }, fadeToggle: { opacity: "toggle" } @@ -604,7 +612,7 @@ jQuery.each({ jQuery.fn[ name ] = function( speed, easing, callback ) { return this.animate( props, speed, easing, callback ); }; -}); +} ); jQuery.timers = []; jQuery.fx.tick = function() { @@ -616,6 +624,7 @@ jQuery.fx.tick = function() { for ( ; i < timers.length; i++ ) { timer = timers[ i ]; + // Checks the timer has not already been removed if ( !timer() && timers[ i ] === timer ) { timers.splice( i--, 1 ); @@ -658,9 +667,10 @@ jQuery.fx.stop = function() { jQuery.fx.speeds = { slow: 600, fast: 200, + // Default speed _default: 400 }; return jQuery; -}); +} ); diff --git a/src/effects/Tween.js b/src/effects/Tween.js index 8f9519410..33edf10f3 100644 --- a/src/effects/Tween.js +++ b/src/effects/Tween.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../css" ], function( jQuery ) { @@ -71,10 +71,12 @@ Tween.propHooks = { // so, simple values such as "10px" are parsed to Float. // complex values such as "rotate(1rad)" are returned as is. result = jQuery.css( tween.elem, tween.prop, "" ); + // Empty strings, null, undefined and "auto" are converted to 0. return !result || result === "auto" ? 0 : result; }, set: function( tween ) { + // use step hook for back compat - use cssHook if its there - use .style if its // available and use plain properties where available if ( jQuery.fx.step[ tween.prop ] ) { @@ -116,4 +118,4 @@ jQuery.fx = Tween.prototype.init; // Back Compat <1.8 extension point jQuery.fx.step = {}; -}); +} ); diff --git a/src/effects/animatedSelector.js b/src/effects/animatedSelector.js index bc5a3d6c1..d84c9c703 100644 --- a/src/effects/animatedSelector.js +++ b/src/effects/animatedSelector.js @@ -1,13 +1,13 @@ -define([ +define( [ "../core", "../selector", "../effects" ], function( jQuery ) { jQuery.expr.filters.animated = function( elem ) { - return jQuery.grep(jQuery.timers, function( fn ) { + return jQuery.grep( jQuery.timers, function( fn ) { return elem === fn.elem; - }).length; + } ).length; }; -}); +} ); diff --git a/src/event.js b/src/event.js index f821bbda7..b6c6ff380 100644 --- a/src/event.js +++ b/src/event.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/document", "./var/rnotwhite", @@ -38,8 +38,10 @@ function on( elem, types, selector, data, fn, one ) { // Types can be a map of types/handlers if ( typeof types === "object" ) { + // ( types-Object, selector, data ) if ( typeof selector !== "string" ) { + // ( types-Object, data ) data = data || selector; selector = undefined; @@ -51,15 +53,18 @@ function on( elem, types, selector, data, fn, one ) { } if ( data == null && fn == null ) { + // ( types, fn ) fn = selector; data = selector = undefined; } else if ( fn == null ) { if ( typeof selector === "string" ) { + // ( types, selector, fn ) fn = data; data = undefined; } else { + // ( types, data, fn ) fn = data; data = selector; @@ -73,16 +78,18 @@ function on( elem, types, selector, data, fn, one ) { if ( one === 1 ) { origFn = fn; fn = function( event ) { + // Can use an empty set, since event contains the info jQuery().off( event ); return origFn.apply( this, arguments ); }; + // Use same guid so caller can remove using origFn fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); } return elem.each( function() { jQuery.event.add( this, types, fn, data, selector ); - }); + } ); } /* @@ -117,17 +124,20 @@ jQuery.event = { } // Init the element's event structure and main handler, if this is the first - if ( !(events = elemData.events) ) { + if ( !( events = elemData.events ) ) { events = elemData.events = {}; } - if ( !(eventHandle = elemData.handle) ) { + if ( !( eventHandle = elemData.handle ) ) { eventHandle = elemData.handle = function( e ) { + // Discard the second event of a jQuery.event.trigger() and // when an event is called after a page has unloaded - return typeof jQuery !== "undefined" && (!e || jQuery.event.triggered !== e.type) ? + return typeof jQuery !== "undefined" && + ( !e || jQuery.event.triggered !== e.type ) ? jQuery.event.dispatch.apply( eventHandle.elem, arguments ) : undefined; }; + // Add elem as a property of the handle fn to prevent a memory leak // with IE non-native events eventHandle.elem = elem; @@ -137,9 +147,9 @@ jQuery.event = { types = ( types || "" ).match( rnotwhite ) || [ "" ]; t = types.length; while ( t-- ) { - tmp = rtypenamespace.exec( types[t] ) || []; - type = origType = tmp[1]; - namespaces = ( tmp[2] || "" ).split( "." ).sort(); + tmp = rtypenamespace.exec( types[ t ] ) || []; + type = origType = tmp[ 1 ]; + namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort(); // There *must* be a type, no attaching namespace-only handlers if ( !type ) { @@ -156,7 +166,7 @@ jQuery.event = { special = jQuery.event.special[ type ] || {}; // handleObj is passed to all event handlers - handleObj = jQuery.extend({ + handleObj = jQuery.extend( { type: type, origType: origType, data: data, @@ -164,11 +174,11 @@ jQuery.event = { guid: handler.guid, selector: selector, needsContext: selector && jQuery.expr.match.needsContext.test( selector ), - namespace: namespaces.join(".") + namespace: namespaces.join( "." ) }, handleObjIn ); // Init the event handler queue if we're the first - if ( !(handlers = events[ type ]) ) { + if ( !( handlers = events[ type ] ) ) { handlers = events[ type ] = []; handlers.delegateCount = 0; @@ -217,7 +227,7 @@ jQuery.event = { namespaces, origType, elemData = jQuery.hasData( elem ) && jQuery._data( elem ); - if ( !elemData || !(events = elemData.events) ) { + if ( !elemData || !( events = elemData.events ) ) { return; } @@ -225,9 +235,9 @@ jQuery.event = { types = ( types || "" ).match( rnotwhite ) || [ "" ]; t = types.length; while ( t-- ) { - tmp = rtypenamespace.exec( types[t] ) || []; - type = origType = tmp[1]; - namespaces = ( tmp[2] || "" ).split( "." ).sort(); + tmp = rtypenamespace.exec( types[ t ] ) || []; + type = origType = tmp[ 1 ]; + namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort(); // Unbind all events (on this namespace, if provided) for the element if ( !type ) { @@ -240,7 +250,8 @@ jQuery.event = { special = jQuery.event.special[ type ] || {}; type = ( selector ? special.delegateType : special.bindType ) || type; handlers = events[ type ] || []; - tmp = tmp[2] && new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ); + tmp = tmp[ 2 ] && + new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" ); // Remove matching events origCount = j = handlers.length; @@ -291,7 +302,7 @@ jQuery.event = { bubbleType, special, tmp, i, eventPath = [ elem || document ], type = hasOwn.call( event, "type" ) ? event.type : event, - namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split(".") : []; + namespaces = hasOwn.call( event, "namespace" ) ? event.namespace.split( "." ) : []; cur = tmp = elem = elem || document; @@ -305,13 +316,14 @@ jQuery.event = { return; } - if ( type.indexOf(".") > -1 ) { + if ( type.indexOf( "." ) > -1 ) { + // Namespaced trigger; create a regexp to match event type in handle() - namespaces = type.split("."); + namespaces = type.split( "." ); type = namespaces.shift(); namespaces.sort(); } - ontype = type.indexOf(":") < 0 && "on" + type; + ontype = type.indexOf( ":" ) < 0 && "on" + type; // Caller can pass in a jQuery.Event object, Object, or just an event type string event = event[ jQuery.expando ] ? @@ -320,9 +332,9 @@ jQuery.event = { // Trigger bitmask: & 1 for native handlers; & 2 for jQuery (always true) event.isTrigger = onlyHandlers ? 2 : 3; - event.namespace = namespaces.join("."); + event.namespace = namespaces.join( "." ); event.rnamespace = event.namespace ? - new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ) : + new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" ) : null; // Clean up the event in case it is being reused @@ -356,14 +368,14 @@ jQuery.event = { } // Only add window if we got to document (e.g., not plain obj or detached DOM) - if ( tmp === (elem.ownerDocument || document) ) { + if ( tmp === ( elem.ownerDocument || document ) ) { eventPath.push( tmp.defaultView || tmp.parentWindow || window ); } } // Fire handlers on the event path i = 0; - while ( (cur = eventPath[i++]) && !event.isPropagationStopped() ) { + while ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) { event.type = i > 1 ? bubbleType : @@ -391,8 +403,11 @@ jQuery.event = { // If nobody prevented the default action, do it now if ( !onlyHandlers && !event.isDefaultPrevented() ) { - if ( (!special._default || special._default.apply( eventPath.pop(), data ) === false) && - jQuery.acceptData( elem ) ) { + if ( + ( !special._default || + special._default.apply( eventPath.pop(), data ) === false + ) && jQuery.acceptData( elem ) + ) { // Call a native DOM method on the target with the same name name as the event. // Don't do default actions on window, that's where global variables be (#6170) @@ -412,6 +427,7 @@ jQuery.event = { try { elem[ type ](); } catch ( e ) { + // IE<9 dies on focus/blur to hidden element (#1486,#12518) // only reproducible on winXP IE8 native, not IE9 in IE8 mode } @@ -439,7 +455,7 @@ jQuery.event = { special = jQuery.event.special[ event.type ] || {}; // Use the fix-ed jQuery.Event rather than the (read-only) native event - args[0] = event; + args[ 0 ] = event; event.delegateTarget = this; // Call the preDispatch hook for the mapped type, and let it bail if desired @@ -452,11 +468,11 @@ jQuery.event = { // Run delegates first; they may want to stop propagation beneath us i = 0; - while ( (matched = handlerQueue[ i++ ]) && !event.isPropagationStopped() ) { + while ( ( matched = handlerQueue[ i++ ] ) && !event.isPropagationStopped() ) { event.currentTarget = matched.elem; j = 0; - while ( (handleObj = matched.handlers[ j++ ]) && + while ( ( handleObj = matched.handlers[ j++ ] ) && !event.isImmediatePropagationStopped() ) { // Triggered event must either 1) have no namespace, or 2) have namespace(s) @@ -466,11 +482,11 @@ jQuery.event = { event.handleObj = handleObj; event.data = handleObj.data; - ret = ( (jQuery.event.special[ handleObj.origType ] || {}).handle || + ret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle || handleObj.handler ).apply( matched.elem, args ); if ( ret !== undefined ) { - if ( (event.result = ret) === false ) { + if ( ( event.result = ret ) === false ) { event.preventDefault(); event.stopPropagation(); } @@ -499,7 +515,7 @@ jQuery.event = { // // Support: Firefox // Avoid non-left-click bubbling in Firefox (#3861) - if ( delegateCount && cur.nodeType && (!event.button || event.type !== "click") ) { + if ( delegateCount && cur.nodeType && ( !event.button || event.type !== "click" ) ) { /* jshint eqeqeq: false */ for ( ; cur != this; cur = cur.parentNode || this ) { @@ -507,7 +523,7 @@ jQuery.event = { // Don't check non-elements (#13208) // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) - if ( cur.nodeType === 1 && (cur.disabled !== true || event.type !== "click") ) { + if ( cur.nodeType === 1 && ( cur.disabled !== true || event.type !== "click" ) ) { matches = []; for ( i = 0; i < delegateCount; i++ ) { handleObj = handlers[ i ]; @@ -525,7 +541,7 @@ jQuery.event = { } } if ( matches.length ) { - handlerQueue.push({ elem: cur, handlers: matches }); + handlerQueue.push( { elem: cur, handlers: matches } ); } } } @@ -533,7 +549,7 @@ jQuery.event = { // Add the remaining (directly-bound) handlers if ( delegateCount < handlers.length ) { - handlerQueue.push({ elem: this, handlers: handlers.slice( delegateCount ) }); + handlerQueue.push( { elem: this, handlers: handlers.slice( delegateCount ) } ); } return handlerQueue; @@ -587,12 +603,12 @@ jQuery.event = { // Includes some event props shared by KeyEvent and MouseEvent props: ( "altKey bubbles cancelable ctrlKey currentTarget detail eventPhase " + - "metaKey relatedTarget shiftKey target timeStamp view which" ).split(" "), + "metaKey relatedTarget shiftKey target timeStamp view which" ).split( " " ), fixHooks: {}, keyHooks: { - props: "char charCode key keyCode".split(" "), + props: "char charCode key keyCode".split( " " ), filter: function( event, original ) { // Add which for key events @@ -606,7 +622,7 @@ jQuery.event = { mouseHooks: { props: ( "button buttons clientX clientY fromElement offsetX offsetY " + - "pageX pageY screenX screenY toElement" ).split(" "), + "pageX pageY screenX screenY toElement" ).split( " " ), filter: function( event, original ) { var body, eventDoc, doc, button = original.button, @@ -645,10 +661,12 @@ jQuery.event = { special: { load: { + // Prevent triggered image.load events from bubbling to window.load noBubble: true }, focus: { + // Fire native event if possible so blur/focus sequence is correct trigger: function() { if ( this !== safeActiveElement() && this.focus ) { @@ -656,6 +674,7 @@ jQuery.event = { this.focus(); return false; } catch ( e ) { + // Support: IE<9 // If we error on focus to hidden element (#1486, #12518), // let .trigger() run the handlers @@ -674,6 +693,7 @@ jQuery.event = { delegateType: "focusout" }, click: { + // For checkbox, fire native event so checked state will be right trigger: function() { if ( jQuery.nodeName( this, "input" ) && this.type === "checkbox" && this.click ) { @@ -708,6 +728,7 @@ jQuery.event = { { type: type, isSimulated: true + // Previously, `originalEvent: {}` was set here, so stopPropagation call // would not be triggered on donor event, since in our own // jQuery.event.stopPropagation function we had a check for existence of @@ -752,8 +773,9 @@ jQuery.removeEvent = document.removeEventListener ? }; jQuery.Event = function( src, props ) { + // Allow instantiation without the 'new' keyword - if ( !(this instanceof jQuery.Event) ) { + if ( !( this instanceof jQuery.Event ) ) { return new jQuery.Event( src, props ); } @@ -766,6 +788,7 @@ jQuery.Event = function( src, props ) { // by a handler lower down the tree; reflect the correct value. this.isDefaultPrevented = src.defaultPrevented || src.defaultPrevented === undefined && + // Support: IE < 9, Android < 4.0 src.returnValue === false ? returnTrue : @@ -822,6 +845,7 @@ jQuery.Event.prototype = { if ( !e || this.isSimulated ) { return; } + // If stopPropagation exists, run it on the original event if ( e.stopPropagation ) { e.stopPropagation(); @@ -852,7 +876,7 @@ jQuery.Event.prototype = { // Safari sends mouseenter too often; see: // https://code.google.com/p/chromium/issues/detail?id=470258 // for the description of the bug (it existed in older Chrome versions as well). -jQuery.each({ +jQuery.each( { mouseenter: "mouseover", mouseleave: "mouseout", pointerenter: "pointerover", @@ -870,7 +894,7 @@ jQuery.each({ // For mousenter/leave call the handler if related is outside the target. // NB: No relatedTarget if the mouse left/entered the browser window - if ( !related || (related !== target && !jQuery.contains( target, related )) ) { + if ( !related || ( related !== target && !jQuery.contains( target, related ) ) ) { event.type = handleObj.origType; ret = handleObj.handler.apply( this, arguments ); event.type = fix; @@ -878,13 +902,14 @@ jQuery.each({ return ret; } }; -}); +} ); // IE submit delegation if ( !support.submit ) { jQuery.event.special.submit = { setup: function() { + // Only need this for delegated form submit events if ( jQuery.nodeName( this, "form" ) ) { return false; @@ -892,6 +917,7 @@ if ( !support.submit ) { // Lazy-add a submit handler when a descendant form may potentially be submitted jQuery.event.add( this, "click._submit keypress._submit", function( e ) { + // Node name check avoids a VML-related crash in IE (#9807) var elem = e.target, form = jQuery.nodeName( elem, "input" ) || jQuery.nodeName( elem, "button" ) ? @@ -901,14 +927,16 @@ if ( !support.submit ) { if ( form && !jQuery._data( form, "submit" ) ) { jQuery.event.add( form, "submit._submit", function( event ) { event._submitBubble = true; - }); + } ); jQuery._data( form, "submit", true ); } - }); + } ); + // return undefined since we don't need an event listener }, postDispatch: function( event ) { + // If form was submitted by the user, bubble the event up the tree if ( event._submitBubble ) { delete event._submitBubble; @@ -919,6 +947,7 @@ if ( !support.submit ) { }, teardown: function() { + // Only need this for delegated form submit events if ( jQuery.nodeName( this, "form" ) ) { return false; @@ -938,6 +967,7 @@ if ( !support.change ) { setup: function() { if ( rformElems.test( this.nodeName ) ) { + // IE doesn't fire change on a check/radio until blur; trigger it on click // after a propertychange. Eat the blur-change in special.change.handle. // This still fires onchange a second time for check/radio after blur. @@ -946,17 +976,19 @@ if ( !support.change ) { if ( event.originalEvent.propertyName === "checked" ) { this._justChanged = true; } - }); + } ); jQuery.event.add( this, "click._change", function( event ) { if ( this._justChanged && !event.isTrigger ) { this._justChanged = false; } + // Allow triggered, simulated change events (#11500) jQuery.event.simulate( "change", this, event ); - }); + } ); } return false; } + // Delegated event; lazy-add a change handler on descendant inputs jQuery.event.add( this, "beforeactivate._change", function( e ) { var elem = e.target; @@ -966,10 +998,10 @@ if ( !support.change ) { if ( this.parentNode && !event.isSimulated && !event.isTrigger ) { jQuery.event.simulate( "change", this.parentNode, event ); } - }); + } ); jQuery._data( elem, "change", true ); } - }); + } ); }, handle: function( event ) { @@ -977,7 +1009,7 @@ if ( !support.change ) { // Swallow native change events from checkbox/radio, we already triggered them above if ( this !== elem || event.isSimulated || event.isTrigger || - (elem.type !== "radio" && elem.type !== "checkbox") ) { + ( elem.type !== "radio" && elem.type !== "checkbox" ) ) { return event.handleObj.handler.apply( this, arguments ); } @@ -1000,7 +1032,7 @@ if ( !support.change ) { // which is spec violation - http://www.w3.org/TR/DOM-Level-3-Events/#events-focusevent-event-order // Related ticket - https://code.google.com/p/chromium/issues/detail?id=449857 if ( !support.focusin ) { - jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { + jQuery.each( { focus: "focusin", blur: "focusout" }, function( orig, fix ) { // Attach a single capturing handler on the document while someone wants focusin/focusout var handler = function( event ) { @@ -1029,10 +1061,10 @@ if ( !support.focusin ) { } } }; - }); + } ); } -jQuery.fn.extend({ +jQuery.fn.extend( { on: function( types, selector, data, fn ) { return on( this, types, selector, data, fn ); @@ -1043,6 +1075,7 @@ jQuery.fn.extend({ off: function( types, selector, fn ) { var handleObj, type; if ( types && types.preventDefault && types.handleObj ) { + // ( event ) dispatched jQuery.Event handleObj = types.handleObj; jQuery( types.delegateTarget ).off( @@ -1055,6 +1088,7 @@ jQuery.fn.extend({ return this; } if ( typeof types === "object" ) { + // ( types-object [, selector] ) for ( type in types ) { this.off( type, selector, types[ type ] ); @@ -1062,6 +1096,7 @@ jQuery.fn.extend({ return this; } if ( selector === false || typeof selector === "function" ) { + // ( types [, fn] ) fn = selector; selector = undefined; @@ -1069,23 +1104,23 @@ jQuery.fn.extend({ if ( fn === false ) { fn = returnFalse; } - return this.each(function() { + return this.each( function() { jQuery.event.remove( this, types, fn, selector ); - }); + } ); }, trigger: function( type, data ) { - return this.each(function() { + return this.each( function() { jQuery.event.trigger( type, data, this ); - }); + } ); }, triggerHandler: function( type, data ) { - var elem = this[0]; + var elem = this[ 0 ]; if ( elem ) { return jQuery.event.trigger( type, data, elem, true ); } } -}); +} ); return jQuery; -}); +} ); diff --git a/src/event/ajax.js b/src/event/ajax.js index c808b583e..98e194bf0 100644 --- a/src/event/ajax.js +++ b/src/event/ajax.js @@ -1,10 +1,10 @@ -define([ +define( [ "../core", "../event" ], function( jQuery ) { // Attach a bunch of functions for handling common AJAX events -jQuery.each([ +jQuery.each( [ "ajaxStart", "ajaxStop", "ajaxComplete", @@ -15,6 +15,6 @@ jQuery.each([ jQuery.fn[ type ] = function( fn ) { return this.on( type, fn ); }; -}); +} ); -}); +} ); diff --git a/src/event/alias.js b/src/event/alias.js index eb43537ff..d2bdc5bb8 100644 --- a/src/event/alias.js +++ b/src/event/alias.js @@ -1,11 +1,11 @@ -define([ +define( [ "../core", "../event" ], function( jQuery ) { -jQuery.each( ("blur focus focusin focusout resize scroll click dblclick " + +jQuery.each( ( "blur focus focusin focusout resize scroll click dblclick " + "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " + - "change select submit keydown keypress keyup contextmenu").split(" "), + "change select submit keydown keypress keyup contextmenu" ).split( " " ), function( i, name ) { // Handle event binding @@ -14,9 +14,9 @@ jQuery.each( ("blur focus focusin focusout resize scroll click dblclick " + this.on( name, null, data, fn ) : this.trigger( name ); }; -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { hover: function( fnOver, fnOut ) { return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver ); }, @@ -32,11 +32,12 @@ jQuery.fn.extend({ return this.on( types, selector, data, fn ); }, undelegate: function( selector, types, fn ) { + // ( namespace ) or ( selector, types [, fn] ) return arguments.length === 1 ? this.off( selector, "**" ) : this.off( types, selector || "**", fn ); } -}); +} ); -}); +} ); diff --git a/src/event/support.js b/src/event/support.js index 132575c20..9787f85d1 100644 --- a/src/event/support.js +++ b/src/event/support.js @@ -1,17 +1,18 @@ -define([ +define( [ "../var/document", "../var/support" ], function( document, support ) { -(function() { +( function() { var i, eventName, div = document.createElement( "div" ); // Support: IE<9 (lack submit/change bubble), Firefox (lack focus(in | out) events) - for ( i in { submit: true, change: true, focusin: true }) { + for ( i in { submit: true, change: true, focusin: true } ) { eventName = "on" + i; - if ( !(support[ i ] = eventName in window) ) { + if ( !( support[ i ] = eventName in window ) ) { + // Beware of CSP restrictions (https://developer.mozilla.org/en/Security/CSP) div.setAttribute( eventName, "t" ); support[ i ] = div.attributes[ eventName ].expando === false; @@ -20,8 +21,8 @@ define([ // Null elements to avoid leaks in IE. div = null; -})(); +} )(); return support; -}); +} ); diff --git a/src/exports/amd.js b/src/exports/amd.js index 9a9846f9f..add6eb9bd 100644 --- a/src/exports/amd.js +++ b/src/exports/amd.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core" ], function( jQuery ) { @@ -18,7 +18,7 @@ define([ if ( typeof define === "function" && define.amd ) { define( "jquery", [], function() { return jQuery; - }); + } ); } -}); +} ); diff --git a/src/exports/global.js b/src/exports/global.js index 067516a75..17ac17d53 100644 --- a/src/exports/global.js +++ b/src/exports/global.js @@ -1,4 +1,5 @@ var + // Map over jQuery in case of overwrite _jQuery = window.jQuery, diff --git a/src/jquery.js b/src/jquery.js index 6e646cf42..265385563 100644 --- a/src/jquery.js +++ b/src/jquery.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./selector", "./traversing", @@ -32,6 +32,6 @@ define([ "./exports/amd" ], function( jQuery ) { -return (window.jQuery = window.$ = jQuery); +return ( window.jQuery = window.$ = jQuery ); -}); +} ); diff --git a/src/manipulation.js b/src/manipulation.js index d62d480b7..15ee3caee 100644 --- a/src/manipulation.js +++ b/src/manipulation.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/document", "./var/concat", @@ -32,12 +32,13 @@ var rinlinejQuery = / jQuery\d+="(?:null|\d+)"/g, rnoshimcache = new RegExp( "<(?:" + nodeNames + ")[\\s/>]", "i" ), rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:-]+)[^>]*)\/>/gi, rnoInnerhtml = /<(?:script|style|link)/i, + // checked="checked" or checked rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i, rscriptTypeMasked = /^true\/(.*)/, rcleanScript = /^\s*<!(?:\[CDATA\[|--)|(?:\]\]|--)>\s*$/g, safeFragment = createSafeFragment( document ), - fragmentDiv = safeFragment.appendChild( document.createElement("div") ); + fragmentDiv = safeFragment.appendChild( document.createElement( "div" ) ); // Manipulating tables requires a tbody function manipulationTarget( elem, content ) { @@ -52,15 +53,15 @@ function manipulationTarget( elem, content ) { // Replace/restore the type attribute of script elements for safe DOM manipulation function disableScript( elem ) { - elem.type = (jQuery.find.attr( elem, "type" ) !== null) + "/" + elem.type; + elem.type = ( jQuery.find.attr( elem, "type" ) !== null ) + "/" + elem.type; return elem; } function restoreScript( elem ) { var match = rscriptTypeMasked.exec( elem.type ); if ( match ) { - elem.type = match[1]; + elem.type = match[ 1 ]; } else { - elem.removeAttribute("type"); + elem.removeAttribute( "type" ); } return elem; } @@ -149,20 +150,20 @@ function domManip( collection, args, callback, ignored ) { i = 0, l = collection.length, iNoClone = l - 1, - value = args[0], + value = args[ 0 ], isFunction = jQuery.isFunction( value ); // We can't cloneNode fragments that contain checked, in WebKit if ( isFunction || ( l > 1 && typeof value === "string" && !support.checkClone && rchecked.test( value ) ) ) { - return collection.each(function( index ) { + return collection.each( function( index ) { var self = collection.eq( index ); if ( isFunction ) { - args[0] = value.call( this, index, self.html() ); + args[ 0 ] = value.call( this, index, self.html() ); } domManip( self, args, callback, ignored ); - }); + } ); } if ( l ) { @@ -189,13 +190,14 @@ function domManip( collection, args, callback, ignored ) { // Keep references to cloned scripts for later restoration if ( hasScripts ) { + // Support: Android<4.1, PhantomJS<2 // push.apply(_, arraylike) throws on ancient WebKit jQuery.merge( scripts, getAll( node, "script" ) ); } } - callback.call( collection[i], node, i ); + callback.call( collection[ i ], node, i ); } if ( hasScripts ) { @@ -212,6 +214,7 @@ function domManip( collection, args, callback, ignored ) { jQuery.contains( doc, node ) ) { if ( node.src ) { + // Optional AJAX dependency, but won't run scripts if not present if ( jQuery._evalUrl ) { jQuery._evalUrl( node.src ); @@ -239,7 +242,7 @@ function remove( elem, selector, keepData ) { elems = selector ? jQuery.filter( selector, elem ) : elem, i = 0; - for ( ; (node = elems[i]) != null; i++ ) { + for ( ; ( node = elems[ i ] ) != null; i++ ) { if ( !keepData && node.nodeType === 1 ) { jQuery.cleanData( getAll( node ) ); @@ -256,7 +259,7 @@ function remove( elem, selector, keepData ) { return elem; } -jQuery.extend({ +jQuery.extend( { htmlPrefilter: function( html ) { return html.replace( rxhtmlTag, "<$1></$2>" ); }, @@ -265,7 +268,7 @@ jQuery.extend({ var destElements, node, clone, i, srcElements, inPage = jQuery.contains( elem.ownerDocument, elem ); - if ( support.html5Clone || jQuery.isXMLDoc(elem) || + if ( support.html5Clone || jQuery.isXMLDoc( elem ) || !rnoshimcache.test( "<" + elem.nodeName + ">" ) ) { clone = elem.cloneNode( true ); @@ -276,18 +279,19 @@ jQuery.extend({ fragmentDiv.removeChild( clone = fragmentDiv.firstChild ); } - if ( (!support.noCloneEvent || !support.noCloneChecked) && - (elem.nodeType === 1 || elem.nodeType === 11) && !jQuery.isXMLDoc(elem) ) { + if ( ( !support.noCloneEvent || !support.noCloneChecked ) && + ( elem.nodeType === 1 || elem.nodeType === 11 ) && !jQuery.isXMLDoc( elem ) ) { // We eschew Sizzle here for performance reasons: http://jsperf.com/getall-vs-sizzle/2 destElements = getAll( clone ); srcElements = getAll( elem ); // Fix all IE cloning issues - for ( i = 0; (node = srcElements[i]) != null; ++i ) { + for ( i = 0; ( node = srcElements[ i ] ) != null; ++i ) { + // Ensure that the destination node is not null; Fixes #9587 - if ( destElements[i] ) { - fixCloneNodeIssues( node, destElements[i] ); + if ( destElements[ i ] ) { + fixCloneNodeIssues( node, destElements[ i ] ); } } } @@ -298,8 +302,8 @@ jQuery.extend({ srcElements = srcElements || getAll( elem ); destElements = destElements || getAll( clone ); - for ( i = 0; (node = srcElements[i]) != null; i++ ) { - cloneCopyEvent( node, destElements[i] ); + for ( i = 0; ( node = srcElements[ i ] ) != null; i++ ) { + cloneCopyEvent( node, destElements[ i ] ); } } else { cloneCopyEvent( elem, clone ); @@ -326,7 +330,7 @@ jQuery.extend({ attributes = support.attributes, special = jQuery.event.special; - for ( ; (elem = elems[i]) != null; i++ ) { + for ( ; ( elem = elems[ i ] ) != null; i++ ) { if ( acceptData || jQuery.acceptData( elem ) ) { id = elem[ internalKey ]; @@ -370,9 +374,9 @@ jQuery.extend({ } } } -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { detach: function( selector ) { return remove( this, selector, true ); }, @@ -386,7 +390,7 @@ jQuery.fn.extend({ return value === undefined ? jQuery.text( this ) : this.empty().append( - ( this[0] && this[0].ownerDocument || document ).createTextNode( value ) + ( this[ 0 ] && this[ 0 ].ownerDocument || document ).createTextNode( value ) ); }, null, value, arguments.length ); }, @@ -397,7 +401,7 @@ jQuery.fn.extend({ var target = manipulationTarget( this, elem ); target.appendChild( elem ); } - }); + } ); }, prepend: function() { @@ -406,7 +410,7 @@ jQuery.fn.extend({ var target = manipulationTarget( this, elem ); target.insertBefore( elem, target.firstChild ); } - }); + } ); }, before: function() { @@ -414,7 +418,7 @@ jQuery.fn.extend({ if ( this.parentNode ) { this.parentNode.insertBefore( elem, this ); } - }); + } ); }, after: function() { @@ -422,14 +426,15 @@ jQuery.fn.extend({ if ( this.parentNode ) { this.parentNode.insertBefore( elem, this.nextSibling ); } - }); + } ); }, empty: function() { var elem, i = 0; - for ( ; (elem = this[i]) != null; i++ ) { + for ( ; ( elem = this[ i ] ) != null; i++ ) { + // Remove element nodes and prevent memory leaks if ( elem.nodeType === 1 ) { jQuery.cleanData( getAll( elem, false ) ); @@ -454,9 +459,9 @@ jQuery.fn.extend({ dataAndEvents = dataAndEvents == null ? false : dataAndEvents; deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents; - return this.map(function() { + return this.map( function() { return jQuery.clone( this, dataAndEvents, deepDataAndEvents ); - }); + } ); }, html: function( value ) { @@ -475,14 +480,15 @@ jQuery.fn.extend({ if ( typeof value === "string" && !rnoInnerhtml.test( value ) && ( support.htmlSerialize || !rnoshimcache.test( value ) ) && ( support.leadingWhitespace || !rleadingWhitespace.test( value ) ) && - !wrapMap[ (rtagName.exec( value ) || [ "", "" ])[ 1 ].toLowerCase() ] ) { + !wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) { value = jQuery.htmlPrefilter( value ); try { - for (; i < l; i++ ) { + for ( ; i < l; i++ ) { + // Remove element nodes and prevent memory leaks - elem = this[i] || {}; + elem = this[ i ] || {}; if ( elem.nodeType === 1 ) { jQuery.cleanData( getAll( elem, false ) ); elem.innerHTML = value; @@ -518,9 +524,9 @@ jQuery.fn.extend({ // Force callback invocation }, ignored ); } -}); +} ); -jQuery.each({ +jQuery.each( { appendTo: "append", prependTo: "prepend", insertBefore: "before", @@ -535,8 +541,8 @@ jQuery.each({ last = insert.length - 1; for ( ; i <= last; i++ ) { - elems = i === last ? this : this.clone(true); - jQuery( insert[i] )[ original ]( elems ); + elems = i === last ? this : this.clone( true ); + jQuery( insert[ i ] )[ original ]( elems ); // Support: IE<9, Android<4.1, PhantomJS<2 // .get() because push.apply(_, arraylike) throws on ancient WebKit @@ -545,7 +551,7 @@ jQuery.each({ return this.pushStack( ret ); }; -}); +} ); return jQuery; -}); +} ); diff --git a/src/manipulation/_evalUrl.js b/src/manipulation/_evalUrl.js index 59464bcd9..572fe30c7 100644 --- a/src/manipulation/_evalUrl.js +++ b/src/manipulation/_evalUrl.js @@ -1,9 +1,9 @@ -define([ +define( [ "../ajax" ], function( jQuery ) { jQuery._evalUrl = function( url ) { - return jQuery.ajax({ + return jQuery.ajax( { url: url, // Make this explicit, since user can override this through ajaxSetup (#11264) @@ -13,9 +13,9 @@ jQuery._evalUrl = function( url ) { async: false, global: false, "throws": true - }); + } ); }; return jQuery._evalUrl; -}); +} ); diff --git a/src/manipulation/buildFragment.js b/src/manipulation/buildFragment.js index 2ef165ef7..0e7958f23 100644 --- a/src/manipulation/buildFragment.js +++ b/src/manipulation/buildFragment.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "./var/rtagName", "./var/rscriptType", @@ -38,22 +38,22 @@ function buildFragment( elems, context, scripts, selection, ignored ) { // Convert html into DOM nodes } else { - tmp = tmp || safe.appendChild( context.createElement("div") ); + tmp = tmp || safe.appendChild( context.createElement( "div" ) ); // Deserialize a standard representation - tag = (rtagName.exec( elem ) || [ "", "" ])[ 1 ].toLowerCase(); + tag = ( rtagName.exec( elem ) || [ "", "" ] )[ 1 ].toLowerCase(); wrap = wrapMap[ tag ] || wrapMap._default; tmp.innerHTML = wrap[ 1 ] + jQuery.htmlPrefilter( elem ) + wrap[ 2 ]; // Descend through wrappers to the right content - j = wrap[0]; + j = wrap[ 0 ]; while ( j-- ) { tmp = tmp.lastChild; } // Manually add leading whitespace removed by IE if ( !support.leadingWhitespace && rleadingWhitespace.test( elem ) ) { - nodes.push( context.createTextNode( rleadingWhitespace.exec( elem )[0] ) ); + nodes.push( context.createTextNode( rleadingWhitespace.exec( elem )[ 0 ] ) ); } jQuery.merge( nodes, tmp.childNodes ); @@ -78,7 +78,7 @@ function buildFragment( elems, context, scripts, selection, ignored ) { } i = 0; - while ( (elem = nodes[ i++ ]) ) { + while ( ( elem = nodes[ i++ ] ) ) { // Skip elements already in the context collection (trac-4087) if ( selection && jQuery.inArray( elem, selection ) > -1 ) { @@ -101,7 +101,7 @@ function buildFragment( elems, context, scripts, selection, ignored ) { // Capture executables if ( scripts ) { j = 0; - while ( (elem = tmp[ j++ ]) ) { + while ( ( elem = tmp[ j++ ] ) ) { if ( rscriptType.test( elem.type || "" ) ) { scripts.push( elem ); } @@ -115,4 +115,4 @@ function buildFragment( elems, context, scripts, selection, ignored ) { } return buildFragment; -}); +} ); diff --git a/src/manipulation/createSafeFragment.js b/src/manipulation/createSafeFragment.js index dd12e66fd..5b766d435 100644 --- a/src/manipulation/createSafeFragment.js +++ b/src/manipulation/createSafeFragment.js @@ -1,4 +1,4 @@ -define([ +define( [ "./var/nodeNames" ], function( nodeNames ) { @@ -17,4 +17,4 @@ function createSafeFragment( document ) { } return createSafeFragment; -}); +} ); diff --git a/src/manipulation/getAll.js b/src/manipulation/getAll.js index d9a31830d..d049b798a 100644 --- a/src/manipulation/getAll.js +++ b/src/manipulation/getAll.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core" ], function( jQuery ) { @@ -13,7 +13,7 @@ function getAll( context, tag ) { if ( !found ) { for ( found = [], elems = context.childNodes || context; - ( elem = elems[i] ) != null; + ( elem = elems[ i ] ) != null; i++ ) { if ( !tag || jQuery.nodeName( elem, tag ) ) { @@ -30,4 +30,4 @@ function getAll( context, tag ) { } return getAll; -}); +} ); diff --git a/src/manipulation/setGlobalEval.js b/src/manipulation/setGlobalEval.js index e0c3197c7..277a8e810 100644 --- a/src/manipulation/setGlobalEval.js +++ b/src/manipulation/setGlobalEval.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core" ], function( jQuery ) { @@ -6,14 +6,14 @@ define([ function setGlobalEval( elems, refElements ) { var elem, i = 0; - for ( ; ( elem = elems[i] ) != null; i++ ) { + for ( ; ( elem = elems[ i ] ) != null; i++ ) { jQuery._data( elem, "globalEval", - !refElements || jQuery._data( refElements[i], "globalEval" ) + !refElements || jQuery._data( refElements[ i ], "globalEval" ) ); } } return setGlobalEval; -}); +} ); diff --git a/src/manipulation/support.js b/src/manipulation/support.js index edf162a3f..8feb7aca3 100644 --- a/src/manipulation/support.js +++ b/src/manipulation/support.js @@ -1,10 +1,10 @@ -define([ +define( [ "../core", "../var/document", "../var/support" ], function( jQuery, document, support ) { -(function() { +( function() { var div = document.createElement( "div" ), fragment = document.createDocumentFragment(), input = document.createElement( "input" ); @@ -31,6 +31,7 @@ define([ // #11217 - WebKit loses check when the name is after the checked attribute fragment.appendChild( div ); + // Support: Windows Web Apps (WWA) // `name` and `type` must use .setAttribute for WWA (#14901) input.setAttribute( "type", "radio" ); @@ -52,8 +53,8 @@ define([ // cleanData must set properties to undefined rather than use removeAttribute div[ jQuery.expando ] = 1; support.attributes = !div.getAttribute( jQuery.expando ); -})(); +} )(); return support; -}); +} ); diff --git a/src/manipulation/var/nodeNames.js b/src/manipulation/var/nodeNames.js index 7ef6bb0e5..05bb604f4 100644 --- a/src/manipulation/var/nodeNames.js +++ b/src/manipulation/var/nodeNames.js @@ -1,5 +1,5 @@ -define(function() { +define( function() { return "abbr|article|aside|audio|bdi|canvas|data|datalist|" + "details|dialog|figcaption|figure|footer|header|hgroup|main|" + "mark|meter|nav|output|picture|progress|section|summary|template|time|video"; -}); +} ); diff --git a/src/manipulation/var/rcheckableType.js b/src/manipulation/var/rcheckableType.js index c27a15dc4..4c95394ac 100644 --- a/src/manipulation/var/rcheckableType.js +++ b/src/manipulation/var/rcheckableType.js @@ -1,3 +1,3 @@ -define(function() { - return (/^(?:checkbox|radio)$/i); -}); +define( function() { + return ( /^(?:checkbox|radio)$/i ); +} ); diff --git a/src/manipulation/var/rleadingWhitespace.js b/src/manipulation/var/rleadingWhitespace.js index 210ccb913..96ef95f31 100644 --- a/src/manipulation/var/rleadingWhitespace.js +++ b/src/manipulation/var/rleadingWhitespace.js @@ -1,3 +1,3 @@ -define(function() { +define( function() { return ( /^\s+/ ); -}); +} ); diff --git a/src/manipulation/var/rscriptType.js b/src/manipulation/var/rscriptType.js index 60ef70ac8..0c77c8a58 100644 --- a/src/manipulation/var/rscriptType.js +++ b/src/manipulation/var/rscriptType.js @@ -1,3 +1,3 @@ -define(function() { +define( function() { return ( /^$|\/(?:java|ecma)script/i ); -}); +} ); diff --git a/src/manipulation/var/rtagName.js b/src/manipulation/var/rtagName.js index cd0b768e0..9e542694a 100644 --- a/src/manipulation/var/rtagName.js +++ b/src/manipulation/var/rtagName.js @@ -1,3 +1,3 @@ -define(function() { +define( function() { return ( /<([\w:-]+)/ ); -}); +} ); diff --git a/src/manipulation/wrapMap.js b/src/manipulation/wrapMap.js index 8202e7d93..505e091f8 100644 --- a/src/manipulation/wrapMap.js +++ b/src/manipulation/wrapMap.js @@ -1,4 +1,4 @@ -define([ +define( [ "./support" ], function( support ) { @@ -37,4 +37,4 @@ wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.the wrapMap.th = wrapMap.td; return wrapMap; -}); +} ); diff --git a/src/offset.js b/src/offset.js index 5e5ce7bc7..fe9b44192 100644 --- a/src/offset.js +++ b/src/offset.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./core/access", "./var/document", @@ -45,7 +45,7 @@ jQuery.offset = { curCSSTop = jQuery.css( elem, "top" ); curCSSLeft = jQuery.css( elem, "left" ); calculatePosition = ( position === "absolute" || position === "fixed" ) && - jQuery.inArray("auto", [ curCSSTop, curCSSLeft ] ) > -1; + jQuery.inArray( "auto", [ curCSSTop, curCSSLeft ] ) > -1; // need to be able to calculate position if either top or left // is auto and position is either absolute or fixed @@ -79,15 +79,16 @@ jQuery.offset = { } }; -jQuery.fn.extend({ +jQuery.fn.extend( { offset: function( options ) { + // Preserve chaining for setter if ( arguments.length ) { return options === undefined ? this : - this.each(function( i ) { + this.each( function( i ) { jQuery.offset.setOffset( this, options, i ); - }); + } ); } var docElem, win, rect, doc, @@ -138,9 +139,11 @@ jQuery.fn.extend({ // Fixed elements are offset from window (parentOffset = {top:0, left: 0}, // because it is its only offset parent if ( jQuery.css( elem, "position" ) === "fixed" ) { + // we assume that getBoundingClientRect is available when computed position is fixed offset = elem.getBoundingClientRect(); } else { + // Get *real* offsetParent offsetParent = this.offsetParent(); @@ -163,7 +166,7 @@ jQuery.fn.extend({ // are the same in Safari causing offset.left to incorrectly be 0 return { top: offset.top - parentOffset.top - jQuery.css( elem, "marginTop", true ), - left: offset.left - parentOffset.left - jQuery.css( elem, "marginLeft", true) + left: offset.left - parentOffset.left - jQuery.css( elem, "marginLeft", true ) }; }, @@ -178,7 +181,7 @@ jQuery.fn.extend({ // // This logic, however, is not guaranteed and can change at any point in the future offsetParent: function() { - return this.map(function() { + return this.map( function() { var offsetParent = this.offsetParent; while ( offsetParent && jQuery.css( offsetParent, "position" ) === "static" ) { @@ -186,9 +189,9 @@ jQuery.fn.extend({ } return offsetParent || docElem; - }); + } ); } -}); +} ); // Create scrollLeft and scrollTop methods jQuery.each( { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function( method, prop ) { @@ -199,7 +202,7 @@ jQuery.each( { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function( var win = getWindow( elem ); if ( val === undefined ) { - return win ? (prop in win) ? win[ prop ] : + return win ? ( prop in win ) ? win[ prop ] : win.document.documentElement[ method ] : elem[ method ]; } @@ -215,7 +218,7 @@ jQuery.each( { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function( } }, method, val, arguments.length, null ); }; -}); +} ); // Support: Safari<7-8+, Chrome<37-44+ // Add the top/left cssHooks using jQuery.fn.position @@ -227,6 +230,7 @@ jQuery.each( [ "top", "left" ], function( i, prop ) { function( elem, computed ) { if ( computed ) { computed = curCSS( elem, prop ); + // if curCSS returns percentage, fallback to offset return rnumnonpx.test( computed ) ? jQuery( elem ).position()[ prop ] + "px" : @@ -234,7 +238,7 @@ jQuery.each( [ "top", "left" ], function( i, prop ) { } } ); -}); +} ); return jQuery; -}); +} ); diff --git a/src/queue.js b/src/queue.js index 3cc1dd22d..0e9785460 100644 --- a/src/queue.js +++ b/src/queue.js @@ -1,10 +1,10 @@ -define([ +define( [ "./core", "./deferred", "./callbacks" ], function( jQuery ) { -jQuery.extend({ +jQuery.extend( { queue: function( elem, type, data ) { var queue; @@ -14,8 +14,8 @@ jQuery.extend({ // Speed up dequeue by getting out quickly if this is just a lookup if ( data ) { - if ( !queue || jQuery.isArray(data) ) { - queue = jQuery._data( elem, type, jQuery.makeArray(data) ); + if ( !queue || jQuery.isArray( data ) ) { + queue = jQuery._data( elem, type, jQuery.makeArray( data ) ); } else { queue.push( data ); } @@ -64,15 +64,15 @@ jQuery.extend({ _queueHooks: function( elem, type ) { var key = type + "queueHooks"; return jQuery._data( elem, key ) || jQuery._data( elem, key, { - empty: jQuery.Callbacks("once memory").add(function() { + empty: jQuery.Callbacks( "once memory" ).add( function() { jQuery._removeData( elem, type + "queue" ); jQuery._removeData( elem, key ); - }) - }); + } ) + } ); } -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { queue: function( type, data ) { var setter = 2; @@ -83,30 +83,31 @@ jQuery.fn.extend({ } if ( arguments.length < setter ) { - return jQuery.queue( this[0], type ); + return jQuery.queue( this[ 0 ], type ); } return data === undefined ? this : - this.each(function() { + this.each( function() { var queue = jQuery.queue( this, type, data ); // ensure a hooks for this queue jQuery._queueHooks( this, type ); - if ( type === "fx" && queue[0] !== "inprogress" ) { + if ( type === "fx" && queue[ 0 ] !== "inprogress" ) { jQuery.dequeue( this, type ); } - }); + } ); }, dequeue: function( type ) { - return this.each(function() { + return this.each( function() { jQuery.dequeue( this, type ); - }); + } ); }, clearQueue: function( type ) { return this.queue( type || "fx", [] ); }, + // Get a promise resolved when queues of a certain type // are emptied (fx is the type by default) promise: function( type, obj ) { @@ -137,7 +138,7 @@ jQuery.fn.extend({ resolve(); return defer.promise( obj ); } -}); +} ); return jQuery; -}); +} ); diff --git a/src/queue/delay.js b/src/queue/delay.js index 93abd0bf2..8d5844d6b 100644 --- a/src/queue/delay.js +++ b/src/queue/delay.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../queue", "../effects" // Delay is optional because of this dependency @@ -15,8 +15,8 @@ jQuery.fn.delay = function( time, type ) { hooks.stop = function() { window.clearTimeout( timeout ); }; - }); + } ); }; return jQuery.fn.delay; -}); +} ); diff --git a/src/selector-sizzle.js b/src/selector-sizzle.js index c091f1821..dcee45f37 100644 --- a/src/selector-sizzle.js +++ b/src/selector-sizzle.js @@ -1,14 +1,14 @@ -define([ +define( [ "./core", "sizzle" ], function( jQuery, Sizzle ) { jQuery.find = Sizzle; jQuery.expr = Sizzle.selectors; -jQuery.expr[":"] = jQuery.expr.pseudos; +jQuery.expr[ ":" ] = jQuery.expr.pseudos; jQuery.uniqueSort = jQuery.unique = Sizzle.uniqueSort; jQuery.text = Sizzle.getText; jQuery.isXMLDoc = Sizzle.isXML; jQuery.contains = Sizzle.contains; -}); +} ); diff --git a/src/selector.js b/src/selector.js index ea71c33e6..e13f585ae 100644 --- a/src/selector.js +++ b/src/selector.js @@ -1 +1 @@ -define([ "./selector-sizzle" ], function() {}); +define( [ "./selector-sizzle" ], function() {} ); diff --git a/src/serialize.js b/src/serialize.js index 9b7ffa342..af0f572eb 100644 --- a/src/serialize.js +++ b/src/serialize.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./manipulation/var/rcheckableType", "./core/init", @@ -16,13 +16,16 @@ function buildParams( prefix, obj, traditional, add ) { var name; if ( jQuery.isArray( obj ) ) { + // Serialize array item. jQuery.each( obj, function( i, v ) { if ( traditional || rbracket.test( prefix ) ) { + // Treat each array item as a scalar. add( prefix, v ); } else { + // Item is non-scalar (array or object), encode its numeric index. buildParams( prefix + "[" + ( typeof v === "object" ? i : "" ) + "]", @@ -31,15 +34,17 @@ function buildParams( prefix, obj, traditional, add ) { add ); } - }); + } ); } else if ( !traditional && jQuery.type( obj ) === "object" ) { + // Serialize object item. for ( name in obj ) { buildParams( prefix + "[" + name + "]", obj[ name ], traditional, add ); } } else { + // Serialize scalar item. add( prefix, obj ); } @@ -51,6 +56,7 @@ jQuery.param = function( a, traditional ) { var prefix, s = [], add = function( key, value ) { + // If value is a function, invoke it and return its value value = jQuery.isFunction( value ) ? value() : ( value == null ? "" : value ); s[ s.length ] = encodeURIComponent( key ) + "=" + encodeURIComponent( value ); @@ -63,12 +69,14 @@ jQuery.param = function( a, traditional ) { // If an array was passed in, assume that it is an array of form elements. if ( jQuery.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) { + // Serialize the form elements jQuery.each( a, function() { add( this.name, this.value ); - }); + } ); } else { + // If traditional, encode the "old" way (the way 1.3.2 or older // did it), otherwise encode params recursively. for ( prefix in a ) { @@ -80,24 +88,26 @@ jQuery.param = function( a, traditional ) { return s.join( "&" ).replace( r20, "+" ); }; -jQuery.fn.extend({ +jQuery.fn.extend( { serialize: function() { return jQuery.param( this.serializeArray() ); }, serializeArray: function() { - return this.map(function() { + return this.map( function() { + // Can add propHook for "elements" to filter or add form elements var elements = jQuery.prop( this, "elements" ); return elements ? jQuery.makeArray( elements ) : this; - }) - .filter(function() { + } ) + .filter( function() { var type = this.type; + // Use .is(":disabled") so that fieldset[disabled] works return this.name && !jQuery( this ).is( ":disabled" ) && rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) && ( this.checked || !rcheckableType.test( type ) ); - }) - .map(function( i, elem ) { + } ) + .map( function( i, elem ) { var val = jQuery( this ).val(); return val == null ? @@ -105,11 +115,11 @@ jQuery.fn.extend({ jQuery.isArray( val ) ? jQuery.map( val, function( val ) { return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; - }) : + } ) : { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; - }).get(); + } ).get(); } -}); +} ); return jQuery; -}); +} ); diff --git a/src/support.js b/src/support.js index f04de4952..97b3587da 100644 --- a/src/support.js +++ b/src/support.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./var/support", "./core/init", // Needed for hasOwn support test @@ -16,4 +16,4 @@ support.ownFirst = i === "0"; // Note: most support tests are defined in their respective modules. -}); +} ); diff --git a/src/traversing.js b/src/traversing.js index c427792c1..ad041821b 100644 --- a/src/traversing.js +++ b/src/traversing.js @@ -1,4 +1,4 @@ -define([ +define( [ "./core", "./traversing/var/rneedsContext", "./core/init", @@ -7,6 +7,7 @@ define([ ], function( jQuery, rneedsContext ) { var rparentsprev = /^(?:parents|prev(?:Until|All))/, + // methods guaranteed to produce a unique set when starting from a unique set guaranteedUnique = { children: true, @@ -15,18 +16,18 @@ var rparentsprev = /^(?:parents|prev(?:Until|All))/, prev: true }; -jQuery.extend({ +jQuery.extend( { dir: function( elem, dir, until ) { var matched = [], cur = elem[ dir ]; while ( cur && cur.nodeType !== 9 && - (until === undefined || cur.nodeType !== 1 || !jQuery( cur ).is( until )) ) { + ( until === undefined || cur.nodeType !== 1 || !jQuery( cur ).is( until ) ) ) { if ( cur.nodeType === 1 ) { matched.push( cur ); } - cur = cur[dir]; + cur = cur[ dir ]; } return matched; }, @@ -42,21 +43,21 @@ jQuery.extend({ return r; } -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { has: function( target ) { var i, targets = jQuery( target, this ), len = targets.length; - return this.filter(function() { + return this.filter( function() { for ( i = 0; i < len; i++ ) { - if ( jQuery.contains( this, targets[i] ) ) { + if ( jQuery.contains( this, targets[ i ] ) ) { return true; } } - }); + } ); }, closest: function( selectors, context ) { @@ -69,14 +70,15 @@ jQuery.fn.extend({ 0; for ( ; i < l; i++ ) { - for ( cur = this[i]; cur && cur !== context; cur = cur.parentNode ) { + for ( cur = this[ i ]; cur && cur !== context; cur = cur.parentNode ) { + // Always skip document fragments - if ( cur.nodeType < 11 && (pos ? - pos.index(cur) > -1 : + if ( cur.nodeType < 11 && ( pos ? + pos.index( cur ) > -1 : // Don't pass non-elements to Sizzle cur.nodeType === 1 && - jQuery.find.matchesSelector(cur, selectors)) ) { + jQuery.find.matchesSelector( cur, selectors ) ) ) { matched.push( cur ); break; @@ -93,18 +95,19 @@ jQuery.fn.extend({ // No argument, return index in parent if ( !elem ) { - return ( this[0] && this[0].parentNode ) ? this.first().prevAll().length : -1; + return ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1; } // index in selector if ( typeof elem === "string" ) { - return jQuery.inArray( this[0], jQuery( elem ) ); + return jQuery.inArray( this[ 0 ], jQuery( elem ) ); } // Locate the position of the desired element return jQuery.inArray( + // If it receives a jQuery object, the first element is used - elem.jquery ? elem[0] : elem, this ); + elem.jquery ? elem[ 0 ] : elem, this ); }, add: function( selector, context ) { @@ -117,10 +120,10 @@ jQuery.fn.extend({ addBack: function( selector ) { return this.add( selector == null ? - this.prevObject : this.prevObject.filter(selector) + this.prevObject : this.prevObject.filter( selector ) ); } -}); +} ); function sibling( cur, dir ) { do { @@ -130,7 +133,7 @@ function sibling( cur, dir ) { return cur; } -jQuery.each({ +jQuery.each( { parent: function( elem ) { var parent = elem.parentNode; return parent && parent.nodeType !== 11 ? parent : null; @@ -181,6 +184,7 @@ jQuery.each({ } if ( this.length > 1 ) { + // Remove duplicates if ( !guaranteedUnique[ name ] ) { ret = jQuery.uniqueSort( ret ); @@ -194,7 +198,7 @@ jQuery.each({ return this.pushStack( ret ); }; -}); +} ); return jQuery; -}); +} ); diff --git a/src/traversing/findFilter.js b/src/traversing/findFilter.js index 0039b95b0..fcb763034 100644 --- a/src/traversing/findFilter.js +++ b/src/traversing/findFilter.js @@ -1,4 +1,4 @@ -define([ +define( [ "../core", "../var/indexOf", "./var/rneedsContext", @@ -13,14 +13,14 @@ function winnow( elements, qualifier, not ) { return jQuery.grep( elements, function( elem, i ) { /* jshint -W018 */ return !!qualifier.call( elem, i, elem ) !== not; - }); + } ); } if ( qualifier.nodeType ) { return jQuery.grep( elements, function( elem ) { return ( elem === qualifier ) !== not; - }); + } ); } @@ -34,7 +34,7 @@ function winnow( elements, qualifier, not ) { return jQuery.grep( elements, function( elem ) { return ( jQuery.inArray( elem, qualifier ) > -1 ) !== not; - }); + } ); } jQuery.filter = function( expr, elems, not ) { @@ -48,10 +48,10 @@ jQuery.filter = function( expr, elems, not ) { jQuery.find.matchesSelector( elem, expr ) ? [ elem ] : [] : jQuery.find.matches( expr, jQuery.grep( elems, function( elem ) { return elem.nodeType === 1; - })); + } ) ); }; -jQuery.fn.extend({ +jQuery.fn.extend( { find: function( selector ) { var i, ret = [], @@ -59,13 +59,13 @@ jQuery.fn.extend({ len = self.length; if ( typeof selector !== "string" ) { - return this.pushStack( jQuery( selector ).filter(function() { + return this.pushStack( jQuery( selector ).filter( function() { for ( i = 0; i < len; i++ ) { if ( jQuery.contains( self[ i ], this ) ) { return true; } } - }) ); + } ) ); } for ( i = 0; i < len; i++ ) { @@ -75,10 +75,10 @@ jQuery.fn.extend({ return this.pushStack( len > 1 ? jQuery.uniqueSort( ret ) : ret ); }, filter: function( selector ) { - return this.pushStack( winnow(this, selector || [], false) ); + return this.pushStack( winnow( this, selector || [], false ) ); }, not: function( selector ) { - return this.pushStack( winnow(this, selector || [], true) ); + return this.pushStack( winnow( this, selector || [], true ) ); }, is: function( selector ) { return !!winnow( @@ -92,6 +92,6 @@ jQuery.fn.extend({ false ).length; } -}); +} ); -}); +} ); diff --git a/src/traversing/var/rneedsContext.js b/src/traversing/var/rneedsContext.js index 3d6ae4038..f57fd9de2 100644 --- a/src/traversing/var/rneedsContext.js +++ b/src/traversing/var/rneedsContext.js @@ -1,6 +1,6 @@ -define([ +define( [ "../../core", "../../selector" ], function( jQuery ) { return jQuery.expr.match.needsContext; -}); +} ); diff --git a/src/var/class2type.js b/src/var/class2type.js index e674c3ba6..3a6932e11 100644 --- a/src/var/class2type.js +++ b/src/var/class2type.js @@ -1,4 +1,5 @@ -define(function() { +define( function() { + // [[Class]] -> type pairs return {}; -}); +} ); diff --git a/src/var/concat.js b/src/var/concat.js index 8606ea34c..e6485639e 100644 --- a/src/var/concat.js +++ b/src/var/concat.js @@ -1,5 +1,5 @@ -define([ +define( [ "./deletedIds" ], function( deletedIds ) { return deletedIds.concat; -}); +} ); diff --git a/src/var/deletedIds.js b/src/var/deletedIds.js index b18fc9ce0..3fd364000 100644 --- a/src/var/deletedIds.js +++ b/src/var/deletedIds.js @@ -1,3 +1,3 @@ -define(function() { +define( function() { return []; -}); +} ); diff --git a/src/var/document.js b/src/var/document.js index ded014f1a..bb9428484 100644 --- a/src/var/document.js +++ b/src/var/document.js @@ -1,3 +1,3 @@ -define(function() { +define( function() { return window.document; -}); +} ); diff --git a/src/var/documentElement.js b/src/var/documentElement.js index c639670f1..e0c0aea6b 100644 --- a/src/var/documentElement.js +++ b/src/var/documentElement.js @@ -1,5 +1,5 @@ -define([ +define( [ "./document" ], function( document ) { return document.documentElement; -}); +} ); diff --git a/src/var/hasOwn.js b/src/var/hasOwn.js index 32c002aff..92f323e04 100644 --- a/src/var/hasOwn.js +++ b/src/var/hasOwn.js @@ -1,5 +1,5 @@ -define([ +define( [ "./class2type" ], function( class2type ) { return class2type.hasOwnProperty; -}); +} ); diff --git a/src/var/indexOf.js b/src/var/indexOf.js index fafddd437..4b440b6d3 100644 --- a/src/var/indexOf.js +++ b/src/var/indexOf.js @@ -1,5 +1,5 @@ -define([ +define( [ "./deletedIds" ], function( deletedIds ) { return deletedIds.indexOf; -}); +} ); diff --git a/src/var/pnum.js b/src/var/pnum.js index 407044724..7fd9f6677 100644 --- a/src/var/pnum.js +++ b/src/var/pnum.js @@ -1,3 +1,3 @@ -define(function() { - return (/[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/).source; -}); +define( function() { + return ( /[+-]?(?:\d*\.|)\d+(?:[eE][+-]?\d+|)/ ).source; +} ); diff --git a/src/var/push.js b/src/var/push.js index cc1e105bf..881590b2e 100644 --- a/src/var/push.js +++ b/src/var/push.js @@ -1,5 +1,5 @@ -define([ +define( [ "./deletedIds" ], function( deletedIds ) { return deletedIds.push; -}); +} ); diff --git a/src/var/rcssNum.js b/src/var/rcssNum.js index 2fc3938a5..408f5e26d 100644 --- a/src/var/rcssNum.js +++ b/src/var/rcssNum.js @@ -1,7 +1,7 @@ -define([ +define( [ "../var/pnum" ], function( pnum ) { return new RegExp( "^(?:([+-])=|)(" + pnum + ")([a-z%]*)$", "i" ); -}); +} ); diff --git a/src/var/rnotwhite.js b/src/var/rnotwhite.js index 7c69bec53..6067728ee 100644 --- a/src/var/rnotwhite.js +++ b/src/var/rnotwhite.js @@ -1,3 +1,3 @@ -define(function() { - return (/\S+/g); -}); +define( function() { + return ( /\S+/g ); +} ); diff --git a/src/var/slice.js b/src/var/slice.js index d47618a8d..4e3e979ec 100644 --- a/src/var/slice.js +++ b/src/var/slice.js @@ -1,5 +1,5 @@ -define([ +define( [ "./deletedIds" ], function( deletedIds ) { return deletedIds.slice; -}); +} ); diff --git a/src/var/support.js b/src/var/support.js index b25dbc74b..3db9b67bc 100644 --- a/src/var/support.js +++ b/src/var/support.js @@ -1,4 +1,5 @@ -define(function() { +define( function() { + // All support tests are defined in their respective modules. return {}; -}); +} ); diff --git a/src/var/toString.js b/src/var/toString.js index ca92d2222..80ac7f13f 100644 --- a/src/var/toString.js +++ b/src/var/toString.js @@ -1,5 +1,5 @@ -define([ +define( [ "./class2type" ], function( class2type ) { return class2type.toString; -}); +} ); diff --git a/src/wrap.js b/src/wrap.js index acab1ae95..e2e28746c 100644 --- a/src/wrap.js +++ b/src/wrap.js @@ -1,11 +1,11 @@ -define([ +define( [ "./core", "./core/init", "./manipulation", // clone "./traversing" // parent, contents ], function( jQuery ) { -jQuery.fn.extend({ +jQuery.fn.extend( { wrapAll: function( html ) { var wrap; @@ -21,7 +21,7 @@ jQuery.fn.extend({ wrap.insertBefore( this[ 0 ] ); } - wrap.map(function() { + wrap.map( function() { var elem = this; while ( elem.firstChild && elem.firstChild.nodeType === 1 ) { @@ -29,7 +29,7 @@ jQuery.fn.extend({ } return elem; - }).append( this ); + } ).append( this ); } return this; @@ -37,12 +37,12 @@ jQuery.fn.extend({ wrapInner: function( html ) { if ( jQuery.isFunction( html ) ) { - return this.each(function(i) { - jQuery(this).wrapInner( html.call(this, i) ); - }); + return this.each( function( i ) { + jQuery( this ).wrapInner( html.call( this, i ) ); + } ); } - return this.each(function() { + return this.each( function() { var self = jQuery( this ), contents = self.contents(); @@ -52,24 +52,24 @@ jQuery.fn.extend({ } else { self.append( html ); } - }); + } ); }, wrap: function( html ) { var isFunction = jQuery.isFunction( html ); - return this.each(function(i) { - jQuery( this ).wrapAll( isFunction ? html.call(this, i) : html ); - }); + return this.each( function( i ) { + jQuery( this ).wrapAll( isFunction ? html.call( this, i ) : html ); + } ); }, unwrap: function( selector ) { - this.parent( selector ).not( "body" ).each(function() { + this.parent( selector ).not( "body" ).each( function() { jQuery( this ).replaceWith( this.childNodes ); - }); + } ); return this; } -}); +} ); return jQuery; -}); +} ); diff --git a/test/data/jquery-1.9.1.js b/test/data/jquery-1.9.1.js index e2c203fe9..80c97a226 100644 --- a/test/data/jquery-1.9.1.js +++ b/test/data/jquery-1.9.1.js @@ -11,7 +11,7 @@ * * Date: 2013-2-4 */ -(function( window, undefined ) { +( function( window, undefined ) { // Can't do this because several apps including ASP.NET trace // the stack via arguments.caller.callee and Firefox dies if @@ -19,6 +19,7 @@ // Support: Firefox 18+ //"use strict"; var + // The deferred used on DOM ready readyList, @@ -58,6 +59,7 @@ var // Define a local copy of jQuery jQuery = function( selector, context ) { + // The jQuery object is actually just the init constructor 'enhanced' return new jQuery.fn.init( selector, context, rootjQuery ); }, @@ -103,6 +105,7 @@ var jQuery.ready(); } }, + // Clean-up method for dom ready events detach = function() { if ( document.addEventListener ) { @@ -116,6 +119,7 @@ var }; jQuery.fn = jQuery.prototype = { + // The current version of jQuery being used jquery: core_version, @@ -130,7 +134,8 @@ jQuery.fn = jQuery.prototype = { // Handle HTML strings if ( typeof selector === "string" ) { - if ( selector.charAt(0) === "<" && selector.charAt( selector.length - 1 ) === ">" && selector.length >= 3 ) { + if ( selector.charAt( 0 ) === "<" && selector.charAt( selector.length - 1 ) === ">" && selector.length >= 3 ) { + // Assume that strings that start and end with <> are HTML and skip the regex check match = [ null, selector, null ]; @@ -139,22 +144,23 @@ jQuery.fn = jQuery.prototype = { } // Match html or make sure no context is specified for #id - if ( match && (match[1] || !context) ) { + if ( match && ( match[ 1 ] || !context ) ) { // HANDLE: $(html) -> $(array) - if ( match[1] ) { - context = context instanceof jQuery ? context[0] : context; + if ( match[ 1 ] ) { + context = context instanceof jQuery ? context[ 0 ] : context; // scripts is true for back-compat jQuery.merge( this, jQuery.parseHTML( - match[1], + match[ 1 ], context && context.nodeType ? context.ownerDocument || context : document, true ) ); // HANDLE: $(html, props) - if ( rsingleTag.test( match[1] ) && jQuery.isPlainObject( context ) ) { + if ( rsingleTag.test( match[ 1 ] ) && jQuery.isPlainObject( context ) ) { for ( match in context ) { + // Properties of context are called as methods if possible if ( jQuery.isFunction( this[ match ] ) ) { this[ match ]( context[ match ] ); @@ -170,20 +176,21 @@ jQuery.fn = jQuery.prototype = { // HANDLE: $(#id) } else { - elem = document.getElementById( match[2] ); + elem = document.getElementById( match[ 2 ] ); // Check parentNode to catch when Blackberry 4.6 returns // nodes that are no longer in the document #6963 if ( elem && elem.parentNode ) { + // Handle the case where IE and Opera return items // by name instead of ID - if ( elem.id !== match[2] ) { + if ( elem.id !== match[ 2 ] ) { return rootjQuery.find( selector ); } // Otherwise, we inject the element directly into the jQuery object this.length = 1; - this[0] = elem; + this[ 0 ] = elem; } this.context = document; @@ -203,7 +210,7 @@ jQuery.fn = jQuery.prototype = { // HANDLE: $(DOMElement) } else if ( selector.nodeType ) { - this.context = this[0] = selector; + this.context = this[ 0 ] = selector; this.length = 1; return this; @@ -271,6 +278,7 @@ jQuery.fn = jQuery.prototype = { }, ready: function( fn ) { + // Add the callback jQuery.ready.promise().done( fn ); @@ -292,17 +300,17 @@ jQuery.fn = jQuery.prototype = { eq: function( i ) { var len = this.length, j = +i + ( i < 0 ? len : 0 ); - return this.pushStack( j >= 0 && j < len ? [ this[j] ] : [] ); + return this.pushStack( j >= 0 && j < len ? [ this[ j ] ] : [] ); }, map: function( callback ) { - return this.pushStack( jQuery.map(this, function( elem, i ) { + return this.pushStack( jQuery.map( this, function( elem, i ) { return callback.call( elem, i, elem ); - })); + } ) ); }, end: function() { - return this.prevObject || this.constructor(null); + return this.prevObject || this.constructor( null ); }, // For internal use only. @@ -317,7 +325,7 @@ jQuery.fn.init.prototype = jQuery.fn; jQuery.extend = jQuery.fn.extend = function() { var src, copyIsArray, copy, name, options, clone, - target = arguments[0] || {}, + target = arguments[ 0 ] || {}, i = 1, length = arguments.length, deep = false; @@ -325,13 +333,14 @@ jQuery.extend = jQuery.fn.extend = function() { // Handle a deep copy situation if ( typeof target === "boolean" ) { deep = target; - target = arguments[1] || {}; + target = arguments[ 1 ] || {}; + // skip the boolean and the target i = 2; } // Handle case when target is a string or something (possible in deep copy) - if ( typeof target !== "object" && !jQuery.isFunction(target) ) { + if ( typeof target !== "object" && !jQuery.isFunction( target ) ) { target = {}; } @@ -342,8 +351,10 @@ jQuery.extend = jQuery.fn.extend = function() { } for ( ; i < length; i++ ) { + // Only deal with non-null/undefined values - if ( (options = arguments[ i ]) != null ) { + if ( ( options = arguments[ i ] ) != null ) { + // Extend the base object for ( name in options ) { src = target[ name ]; @@ -355,13 +366,13 @@ jQuery.extend = jQuery.fn.extend = function() { } // Recurse if we're merging plain objects or arrays - if ( deep && copy && ( jQuery.isPlainObject(copy) || (copyIsArray = jQuery.isArray(copy)) ) ) { + if ( deep && copy && ( jQuery.isPlainObject( copy ) || ( copyIsArray = jQuery.isArray( copy ) ) ) ) { if ( copyIsArray ) { copyIsArray = false; - clone = src && jQuery.isArray(src) ? src : []; + clone = src && jQuery.isArray( src ) ? src : []; } else { - clone = src && jQuery.isPlainObject(src) ? src : {}; + clone = src && jQuery.isPlainObject( src ) ? src : {}; } // Never move original objects, clone them @@ -379,7 +390,7 @@ jQuery.extend = jQuery.fn.extend = function() { return target; }; -jQuery.extend({ +jQuery.extend( { noConflict: function( deep ) { if ( window.$ === jQuery ) { window.$ = _$; @@ -434,7 +445,7 @@ jQuery.extend({ // Trigger any bound ready events if ( jQuery.fn.trigger ) { - jQuery( document ).trigger("ready").off("ready"); + jQuery( document ).trigger( "ready" ).off( "ready" ); } }, @@ -442,11 +453,11 @@ jQuery.extend({ // Since version 1.3, DOM methods and functions like alert // aren't supported. They return false on IE (#2968). isFunction: function( obj ) { - return jQuery.type(obj) === "function"; + return jQuery.type( obj ) === "function"; }, isArray: Array.isArray || function( obj ) { - return jQuery.type(obj) === "array"; + return jQuery.type( obj ) === "array"; }, isWindow: function( obj ) { @@ -454,7 +465,7 @@ jQuery.extend({ }, isNumeric: function( obj ) { - return !isNaN( parseFloat(obj) ) && isFinite( obj ); + return !isNaN( parseFloat( obj ) ) && isFinite( obj ); }, type: function( obj ) { @@ -462,26 +473,29 @@ jQuery.extend({ return String( obj ); } return typeof obj === "object" || typeof obj === "function" ? - class2type[ core_toString.call(obj) ] || "object" : + class2type[ core_toString.call( obj ) ] || "object" : typeof obj; }, isPlainObject: function( obj ) { + // Must be an Object. // Because of IE, we also have to check the presence of the constructor property. // Make sure that DOM nodes and window objects don't pass through, as well - if ( !obj || jQuery.type(obj) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) { + if ( !obj || jQuery.type( obj ) !== "object" || obj.nodeType || jQuery.isWindow( obj ) ) { return false; } try { + // Not own constructor property must be Object if ( obj.constructor && - !core_hasOwn.call(obj, "constructor") && - !core_hasOwn.call(obj.constructor.prototype, "isPrototypeOf") ) { + !core_hasOwn.call( obj, "constructor" ) && + !core_hasOwn.call( obj.constructor.prototype, "isPrototypeOf" ) ) { return false; } } catch ( e ) { + // IE8,9 Will throw exceptions on certain host objects #9897 return false; } @@ -525,7 +539,7 @@ jQuery.extend({ // Single tag if ( parsed ) { - return [ context.createElement( parsed[1] ) ]; + return [ context.createElement( parsed[ 1 ] ) ]; } parsed = jQuery.buildFragment( [ data ], context, scripts ); @@ -536,6 +550,7 @@ jQuery.extend({ }, parseJSON: function( data ) { + // Attempt to parse using the native JSON parser first if ( window.JSON && window.JSON.parse ) { return window.JSON.parse( data ); @@ -551,11 +566,12 @@ jQuery.extend({ data = jQuery.trim( data ); if ( data ) { + // Make sure the incoming data is actual JSON // Logic borrowed from http://json.org/json2.js if ( rvalidchars.test( data.replace( rvalidescape, "@" ) .replace( rvalidtokens, "]" ) - .replace( rvalidbraces, "")) ) { + .replace( rvalidbraces, "" ) ) ) { return ( new Function( "return " + data ) )(); } @@ -574,13 +590,13 @@ jQuery.extend({ try { if ( window.DOMParser ) { // Standard tmp = new DOMParser(); - xml = tmp.parseFromString( data , "text/xml" ); + xml = tmp.parseFromString( data, "text/xml" ); } else { // IE xml = new ActiveXObject( "Microsoft.XMLDOM" ); xml.async = "false"; xml.loadXML( data ); } - } catch( e ) { + } catch ( e ) { xml = undefined; } if ( !xml || !xml.documentElement || xml.getElementsByTagName( "parsererror" ).length ) { @@ -596,6 +612,7 @@ jQuery.extend({ // http://weblogs.java.net/blog/driscoll/archive/2009/09/08/eval-javascript-global-context globalEval: function( data ) { if ( data && jQuery.trim( data ) ) { + // We use execScript on Internet Explorer // We use an anonymous function so that context is window // rather than jQuery in Firefox @@ -666,7 +683,7 @@ jQuery.extend({ }, // Use native String.trim function wherever possible - trim: core_trim && !core_trim.call("\uFEFF\xA0") ? + trim: core_trim && !core_trim.call( "\uFEFF\xA0" ) ? function( text ) { return text == null ? "" : @@ -685,7 +702,7 @@ jQuery.extend({ var ret = results || []; if ( arr != null ) { - if ( isArraylike( Object(arr) ) ) { + if ( isArraylike( Object( arr ) ) ) { jQuery.merge( ret, typeof arr === "string" ? [ arr ] : arr @@ -710,6 +727,7 @@ jQuery.extend({ i = i ? i < 0 ? Math.max( 0, len + i ) : i : 0; for ( ; i < len; i++ ) { + // Skip accessing in sparse arrays if ( i in arr && arr[ i ] === elem ) { return i; @@ -730,7 +748,7 @@ jQuery.extend({ first[ i++ ] = second[ j ]; } } else { - while ( second[j] !== undefined ) { + while ( second[ j ] !== undefined ) { first[ i++ ] = second[ j++ ]; } } @@ -835,7 +853,7 @@ jQuery.extend({ if ( jQuery.type( key ) === "object" ) { chainable = true; for ( i in key ) { - jQuery.access( elems, fn, i, key[i], true, emptyGet, raw ); + jQuery.access( elems, fn, i, key[ i ], true, emptyGet, raw ); } // Sets one value @@ -847,6 +865,7 @@ jQuery.extend({ } if ( bulk ) { + // Bulk operations run against the entire set if ( raw ) { fn.call( elems, value ); @@ -863,7 +882,7 @@ jQuery.extend({ if ( fn ) { for ( ; i < length; i++ ) { - fn( elems[i], key, raw ? value : value.call( elems[i], i, fn( elems[i], key ) ) ); + fn( elems[ i ], key, raw ? value : value.call( elems[ i ], i, fn( elems[ i ], key ) ) ); } } } @@ -874,13 +893,13 @@ jQuery.extend({ // Gets bulk ? fn.call( elems ) : - length ? fn( elems[0], key ) : emptyGet; + length ? fn( elems[ 0 ], key ) : emptyGet; }, now: function() { return ( new Date() ).getTime(); } -}); +} ); jQuery.ready.promise = function( obj ) { if ( !readyList ) { @@ -891,11 +910,13 @@ jQuery.ready.promise = function( obj ) { // we once tried to use readyState "interactive" here, but it caused issues like the one // discovered by ChrisS here: http://bugs.jquery.com/ticket/12282#comment:15 if ( document.readyState === "complete" ) { + // Handle it asynchronously to allow scripts the opportunity to delay ready setTimeout( jQuery.ready ); // Standards-based browsers support DOMContentLoaded } else if ( document.addEventListener ) { + // Use the handy event callback document.addEventListener( "DOMContentLoaded", completed, false ); @@ -904,6 +925,7 @@ jQuery.ready.promise = function( obj ) { // If IE event model is used } else { + // Ensure firing before onload, maybe late but safe also for iframes document.attachEvent( "onreadystatechange", completed ); @@ -916,17 +938,18 @@ jQuery.ready.promise = function( obj ) { try { top = window.frameElement == null && document.documentElement; - } catch(e) {} + } catch ( e ) {} if ( top && top.doScroll ) { - (function doScrollCheck() { + ( function doScrollCheck() { if ( !jQuery.isReady ) { try { + // Use the trick by Diego Perini // http://javascript.nwbox.com/IEContentLoaded/ - top.doScroll("left"); - } catch(e) { + top.doScroll( "left" ); + } catch ( e ) { return setTimeout( doScrollCheck, 50 ); } @@ -936,7 +959,7 @@ jQuery.ready.promise = function( obj ) { // and execute any waiting functions jQuery.ready(); } - })(); + } )(); } } } @@ -944,9 +967,9 @@ jQuery.ready.promise = function( obj ) { }; // Populate the class2type map -jQuery.each("Boolean Number String Function Array Date RegExp Object Error".split(" "), function(i, name) { +jQuery.each( "Boolean Number String Function Array Date RegExp Object Error".split( " " ), function( i, name ) { class2type[ "[object " + name + "]" ] = name.toLowerCase(); -}); +} ); function isArraylike( obj ) { var length = obj.length, @@ -966,7 +989,8 @@ function isArraylike( obj ) { } // All jQuery objects should point back to these -rootjQuery = jQuery(document); +rootjQuery = jQuery( document ); + // String to Object options format cache var optionsCache = {}; @@ -975,7 +999,7 @@ function createOptions( options ) { var object = optionsCache[ options ] = {}; jQuery.each( options.match( core_rnotwhite ) || [], function( _, flag ) { object[ flag ] = true; - }); + } ); return object; } @@ -1011,20 +1035,28 @@ jQuery.Callbacks = function( options ) { var // Flag to know if list is currently firing firing, + // Last fire value (for non-forgettable lists) memory, + // Flag to know if list was already fired fired, + // End of the loop when firing firingLength, + // Index of currently firing callback (modified by remove if needed) firingIndex, + // First callback to fire (used internally by add and fireWith) firingStart, + // Actual callback list list = [], + // Stack of fire calls for repeatable lists stack = !options.once && [], + // Fire callbacks fire = function( data ) { memory = options.memory && data; @@ -1052,14 +1084,17 @@ jQuery.Callbacks = function( options ) { } } }, + // Actual Callbacks object self = { + // Add a callback or a collection of callbacks to the list add: function() { if ( list ) { + // First, we save the current length var start = list.length; - (function add( args ) { + ( function add( args ) { jQuery.each( args, function( _, arg ) { var type = jQuery.type( arg ); if ( type === "function" ) { @@ -1067,15 +1102,18 @@ jQuery.Callbacks = function( options ) { list.push( arg ); } } else if ( arg && arg.length && type !== "string" ) { + // Inspect recursively add( arg ); } - }); - })( arguments ); + } ); + } )( arguments ); + // Do we need to add the callbacks to the // current firing batch? if ( firing ) { firingLength = list.length; + // With memory, if we're not firing then // we should call right away } else if ( memory ) { @@ -1085,13 +1123,15 @@ jQuery.Callbacks = function( options ) { } return this; }, + // Remove a callback from the list remove: function() { if ( list ) { jQuery.each( arguments, function( _, arg ) { var index; - while( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { + while ( ( index = jQuery.inArray( arg, list, index ) ) > -1 ) { list.splice( index, 1 ); + // Handle firing indexes if ( firing ) { if ( index <= firingLength ) { @@ -1102,29 +1142,34 @@ jQuery.Callbacks = function( options ) { } } } - }); + } ); } return this; }, + // Check if a given callback is in the list. // If no argument is given, return whether or not list has callbacks attached. has: function( fn ) { return fn ? jQuery.inArray( fn, list ) > -1 : !!( list && list.length ); }, + // Remove all callbacks from the list empty: function() { list = []; return this; }, + // Have the list do nothing anymore disable: function() { list = stack = memory = undefined; return this; }, + // Is it disabled? disabled: function() { return !list; }, + // Lock the list in its current state lock: function() { stack = undefined; @@ -1133,10 +1178,12 @@ jQuery.Callbacks = function( options ) { } return this; }, + // Is it locked? locked: function() { return !stack; }, + // Call all callbacks with the given context and arguments fireWith: function( context, args ) { args = args || []; @@ -1150,11 +1197,13 @@ jQuery.Callbacks = function( options ) { } return this; }, + // Call all the callbacks with the given arguments fire: function() { self.fireWith( this, arguments ); return this; }, + // To know if the callbacks have already been called at least once fired: function() { return !!fired; @@ -1163,14 +1212,15 @@ jQuery.Callbacks = function( options ) { return self; }; -jQuery.extend({ +jQuery.extend( { Deferred: function( func ) { var tuples = [ + // action, add listener, listener list, final state - [ "resolve", "done", jQuery.Callbacks("once memory"), "resolved" ], - [ "reject", "fail", jQuery.Callbacks("once memory"), "rejected" ], - [ "notify", "progress", jQuery.Callbacks("memory") ] + [ "resolve", "done", jQuery.Callbacks( "once memory" ), "resolved" ], + [ "reject", "fail", jQuery.Callbacks( "once memory" ), "rejected" ], + [ "notify", "progress", jQuery.Callbacks( "memory" ) ] ], state = "pending", promise = { @@ -1183,12 +1233,13 @@ jQuery.extend({ }, then: function( /* fnDone, fnFail, fnProgress */ ) { var fns = arguments; - return jQuery.Deferred(function( newDefer ) { + return jQuery.Deferred( function( newDefer ) { jQuery.each( tuples, function( i, tuple ) { var action = tuple[ 0 ], fn = jQuery.isFunction( fns[ i ] ) && fns[ i ]; + // deferred[ done | fail | progress ] for forwarding actions to newDefer - deferred[ tuple[1] ](function() { + deferred[ tuple[ 1 ] ]( function() { var returned = fn && fn.apply( this, arguments ); if ( returned && jQuery.isFunction( returned.promise ) ) { returned.promise() @@ -1198,11 +1249,12 @@ jQuery.extend({ } else { newDefer[ action + "With" ]( this === promise ? newDefer.promise() : this, fn ? [ returned ] : arguments ); } - }); - }); + } ); + } ); fns = null; - }).promise(); + } ).promise(); }, + // Get a promise for this deferred // If obj is provided, the promise aspect is added to the object promise: function( obj ) { @@ -1220,11 +1272,12 @@ jQuery.extend({ stateString = tuple[ 3 ]; // promise[ done | fail | progress ] = list.add - promise[ tuple[1] ] = list.add; + promise[ tuple[ 1 ] ] = list.add; // Handle state if ( stateString ) { - list.add(function() { + list.add( function() { + // state = [ resolved | rejected ] state = stateString; @@ -1233,12 +1286,12 @@ jQuery.extend({ } // deferred[ resolve | reject | notify ] - deferred[ tuple[0] ] = function() { - deferred[ tuple[0] + "With" ]( this === deferred ? promise : this, arguments ); + deferred[ tuple[ 0 ] ] = function() { + deferred[ tuple[ 0 ] + "With" ]( this === deferred ? promise : this, arguments ); return this; }; - deferred[ tuple[0] + "With" ] = list.fireWith; - }); + deferred[ tuple[ 0 ] + "With" ] = list.fireWith; + } ); // Make the deferred a promise promise.promise( deferred ); @@ -1269,7 +1322,7 @@ jQuery.extend({ return function( value ) { contexts[ i ] = this; values[ i ] = arguments.length > 1 ? core_slice.call( arguments ) : value; - if( values === progressValues ) { + if ( values === progressValues ) { deferred.notifyWith( contexts, values ); } else if ( !( --remaining ) ) { deferred.resolveWith( contexts, values ); @@ -1303,32 +1356,33 @@ jQuery.extend({ return deferred.promise(); } -}); -jQuery.support = (function() { +} ); +jQuery.support = ( function() { var support, all, a, input, select, fragment, opt, eventName, isSupported, i, - div = document.createElement("div"); + div = document.createElement( "div" ); // Setup div.setAttribute( "className", "t" ); div.innerHTML = " <link/><table></table><a href='/a'>a</a><input type='checkbox'/>"; // Support tests won't run in some limited or non-browser environments - all = div.getElementsByTagName("*"); - a = div.getElementsByTagName("a")[ 0 ]; + all = div.getElementsByTagName( "*" ); + a = div.getElementsByTagName( "a" )[ 0 ]; if ( !all || !a || !all.length ) { return {}; } // First batch of tests - select = document.createElement("select"); - opt = select.appendChild( document.createElement("option") ); - input = div.getElementsByTagName("input")[ 0 ]; + select = document.createElement( "select" ); + opt = select.appendChild( document.createElement( "option" ) ); + input = div.getElementsByTagName( "input" )[ 0 ]; a.style.cssText = "top:1px;float:left;opacity:.5"; support = { + // Test setAttribute on camelCase class. If it works, we need attrFixes when doing get/setAttribute (ie6/7) getSetAttribute: div.className !== "t", @@ -1337,19 +1391,19 @@ jQuery.support = (function() { // Make sure that tbody elements aren't automatically inserted // IE will insert them into empty tables - tbody: !div.getElementsByTagName("tbody").length, + tbody: !div.getElementsByTagName( "tbody" ).length, // Make sure that link elements get serialized correctly by innerHTML // This requires a wrapper element in IE - htmlSerialize: !!div.getElementsByTagName("link").length, + htmlSerialize: !!div.getElementsByTagName( "link" ).length, // Get the style information from getAttribute // (IE uses .cssText instead) - style: /top/.test( a.getAttribute("style") ), + style: /top/.test( a.getAttribute( "style" ) ), // Make sure that URLs aren't manipulated // (IE normalizes it by default) - hrefNormalized: a.getAttribute("href") === "/a", + hrefNormalized: a.getAttribute( "href" ) === "/a", // Make sure that element opacity exists // (IE uses filter instead) @@ -1368,11 +1422,11 @@ jQuery.support = (function() { optSelected: opt.selected, // Tests for enctype support on a form (#6743) - enctype: !!document.createElement("form").enctype, + enctype: !!document.createElement( "form" ).enctype, // Makes sure cloning an html5 element does not cause problems // Where outerHTML is undefined, this still works - html5Clone: document.createElement("nav").cloneNode( true ).outerHTML !== "<:nav></:nav>", + html5Clone: document.createElement( "nav" ).cloneNode( true ).outerHTML !== "<:nav></:nav>", // jQuery.support.boxModel DEPRECATED in 1.8 since we don't support Quirks Mode boxModel: document.compatMode === "CSS1Compat", @@ -1399,12 +1453,12 @@ jQuery.support = (function() { // Support: IE<9 try { delete div.test; - } catch( e ) { + } catch ( e ) { support.deleteExpando = false; } // Check if we can trust getAttribute("value") - input = document.createElement("input"); + input = document.createElement( "input" ); input.setAttribute( "value", "" ); support.input = input.getAttribute( "value" ) === ""; @@ -1433,14 +1487,14 @@ jQuery.support = (function() { if ( div.attachEvent ) { div.attachEvent( "onclick", function() { support.noCloneEvent = false; - }); + } ); div.cloneNode( true ).click(); } // Support: IE<9 (lack submit/change bubble), Firefox 17+ (lack focusin event) // Beware of CSP restrictions (https://developer.mozilla.org/en/Security/CSP), test/csp.php - for ( i in { submit: true, change: true, focusin: true }) { + for ( i in { submit: true, change: true, focusin: true } ) { div.setAttribute( eventName = "on" + i, "t" ); support[ i + "Bubbles" ] = eventName in window || div.attributes[ eventName ].expando === false; @@ -1451,17 +1505,18 @@ jQuery.support = (function() { support.clearCloneStyle = div.style.backgroundClip === "content-box"; // Run tests that need a body at doc ready - jQuery(function() { + jQuery( function() { var container, marginDiv, tds, divReset = "padding:0;margin:0;border:0;display:block;box-sizing:content-box;-moz-box-sizing:content-box;-webkit-box-sizing:content-box;", - body = document.getElementsByTagName("body")[0]; + body = document.getElementsByTagName( "body" )[ 0 ]; if ( !body ) { + // Return for frameset docs that don't have a body return; } - container = document.createElement("div"); + container = document.createElement( "div" ); container.style.cssText = "border:0;width:0;height:0;position:absolute;top:0;left:-9999px;margin-top:1px"; body.appendChild( container ).appendChild( div ); @@ -1474,7 +1529,7 @@ jQuery.support = (function() { // display:none (it is still safe to use offsets if a parent element is // hidden; don safety goggles and see bug #4512 for more information). div.innerHTML = "<table><tr><td></td><td>t</td></tr></table>"; - tds = div.getElementsByTagName("td"); + tds = div.getElementsByTagName( "td" ); tds[ 0 ].style.cssText = "padding:0;margin:0;border:0;display:none"; isSupported = ( tds[ 0 ].offsetHeight === 0 ); @@ -1500,7 +1555,7 @@ jQuery.support = (function() { // gets computed margin-right based on width of container. (#3333) // Fails in WebKit before Feb 2011 nightlies // WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right - marginDiv = div.appendChild( document.createElement("div") ); + marginDiv = div.appendChild( document.createElement( "div" ) ); marginDiv.style.cssText = div.style.cssText = divReset; marginDiv.style.marginRight = marginDiv.style.width = "0"; div.style.width = "1px"; @@ -1510,6 +1565,7 @@ jQuery.support = (function() { } if ( typeof div.style.zoom !== core_strundefined ) { + // Support: IE<8 // Check if natively block-level elements act like inline-block // elements when setting their display to 'inline' and giving @@ -1526,6 +1582,7 @@ jQuery.support = (function() { support.shrinkWrapBlocks = ( div.offsetWidth !== 3 ); if ( support.inlineBlockNeedsLayout ) { + // Prevent IE 6 from affecting layout for positioned elements #11048 // Prevent IE from shrinking the body in IE 7 mode #12869 // Support: IE<8 @@ -1537,18 +1594,18 @@ jQuery.support = (function() { // Null elements to avoid leaks in IE container = div = tds = marginDiv = null; - }); + } ); // Null elements to avoid leaks in IE all = select = fragment = opt = a = input = null; return support; -})(); +} )(); var rbrace = /(?:\{[\s\S]*\}|\[[\s\S]*\])$/, rmultiDash = /([A-Z])/g; -function internalData( elem, name, data, pvt /* Internal Use Only */ ){ +function internalData( elem, name, data, pvt /* Internal Use Only */ ) { if ( !jQuery.acceptData( elem ) ) { return; } @@ -1571,11 +1628,12 @@ function internalData( elem, name, data, pvt /* Internal Use Only */ ){ // Avoid doing any more work than we need to when trying to get data on an // object that has no data at all - if ( (!id || !cache[id] || (!pvt && !cache[id].data)) && getByName && data === undefined ) { + if ( ( !id || !cache[ id ] || ( !pvt && !cache[ id ].data ) ) && getByName && data === undefined ) { return; } if ( !id ) { + // Only DOM nodes need a new unique ID for each element since their data // ends up in the global cache if ( isNode ) { @@ -1679,10 +1737,11 @@ function internalRemoveData( elem, name, pvt ) { if ( name in thisCache ) { name = [ name ]; } else { - name = name.split(" "); + name = name.split( " " ); } } } else { + // If "name" is an array of keys... // When data is initially created, via ("key", "val") signature, // keys will be converted to camelCase. @@ -1693,7 +1752,7 @@ function internalRemoveData( elem, name, pvt ) { } for ( i = 0, l = name.length; i < l; i++ ) { - delete thisCache[ name[i] ]; + delete thisCache[ name[ i ] ]; } // If there is no data left in the cache, we want to continue @@ -1729,7 +1788,7 @@ function internalRemoveData( elem, name, pvt ) { } } -jQuery.extend({ +jQuery.extend( { cache: {}, // Unique for each copy of jQuery on the page @@ -1740,13 +1799,14 @@ jQuery.extend({ // attempt to add expando properties to them. noData: { "embed": true, + // Ban all objects except for Flash (which handle expandos) "object": "clsid:D27CDB6E-AE6D-11cf-96B8-444553540000", "applet": true }, hasData: function( elem ) { - elem = elem.nodeType ? jQuery.cache[ elem[jQuery.expando] ] : elem[ jQuery.expando ]; + elem = elem.nodeType ? jQuery.cache[ elem[ jQuery.expando ] ] : elem[ jQuery.expando ]; return !!elem && !isEmptyDataObject( elem ); }, @@ -1769,6 +1829,7 @@ jQuery.extend({ // A method for determining if a DOM node can handle the data expando acceptData: function( elem ) { + // Do not set data on non-element because it will not be cleared (#8335). if ( elem.nodeType && elem.nodeType !== 1 && elem.nodeType !== 9 ) { return false; @@ -1777,14 +1838,14 @@ jQuery.extend({ var noData = elem.nodeName && jQuery.noData[ elem.nodeName.toLowerCase() ]; // nodes accept data unless otherwise specified; rejection can be conditional - return !noData || noData !== true && elem.getAttribute("classid") === noData; + return !noData || noData !== true && elem.getAttribute( "classid" ) === noData; } -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { data: function( key, value ) { var attrs, name, - elem = this[0], + elem = this[ 0 ], i = 0, data = null; @@ -1796,10 +1857,10 @@ jQuery.fn.extend({ if ( elem.nodeType === 1 && !jQuery._data( elem, "parsedAttrs" ) ) { attrs = elem.attributes; for ( ; i < attrs.length; i++ ) { - name = attrs[i].name; + name = attrs[ i ].name; if ( !name.indexOf( "data-" ) ) { - name = jQuery.camelCase( name.slice(5) ); + name = jQuery.camelCase( name.slice( 5 ) ); dataAttr( elem, name, data[ name ] ); } @@ -1813,32 +1874,34 @@ jQuery.fn.extend({ // Sets multiple values if ( typeof key === "object" ) { - return this.each(function() { + return this.each( function() { jQuery.data( this, key ); - }); + } ); } return jQuery.access( this, function( value ) { if ( value === undefined ) { + // Try to fetch any internally stored data first return elem ? dataAttr( elem, key, jQuery.data( elem, key ) ) : null; } - this.each(function() { + this.each( function() { jQuery.data( this, key, value ); - }); + } ); }, null, value, arguments.length > 1, null, true ); }, removeData: function( key ) { - return this.each(function() { + return this.each( function() { jQuery.removeData( this, key ); - }); + } ); } -}); +} ); function dataAttr( elem, key, data ) { + // If nothing was found internally, try to fetch any // data from the HTML5 data-* attribute if ( data === undefined && elem.nodeType === 1 ) { @@ -1852,11 +1915,12 @@ function dataAttr( elem, key, data ) { data = data === "true" ? true : data === "false" ? false : data === "null" ? null : + // Only convert to a number if it doesn't change the string +data + "" === data ? +data : rbrace.test( data ) ? jQuery.parseJSON( data ) : data; - } catch( e ) {} + } catch ( e ) {} // Make sure we set the data so it isn't changed later jQuery.data( elem, key, data ); @@ -1875,7 +1939,7 @@ function isEmptyDataObject( obj ) { for ( name in obj ) { // if the public data object is empty, the private is still empty - if ( name === "data" && jQuery.isEmptyObject( obj[name] ) ) { + if ( name === "data" && jQuery.isEmptyObject( obj[ name ] ) ) { continue; } if ( name !== "toJSON" ) { @@ -1885,7 +1949,7 @@ function isEmptyDataObject( obj ) { return true; } -jQuery.extend({ +jQuery.extend( { queue: function( elem, type, data ) { var queue; @@ -1895,8 +1959,8 @@ jQuery.extend({ // Speed up dequeue by getting out quickly if this is just a lookup if ( data ) { - if ( !queue || jQuery.isArray(data) ) { - queue = jQuery._data( elem, type, jQuery.makeArray(data) ); + if ( !queue || jQuery.isArray( data ) ) { + queue = jQuery._data( elem, type, jQuery.makeArray( data ) ); } else { queue.push( data ); } @@ -1945,15 +2009,15 @@ jQuery.extend({ _queueHooks: function( elem, type ) { var key = type + "queueHooks"; return jQuery._data( elem, key ) || jQuery._data( elem, key, { - empty: jQuery.Callbacks("once memory").add(function() { + empty: jQuery.Callbacks( "once memory" ).add( function() { jQuery._removeData( elem, type + "queue" ); jQuery._removeData( elem, key ); - }) - }); + } ) + } ); } -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { queue: function( type, data ) { var setter = 2; @@ -1964,27 +2028,28 @@ jQuery.fn.extend({ } if ( arguments.length < setter ) { - return jQuery.queue( this[0], type ); + return jQuery.queue( this[ 0 ], type ); } return data === undefined ? this : - this.each(function() { + this.each( function() { var queue = jQuery.queue( this, type, data ); // ensure a hooks for this queue jQuery._queueHooks( this, type ); - if ( type === "fx" && queue[0] !== "inprogress" ) { + if ( type === "fx" && queue[ 0 ] !== "inprogress" ) { jQuery.dequeue( this, type ); } - }); + } ); }, dequeue: function( type ) { - return this.each(function() { + return this.each( function() { jQuery.dequeue( this, type ); - }); + } ); }, + // Based off of the plugin by Clint Helfers, with permission. // http://blindsignals.com/index.php/2009/07/jquery-delay/ delay: function( time, type ) { @@ -1996,11 +2061,12 @@ jQuery.fn.extend({ hooks.stop = function() { clearTimeout( timeout ); }; - }); + } ); }, clearQueue: function( type ) { return this.queue( type || "fx", [] ); }, + // Get a promise resolved when queues of a certain type // are emptied (fx is the type by default) promise: function( type, obj ) { @@ -2021,7 +2087,7 @@ jQuery.fn.extend({ } type = type || "fx"; - while( i-- ) { + while ( i-- ) { tmp = jQuery._data( elements[ i ], type + "queueHooks" ); if ( tmp && tmp.empty ) { count++; @@ -2031,7 +2097,7 @@ jQuery.fn.extend({ resolve(); return defer.promise( obj ); } -}); +} ); var nodeHook, boolHook, rclass = /[\t\r\n]/g, rreturn = /\r/g, @@ -2042,15 +2108,15 @@ var nodeHook, boolHook, getSetAttribute = jQuery.support.getSetAttribute, getSetInput = jQuery.support.input; -jQuery.fn.extend({ +jQuery.fn.extend( { attr: function( name, value ) { return jQuery.access( this, jQuery.attr, name, value, arguments.length > 1 ); }, removeAttr: function( name ) { - return this.each(function() { + return this.each( function() { jQuery.removeAttr( this, name ); - }); + } ); }, prop: function( name, value ) { @@ -2059,13 +2125,14 @@ jQuery.fn.extend({ removeProp: function( name ) { name = jQuery.propFix[ name ] || name; - return this.each(function() { + return this.each( function() { + // try/catch handles cases where IE balks (such as removing a property on window) try { this[ name ] = undefined; delete this[ name ]; - } catch( e ) {} - }); + } catch ( e ) {} + } ); }, addClass: function( value ) { @@ -2075,12 +2142,13 @@ jQuery.fn.extend({ proceed = typeof value === "string" && value; if ( jQuery.isFunction( value ) ) { - return this.each(function( j ) { + return this.each( function( j ) { jQuery( this ).addClass( value.call( this, j, this.className ) ); - }); + } ); } if ( proceed ) { + // The disjunction here is for better compressibility (see removeClass) classes = ( value || "" ).match( core_rnotwhite ) || []; @@ -2093,7 +2161,7 @@ jQuery.fn.extend({ if ( cur ) { j = 0; - while ( (clazz = classes[j++]) ) { + while ( ( clazz = classes[ j++ ] ) ) { if ( cur.indexOf( " " + clazz + " " ) < 0 ) { cur += clazz + " "; } @@ -2114,15 +2182,16 @@ jQuery.fn.extend({ proceed = arguments.length === 0 || typeof value === "string" && value; if ( jQuery.isFunction( value ) ) { - return this.each(function( j ) { + return this.each( function( j ) { jQuery( this ).removeClass( value.call( this, j, this.className ) ); - }); + } ); } if ( proceed ) { classes = ( value || "" ).match( core_rnotwhite ) || []; for ( ; i < len; i++ ) { elem = this[ i ]; + // This expression is here for better compressibility (see addClass) cur = elem.nodeType === 1 && ( elem.className ? ( " " + elem.className + " " ).replace( rclass, " " ) : @@ -2131,7 +2200,8 @@ jQuery.fn.extend({ if ( cur ) { j = 0; - while ( (clazz = classes[j++]) ) { + while ( ( clazz = classes[ j++ ] ) ) { + // Remove *all* instances while ( cur.indexOf( " " + clazz + " " ) >= 0 ) { cur = cur.replace( " " + clazz + " ", " " ); @@ -2150,13 +2220,14 @@ jQuery.fn.extend({ isBool = typeof stateVal === "boolean"; if ( jQuery.isFunction( value ) ) { - return this.each(function( i ) { - jQuery( this ).toggleClass( value.call(this, i, this.className, stateVal), stateVal ); - }); + return this.each( function( i ) { + jQuery( this ).toggleClass( value.call( this, i, this.className, stateVal ), stateVal ); + } ); } - return this.each(function() { + return this.each( function() { if ( type === "string" ) { + // toggle individual class names var className, i = 0, @@ -2164,7 +2235,8 @@ jQuery.fn.extend({ state = stateVal, classNames = value.match( core_rnotwhite ) || []; - while ( (className = classNames[ i++ ]) ) { + while ( ( className = classNames[ i++ ] ) ) { + // check each className given, space separated list state = isBool ? state : !self.hasClass( className ); self[ state ? "addClass" : "removeClass" ]( className ); @@ -2173,6 +2245,7 @@ jQuery.fn.extend({ // Toggle whole class name } else if ( type === core_strundefined || type === "boolean" ) { if ( this.className ) { + // store className if set jQuery._data( this, "__className__", this.className ); } @@ -2183,7 +2256,7 @@ jQuery.fn.extend({ // falling back to the empty string if nothing was stored. this.className = this.className || value === false ? "" : jQuery._data( this, "__className__" ) || ""; } - }); + } ); }, hasClass: function( selector ) { @@ -2191,7 +2264,7 @@ jQuery.fn.extend({ i = 0, l = this.length; for ( ; i < l; i++ ) { - if ( this[i].nodeType === 1 && (" " + this[i].className + " ").replace(rclass, " ").indexOf( className ) >= 0 ) { + if ( this[ i ].nodeType === 1 && ( " " + this[ i ].className + " " ).replace( rclass, " " ).indexOf( className ) >= 0 ) { return true; } } @@ -2201,21 +2274,23 @@ jQuery.fn.extend({ val: function( value ) { var ret, hooks, isFunction, - elem = this[0]; + elem = this[ 0 ]; if ( !arguments.length ) { if ( elem ) { hooks = jQuery.valHooks[ elem.type ] || jQuery.valHooks[ elem.nodeName.toLowerCase() ]; - if ( hooks && "get" in hooks && (ret = hooks.get( elem, "value" )) !== undefined ) { + if ( hooks && "get" in hooks && ( ret = hooks.get( elem, "value" ) ) !== undefined ) { return ret; } ret = elem.value; return typeof ret === "string" ? + // handle most common string cases - ret.replace(rreturn, "") : + ret.replace( rreturn, "" ) : + // handle cases where value is null/undef or number ret == null ? "" : ret; } @@ -2225,9 +2300,9 @@ jQuery.fn.extend({ isFunction = jQuery.isFunction( value ); - return this.each(function( i ) { + return this.each( function( i ) { var val, - self = jQuery(this); + self = jQuery( this ); if ( this.nodeType !== 1 ) { return; @@ -2245,25 +2320,26 @@ jQuery.fn.extend({ } else if ( typeof val === "number" ) { val += ""; } else if ( jQuery.isArray( val ) ) { - val = jQuery.map(val, function ( value ) { + val = jQuery.map( val, function( value ) { return value == null ? "" : value + ""; - }); + } ); } hooks = jQuery.valHooks[ this.type ] || jQuery.valHooks[ this.nodeName.toLowerCase() ]; // If set returns undefined, fall back to normal setting - if ( !hooks || !("set" in hooks) || hooks.set( this, val, "value" ) === undefined ) { + if ( !hooks || !( "set" in hooks ) || hooks.set( this, val, "value" ) === undefined ) { this.value = val; } - }); + } ); } -}); +} ); -jQuery.extend({ +jQuery.extend( { valHooks: { option: { get: function( elem ) { + // attributes.value is undefined in Blackberry 4.7 but // uses .value. See #6932 var val = elem.attributes.value; @@ -2288,8 +2364,9 @@ jQuery.extend({ // oldIE doesn't update selected after form reset (#2551) if ( ( option.selected || i === index ) && + // Don't return options that are disabled or in a disabled optgroup - ( jQuery.support.optDisabled ? !option.disabled : option.getAttribute("disabled") === null ) && + ( jQuery.support.optDisabled ? !option.disabled : option.getAttribute( "disabled" ) === null ) && ( !option.parentNode.disabled || !jQuery.nodeName( option.parentNode, "optgroup" ) ) ) { // Get the specific value for the option @@ -2311,9 +2388,9 @@ jQuery.extend({ set: function( elem, value ) { var values = jQuery.makeArray( value ); - jQuery(elem).find("option").each(function() { - this.selected = jQuery.inArray( jQuery(this).val(), values ) >= 0; - }); + jQuery( elem ).find( "option" ).each( function() { + this.selected = jQuery.inArray( jQuery( this ).val(), values ) >= 0; + } ); if ( !values.length ) { elem.selectedIndex = -1; @@ -2351,7 +2428,7 @@ jQuery.extend({ if ( value === null ) { jQuery.removeAttr( elem, name ); - } else if ( hooks && notxml && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) { + } else if ( hooks && notxml && "set" in hooks && ( ret = hooks.set( elem, value, name ) ) !== undefined ) { return ret; } else { @@ -2359,7 +2436,7 @@ jQuery.extend({ return value; } - } else if ( hooks && notxml && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) { + } else if ( hooks && notxml && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) { return ret; } else { @@ -2383,11 +2460,12 @@ jQuery.extend({ attrNames = value && value.match( core_rnotwhite ); if ( attrNames && elem.nodeType === 1 ) { - while ( (name = attrNames[i++]) ) { + while ( ( name = attrNames[ i++ ] ) ) { propName = jQuery.propFix[ name ] || name; // Boolean attributes get special treatment (#10870) if ( rboolean.test( name ) ) { + // Set corresponding property to false for boolean attributes // Also clear defaultChecked/defaultSelected (if appropriate) for IE<8 if ( !getSetAttribute && ruseDefault.test( name ) ) { @@ -2410,7 +2488,8 @@ jQuery.extend({ attrHooks: { type: { set: function( elem, value ) { - if ( !jQuery.support.radioValue && value === "radio" && jQuery.nodeName(elem, "input") ) { + if ( !jQuery.support.radioValue && value === "radio" && jQuery.nodeName( elem, "input" ) ) { + // Setting the type on a radio button after the value resets the value in IE6-9 // Reset value to default in case type is set after value during creation var val = elem.value; @@ -2451,13 +2530,14 @@ jQuery.extend({ notxml = nType !== 1 || !jQuery.isXMLDoc( elem ); if ( notxml ) { + // Fix name and attach hooks name = jQuery.propFix[ name ] || name; hooks = jQuery.propHooks[ name ]; } if ( value !== undefined ) { - if ( hooks && "set" in hooks && (ret = hooks.set( elem, value, name )) !== undefined ) { + if ( hooks && "set" in hooks && ( ret = hooks.set( elem, value, name ) ) !== undefined ) { return ret; } else { @@ -2465,7 +2545,7 @@ jQuery.extend({ } } else { - if ( hooks && "get" in hooks && (ret = hooks.get( elem, name )) !== null ) { + if ( hooks && "get" in hooks && ( ret = hooks.get( elem, name ) ) !== null ) { return ret; } else { @@ -2477,9 +2557,10 @@ jQuery.extend({ propHooks: { tabIndex: { get: function( elem ) { + // elem.tabIndex doesn't always return the correct value when it hasn't been explicitly set // http://fluidproject.org/blog/2008/01/09/getting-setting-and-removing-tabindex-values-with-javascript/ - var attributeNode = elem.getAttributeNode("tabindex"); + var attributeNode = elem.getAttributeNode( "tabindex" ); return attributeNode && attributeNode.specified ? parseInt( attributeNode.value, 10 ) : @@ -2489,12 +2570,13 @@ jQuery.extend({ } } } -}); +} ); // Hook for boolean attributes boolHook = { get: function( elem, name ) { var + // Use .prop to determine if this attribute is understood as boolean prop = jQuery.prop( elem, name ), @@ -2504,6 +2586,7 @@ boolHook = { getSetInput && getSetAttribute ? attr != null : + // oldIE fabricates an empty string for missing boolean attributes // and conflates checked/selected into attroperties ruseDefault.test( name ) ? @@ -2519,9 +2602,11 @@ boolHook = { }, set: function( elem, value, name ) { if ( value === false ) { + // Remove boolean attributes when set to false jQuery.removeAttr( elem, name ); } else if ( getSetInput && getSetAttribute || !ruseDefault.test( name ) ) { + // IE<8 needs the *property* name elem.setAttribute( !getSetAttribute && jQuery.propFix[ name ] || name, name ); @@ -2548,9 +2633,11 @@ if ( !getSetInput || !getSetAttribute ) { }, set: function( elem, value, name ) { if ( jQuery.nodeName( elem, "input" ) ) { + // Does not return so that setAttribute is also used elem.defaultValue = value; } else { + // Use nodeHook if defined (#1954); otherwise setAttribute is fine return nodeHook && nodeHook.set( elem, value, name ); } @@ -2571,11 +2658,12 @@ if ( !getSetAttribute ) { undefined; }, set: function( elem, value, name ) { + // Set the existing or create a new attribute node var ret = elem.getAttributeNode( name ); if ( !ret ) { elem.setAttributeNode( - (ret = elem.ownerDocument.createAttribute( name )) + ( ret = elem.ownerDocument.createAttribute( name ) ) ); } @@ -2599,7 +2687,7 @@ if ( !getSetAttribute ) { // Set width and height to auto instead of 0 on empty string( Bug #8150 ) // This is for removals - jQuery.each([ "width", "height" ], function( i, name ) { + jQuery.each( [ "width", "height" ], function( i, name ) { jQuery.attrHooks[ name ] = jQuery.extend( jQuery.attrHooks[ name ], { set: function( elem, value ) { if ( value === "" ) { @@ -2607,36 +2695,36 @@ if ( !getSetAttribute ) { return value; } } - }); - }); + } ); + } ); } - // Some attributes require a special call on IE // http://msdn.microsoft.com/en-us/library/ms536429%28VS.85%29.aspx if ( !jQuery.support.hrefNormalized ) { - jQuery.each([ "href", "src", "width", "height" ], function( i, name ) { + jQuery.each( [ "href", "src", "width", "height" ], function( i, name ) { jQuery.attrHooks[ name ] = jQuery.extend( jQuery.attrHooks[ name ], { get: function( elem ) { var ret = elem.getAttribute( name, 2 ); return ret == null ? undefined : ret; } - }); - }); + } ); + } ); // href/src property should get the full normalized URL (#10299/#12915) - jQuery.each([ "href", "src" ], function( i, name ) { + jQuery.each( [ "href", "src" ], function( i, name ) { jQuery.propHooks[ name ] = { get: function( elem ) { return elem.getAttribute( name, 4 ); } }; - }); + } ); } if ( !jQuery.support.style ) { jQuery.attrHooks.style = { get: function( elem ) { + // Return undefined in the case of empty string // Note: IE uppercases css property names, but if we were to .toLowerCase() // .cssText, that would destroy case senstitivity in URL's, like in "background" @@ -2665,7 +2753,7 @@ if ( !jQuery.support.optSelected ) { } return null; } - }); + } ); } // IE6/7 call enctype encoding @@ -2675,24 +2763,25 @@ if ( !jQuery.support.enctype ) { // Radios and checkboxes getter/setter if ( !jQuery.support.checkOn ) { - jQuery.each([ "radio", "checkbox" ], function() { + jQuery.each( [ "radio", "checkbox" ], function() { jQuery.valHooks[ this ] = { get: function( elem ) { + // Handle the case where in Webkit "" is returned instead of "on" if a value isn't specified - return elem.getAttribute("value") === null ? "on" : elem.value; + return elem.getAttribute( "value" ) === null ? "on" : elem.value; } }; - }); + } ); } -jQuery.each([ "radio", "checkbox" ], function() { +jQuery.each( [ "radio", "checkbox" ], function() { jQuery.valHooks[ this ] = jQuery.extend( jQuery.valHooks[ this ], { set: function( elem, value ) { if ( jQuery.isArray( value ) ) { - return ( elem.checked = jQuery.inArray( jQuery(elem).val(), value ) >= 0 ); + return ( elem.checked = jQuery.inArray( jQuery( elem ).val(), value ) >= 0 ); } } - }); -}); + } ); +} ); var rformElems = /^(?:input|select|textarea)$/i, rkeyEvent = /^key/, rmouseEvent = /^(?:mouse|contextmenu)|click/, @@ -2739,29 +2828,31 @@ jQuery.event = { } // Init the element's event structure and main handler, if this is the first - if ( !(events = elemData.events) ) { + if ( !( events = elemData.events ) ) { events = elemData.events = {}; } - if ( !(eventHandle = elemData.handle) ) { + if ( !( eventHandle = elemData.handle ) ) { eventHandle = elemData.handle = function( e ) { + // Discard the second event of a jQuery.event.trigger() and // when an event is called after a page has unloaded - return typeof jQuery !== core_strundefined && (!e || jQuery.event.triggered !== e.type) ? + return typeof jQuery !== core_strundefined && ( !e || jQuery.event.triggered !== e.type ) ? jQuery.event.dispatch.apply( eventHandle.elem, arguments ) : undefined; }; + // Add elem as a property of the handle fn to prevent a memory leak with IE non-native events eventHandle.elem = elem; } // Handle multiple events separated by a space // jQuery(...).bind("mouseover mouseout", fn); - types = ( types || "" ).match( core_rnotwhite ) || [""]; + types = ( types || "" ).match( core_rnotwhite ) || [ "" ]; t = types.length; while ( t-- ) { - tmp = rtypenamespace.exec( types[t] ) || []; - type = origType = tmp[1]; - namespaces = ( tmp[2] || "" ).split( "." ).sort(); + tmp = rtypenamespace.exec( types[ t ] ) || []; + type = origType = tmp[ 1 ]; + namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort(); // If event changes its type, use the special event handlers for the changed type special = jQuery.event.special[ type ] || {}; @@ -2773,7 +2864,7 @@ jQuery.event = { special = jQuery.event.special[ type ] || {}; // handleObj is passed to all event handlers - handleObj = jQuery.extend({ + handleObj = jQuery.extend( { type: type, origType: origType, data: data, @@ -2781,16 +2872,17 @@ jQuery.event = { guid: handler.guid, selector: selector, needsContext: selector && jQuery.expr.match.needsContext.test( selector ), - namespace: namespaces.join(".") + namespace: namespaces.join( "." ) }, handleObjIn ); // Init the event handler queue if we're the first - if ( !(handlers = events[ type ]) ) { + if ( !( handlers = events[ type ] ) ) { handlers = events[ type ] = []; handlers.delegateCount = 0; // Only use addEventListener/attachEvent if the special events handler returns false if ( !special.setup || special.setup.call( elem, data, namespaces, eventHandle ) === false ) { + // Bind the global event handler to the element if ( elem.addEventListener ) { elem.addEventListener( type, eventHandle, false ); @@ -2832,17 +2924,17 @@ jQuery.event = { namespaces, origType, elemData = jQuery.hasData( elem ) && jQuery._data( elem ); - if ( !elemData || !(events = elemData.events) ) { + if ( !elemData || !( events = elemData.events ) ) { return; } // Once for each type.namespace in types; type may be omitted - types = ( types || "" ).match( core_rnotwhite ) || [""]; + types = ( types || "" ).match( core_rnotwhite ) || [ "" ]; t = types.length; while ( t-- ) { - tmp = rtypenamespace.exec( types[t] ) || []; - type = origType = tmp[1]; - namespaces = ( tmp[2] || "" ).split( "." ).sort(); + tmp = rtypenamespace.exec( types[ t ] ) || []; + type = origType = tmp[ 1 ]; + namespaces = ( tmp[ 2 ] || "" ).split( "." ).sort(); // Unbind all events (on this namespace, if provided) for the element if ( !type ) { @@ -2855,7 +2947,7 @@ jQuery.event = { special = jQuery.event.special[ type ] || {}; type = ( selector ? special.delegateType : special.bindType ) || type; handlers = events[ type ] || []; - tmp = tmp[2] && new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ); + tmp = tmp[ 2 ] && new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" ); // Remove matching events origCount = j = handlers.length; @@ -2903,7 +2995,7 @@ jQuery.event = { bubbleType, special, tmp, i, eventPath = [ elem || document ], type = core_hasOwn.call( event, "type" ) ? event.type : event, - namespaces = core_hasOwn.call( event, "namespace" ) ? event.namespace.split(".") : []; + namespaces = core_hasOwn.call( event, "namespace" ) ? event.namespace.split( "." ) : []; cur = tmp = elem = elem || document; @@ -2917,13 +3009,14 @@ jQuery.event = { return; } - if ( type.indexOf(".") >= 0 ) { + if ( type.indexOf( "." ) >= 0 ) { + // Namespaced trigger; create a regexp to match event type in handle() - namespaces = type.split("."); + namespaces = type.split( "." ); type = namespaces.shift(); namespaces.sort(); } - ontype = type.indexOf(":") < 0 && "on" + type; + ontype = type.indexOf( ":" ) < 0 && "on" + type; // Caller can pass in a jQuery.Event object, Object, or just an event type string event = event[ jQuery.expando ] ? @@ -2931,9 +3024,9 @@ jQuery.event = { new jQuery.Event( type, typeof event === "object" && event ); event.isTrigger = true; - event.namespace = namespaces.join("."); + event.namespace = namespaces.join( "." ); event.namespace_re = event.namespace ? - new RegExp( "(^|\\.)" + namespaces.join("\\.(?:.*\\.|)") + "(\\.|$)" ) : + new RegExp( "(^|\\.)" + namespaces.join( "\\.(?:.*\\.|)" ) + "(\\.|$)" ) : null; // Clean up the event in case it is being reused @@ -2967,14 +3060,14 @@ jQuery.event = { } // Only add window if we got to document (e.g., not plain obj or detached DOM) - if ( tmp === (elem.ownerDocument || document) ) { + if ( tmp === ( elem.ownerDocument || document ) ) { eventPath.push( tmp.defaultView || tmp.parentWindow || window ); } } // Fire handlers on the event path i = 0; - while ( (cur = eventPath[i++]) && !event.isPropagationStopped() ) { + while ( ( cur = eventPath[ i++ ] ) && !event.isPropagationStopped() ) { event.type = i > 1 ? bubbleType : @@ -2997,8 +3090,8 @@ jQuery.event = { // If nobody prevented the default action, do it now if ( !onlyHandlers && !event.isDefaultPrevented() ) { - if ( (!special._default || special._default.apply( elem.ownerDocument, data ) === false) && - !(type === "click" && jQuery.nodeName( elem, "a" )) && jQuery.acceptData( elem ) ) { + if ( ( !special._default || special._default.apply( elem.ownerDocument, data ) === false ) && + !( type === "click" && jQuery.nodeName( elem, "a" ) ) && jQuery.acceptData( elem ) ) { // Call a native DOM method on the target with the same name name as the event. // Can't use an .isFunction() check here because IE6/7 fails that test. @@ -3017,6 +3110,7 @@ jQuery.event = { try { elem[ type ](); } catch ( e ) { + // IE<9 dies on focus/blur to hidden element (#1486,#12518) // only reproducible on winXP IE8 native, not IE9 in IE8 mode } @@ -3044,7 +3138,7 @@ jQuery.event = { special = jQuery.event.special[ event.type ] || {}; // Use the fix-ed jQuery.Event rather than the (read-only) native event - args[0] = event; + args[ 0 ] = event; event.delegateTarget = this; // Call the preDispatch hook for the mapped type, and let it bail if desired @@ -3057,11 +3151,11 @@ jQuery.event = { // Run delegates first; they may want to stop propagation beneath us i = 0; - while ( (matched = handlerQueue[ i++ ]) && !event.isPropagationStopped() ) { + while ( ( matched = handlerQueue[ i++ ] ) && !event.isPropagationStopped() ) { event.currentTarget = matched.elem; j = 0; - while ( (handleObj = matched.handlers[ j++ ]) && !event.isImmediatePropagationStopped() ) { + while ( ( handleObj = matched.handlers[ j++ ] ) && !event.isImmediatePropagationStopped() ) { // Triggered event must either 1) have no namespace, or // 2) have namespace(s) a subset or equal to those in the bound event (both can have no namespace). @@ -3070,11 +3164,11 @@ jQuery.event = { event.handleObj = handleObj; event.data = handleObj.data; - ret = ( (jQuery.event.special[ handleObj.origType ] || {}).handle || handleObj.handler ) + ret = ( ( jQuery.event.special[ handleObj.origType ] || {} ).handle || handleObj.handler ) .apply( matched.elem, args ); if ( ret !== undefined ) { - if ( (event.result = ret) === false ) { + if ( ( event.result = ret ) === false ) { event.preventDefault(); event.stopPropagation(); } @@ -3100,13 +3194,13 @@ jQuery.event = { // Find delegate handlers // Black-hole SVG <use> instance trees (#13180) // Avoid non-left-click bubbling in Firefox (#3861) - if ( delegateCount && cur.nodeType && (!event.button || event.type !== "click") ) { + if ( delegateCount && cur.nodeType && ( !event.button || event.type !== "click" ) ) { for ( ; cur != this; cur = cur.parentNode || this ) { // Don't check non-elements (#13208) // Don't process clicks on disabled elements (#6911, #8165, #11382, #11764) - if ( cur.nodeType === 1 && (cur.disabled !== true || event.type !== "click") ) { + if ( cur.nodeType === 1 && ( cur.disabled !== true || event.type !== "click" ) ) { matches = []; for ( i = 0; i < delegateCount; i++ ) { handleObj = handlers[ i ]; @@ -3124,7 +3218,7 @@ jQuery.event = { } } if ( matches.length ) { - handlerQueue.push({ elem: cur, handlers: matches }); + handlerQueue.push( { elem: cur, handlers: matches } ); } } } @@ -3132,7 +3226,7 @@ jQuery.event = { // Add the remaining (directly-bound) handlers if ( delegateCount < handlers.length ) { - handlerQueue.push({ elem: this, handlers: handlers.slice( delegateCount ) }); + handlerQueue.push( { elem: this, handlers: handlers.slice( delegateCount ) } ); } return handlerQueue; @@ -3185,12 +3279,12 @@ jQuery.event = { }, // Includes some event props shared by KeyEvent and MouseEvent - props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split(" "), + props: "altKey bubbles cancelable ctrlKey currentTarget eventPhase metaKey relatedTarget shiftKey target timeStamp view which".split( " " ), fixHooks: {}, keyHooks: { - props: "char charCode key keyCode".split(" "), + props: "char charCode key keyCode".split( " " ), filter: function( event, original ) { // Add which for key events @@ -3203,7 +3297,7 @@ jQuery.event = { }, mouseHooks: { - props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split(" "), + props: "button buttons clientX clientY fromElement offsetX offsetY pageX pageY screenX screenY toElement".split( " " ), filter: function( event, original ) { var body, eventDoc, doc, button = original.button, @@ -3236,10 +3330,12 @@ jQuery.event = { special: { load: { + // Prevent triggered image.load events from bubbling to window.load noBubble: true }, click: { + // For checkbox, fire native event so checked state will be right trigger: function() { if ( jQuery.nodeName( this, "input" ) && this.type === "checkbox" && this.click ) { @@ -3249,6 +3345,7 @@ jQuery.event = { } }, focus: { + // Fire native event if possible so blur/focus sequence is correct trigger: function() { if ( this !== document.activeElement && this.focus ) { @@ -3256,6 +3353,7 @@ jQuery.event = { this.focus(); return false; } catch ( e ) { + // Support: IE<9 // If we error on focus to hidden element (#1486, #12518), // let .trigger() run the handlers @@ -3286,6 +3384,7 @@ jQuery.event = { }, simulate: function( type, elem, event, bubble ) { + // Piggyback on a donor event to simulate a different one. // Fake originalEvent to avoid donor's stopPropagation, but if the // simulated event prevents default then we do the same on the donor. @@ -3330,8 +3429,9 @@ jQuery.removeEvent = document.removeEventListener ? }; jQuery.Event = function( src, props ) { + // Allow instantiation without the 'new' keyword - if ( !(this instanceof jQuery.Event) ) { + if ( !( this instanceof jQuery.Event ) ) { return new jQuery.Event( src, props ); } @@ -3394,6 +3494,7 @@ jQuery.Event.prototype = { if ( !e ) { return; } + // If stopPropagation exists, run it on the original event if ( e.stopPropagation ) { e.stopPropagation(); @@ -3410,7 +3511,7 @@ jQuery.Event.prototype = { }; // Create mouseenter/leave events using mouseover/out and event-time checks -jQuery.each({ +jQuery.each( { mouseenter: "mouseover", mouseleave: "mouseout" }, function( orig, fix ) { @@ -3426,7 +3527,7 @@ jQuery.each({ // For mousenter/leave call the handler if related is outside the target. // NB: No relatedTarget if the mouse left/entered the browser window - if ( !related || (related !== target && !jQuery.contains( target, related )) ) { + if ( !related || ( related !== target && !jQuery.contains( target, related ) ) ) { event.type = handleObj.origType; ret = handleObj.handler.apply( this, arguments ); event.type = fix; @@ -3434,13 +3535,14 @@ jQuery.each({ return ret; } }; -}); +} ); // IE submit delegation if ( !jQuery.support.submitBubbles ) { jQuery.event.special.submit = { setup: function() { + // Only need this for delegated form submit events if ( jQuery.nodeName( this, "form" ) ) { return false; @@ -3448,20 +3550,23 @@ if ( !jQuery.support.submitBubbles ) { // Lazy-add a submit handler when a descendant form may potentially be submitted jQuery.event.add( this, "click._submit keypress._submit", function( e ) { + // Node name check avoids a VML-related crash in IE (#9807) var elem = e.target, form = jQuery.nodeName( elem, "input" ) || jQuery.nodeName( elem, "button" ) ? elem.form : undefined; if ( form && !jQuery._data( form, "submitBubbles" ) ) { jQuery.event.add( form, "submit._submit", function( event ) { event._submit_bubble = true; - }); + } ); jQuery._data( form, "submitBubbles", true ); } - }); + } ); + // return undefined since we don't need an event listener }, postDispatch: function( event ) { + // If form was submitted by the user, bubble the event up the tree if ( event._submit_bubble ) { delete event._submit_bubble; @@ -3472,6 +3577,7 @@ if ( !jQuery.support.submitBubbles ) { }, teardown: function() { + // Only need this for delegated form submit events if ( jQuery.nodeName( this, "form" ) ) { return false; @@ -3491,6 +3597,7 @@ if ( !jQuery.support.changeBubbles ) { setup: function() { if ( rformElems.test( this.nodeName ) ) { + // IE doesn't fire change on a check/radio until blur; trigger it on click // after a propertychange. Eat the blur-change in special.change.handle. // This still fires onchange a second time for check/radio after blur. @@ -3499,17 +3606,19 @@ if ( !jQuery.support.changeBubbles ) { if ( event.originalEvent.propertyName === "checked" ) { this._just_changed = true; } - }); + } ); jQuery.event.add( this, "click._change", function( event ) { if ( this._just_changed && !event.isTrigger ) { this._just_changed = false; } + // Allow triggered, simulated change events (#11500) jQuery.event.simulate( "change", this, event, true ); - }); + } ); } return false; } + // Delegated event; lazy-add a change handler on descendant inputs jQuery.event.add( this, "beforeactivate._change", function( e ) { var elem = e.target; @@ -3519,17 +3628,17 @@ if ( !jQuery.support.changeBubbles ) { if ( this.parentNode && !event.isSimulated && !event.isTrigger ) { jQuery.event.simulate( "change", this.parentNode, event, true ); } - }); + } ); jQuery._data( elem, "changeBubbles", true ); } - }); + } ); }, handle: function( event ) { var elem = event.target; // Swallow native change events from checkbox/radio, we already triggered them above - if ( this !== elem || event.isSimulated || event.isTrigger || (elem.type !== "radio" && elem.type !== "checkbox") ) { + if ( this !== elem || event.isSimulated || event.isTrigger || ( elem.type !== "radio" && elem.type !== "checkbox" ) ) { return event.handleObj.handler.apply( this, arguments ); } }, @@ -3544,7 +3653,7 @@ if ( !jQuery.support.changeBubbles ) { // Create "bubbling" focus and blur events if ( !jQuery.support.focusinBubbles ) { - jQuery.each({ focus: "focusin", blur: "focusout" }, function( orig, fix ) { + jQuery.each( { focus: "focusin", blur: "focusout" }, function( orig, fix ) { // Attach a single capturing handler while someone wants focusin/focusout var attaches = 0, @@ -3564,18 +3673,20 @@ if ( !jQuery.support.focusinBubbles ) { } } }; - }); + } ); } -jQuery.fn.extend({ +jQuery.fn.extend( { on: function( types, selector, data, fn, /*INTERNAL*/ one ) { var type, origFn; // Types can be a map of types/handlers if ( typeof types === "object" ) { + // ( types-Object, selector, data ) if ( typeof selector !== "string" ) { + // ( types-Object, data ) data = data || selector; selector = undefined; @@ -3587,15 +3698,18 @@ jQuery.fn.extend({ } if ( data == null && fn == null ) { + // ( types, fn ) fn = selector; data = selector = undefined; } else if ( fn == null ) { if ( typeof selector === "string" ) { + // ( types, selector, fn ) fn = data; data = undefined; } else { + // ( types, data, fn ) fn = data; data = selector; @@ -3611,16 +3725,18 @@ jQuery.fn.extend({ if ( one === 1 ) { origFn = fn; fn = function( event ) { + // Can use an empty set, since event contains the info jQuery().off( event ); return origFn.apply( this, arguments ); }; + // Use same guid so caller can remove using origFn fn.guid = origFn.guid || ( origFn.guid = jQuery.guid++ ); } return this.each( function() { jQuery.event.add( this, types, fn, data, selector ); - }); + } ); }, one: function( types, selector, data, fn ) { return this.on( types, selector, data, fn, 1 ); @@ -3628,6 +3744,7 @@ jQuery.fn.extend({ off: function( types, selector, fn ) { var handleObj, type; if ( types && types.preventDefault && types.handleObj ) { + // ( event ) dispatched jQuery.Event handleObj = types.handleObj; jQuery( types.delegateTarget ).off( @@ -3638,6 +3755,7 @@ jQuery.fn.extend({ return this; } if ( typeof types === "object" ) { + // ( types-object [, selector] ) for ( type in types ) { this.off( type, selector, types[ type ] ); @@ -3645,6 +3763,7 @@ jQuery.fn.extend({ return this; } if ( selector === false || typeof selector === "function" ) { + // ( types [, fn] ) fn = selector; selector = undefined; @@ -3652,9 +3771,9 @@ jQuery.fn.extend({ if ( fn === false ) { fn = returnFalse; } - return this.each(function() { + return this.each( function() { jQuery.event.remove( this, types, fn, selector ); - }); + } ); }, bind: function( types, data, fn ) { @@ -3668,29 +3787,30 @@ jQuery.fn.extend({ return this.on( types, selector, data, fn ); }, undelegate: function( selector, types, fn ) { + // ( namespace ) or ( selector, types [, fn] ) return arguments.length === 1 ? this.off( selector, "**" ) : this.off( types, selector || "**", fn ); }, trigger: function( type, data ) { - return this.each(function() { + return this.each( function() { jQuery.event.trigger( type, data, this ); - }); + } ); }, triggerHandler: function( type, data ) { - var elem = this[0]; + var elem = this[ 0 ]; if ( elem ) { return jQuery.event.trigger( type, data, elem, true ); } } -}); +} ); /*! * Sizzle CSS Selector Engine * Copyright 2012 jQuery Foundation and other contributors * Released under the MIT license * http://sizzlejs.com/ */ -(function( window, undefined ) { +( function( window, undefined ) { var i, cachedruns, @@ -3713,7 +3833,7 @@ var i, sortOrder, // Instance-specific data - expando = "sizzle" + -(new Date()), + expando = "sizzle" + -( new Date() ), preferredDoc = window.document, support = {}, dirruns = 0, @@ -3731,23 +3851,24 @@ var i, pop = arr.pop, push = arr.push, slice = arr.slice, + // Use a stripped-down indexOf if we can't use a native one indexOf = arr.indexOf || function( elem ) { var i = 0, len = this.length; for ( ; i < len; i++ ) { - if ( this[i] === elem ) { + if ( this[ i ] === elem ) { return i; } } return -1; }, - // Regular expressions // Whitespace characters http://www.w3.org/TR/css3-selectors/#whitespace whitespace = "[\\x20\\t\\r\\n\\f]", + // http://www.w3.org/TR/css3-syntax/#characters characterEncoding = "(?:\\\\.|[\\w-]|[^\\x00-\\xa0])+", @@ -3787,6 +3908,7 @@ var i, "CHILD": new RegExp( "^:(only|first|last|nth|nth-last)-(child|of-type)(?:\\(" + whitespace + "*(even|odd|(([+-]|)(\\d*)n|)" + whitespace + "*(?:([+-]|)" + whitespace + "*(\\d+)|))" + whitespace + "*\\)|)", "i" ), + // For use in libraries implementing .is() // We use this for POS matching in `select` "needsContext": new RegExp( "^" + whitespace + "*[>+~]|:(even|odd|eq|gt|lt|nth|first|last)(?:\\(" + @@ -3810,24 +3932,27 @@ var i, runescape = /\\([\da-fA-F]{1,6}[\x20\t\r\n\f]?|.)/g, funescape = function( _, escaped ) { var high = "0x" + escaped - 0x10000; + // NaN means non-codepoint return high !== high ? escaped : + // BMP codepoint high < 0 ? String.fromCharCode( high + 0x10000 ) : + // Supplemental Plane codepoint (surrogate pair) String.fromCharCode( high >> 10 | 0xD800, high & 0x3FF | 0xDC00 ); }; // Use a stripped-down slice if we can't use a native one try { - slice.call( preferredDoc.documentElement.childNodes, 0 )[0].nodeType; + slice.call( preferredDoc.documentElement.childNodes, 0 )[ 0 ].nodeType; } catch ( e ) { slice = function( i ) { var elem, results = []; - while ( (elem = this[i++]) ) { + while ( ( elem = this[ i++ ] ) ) { results.push( elem ); } return results; @@ -3852,14 +3977,16 @@ function createCache() { var cache, keys = []; - return (cache = function( key, value ) { + return ( cache = function( key, value ) { + // Use (key + " ") to avoid collision with native prototype properties (see Issue #157) if ( keys.push( key += " " ) > Expr.cacheLength ) { + // Only keep the most recent entries delete cache[ keys.shift() ]; } - return (cache[ key ] = value); - }); + return ( cache[ key ] = value ); + } ); } /** @@ -3876,13 +4003,14 @@ function markFunction( fn ) { * @param {Function} fn Passed the created div and expects a boolean result */ function assert( fn ) { - var div = document.createElement("div"); + var div = document.createElement( "div" ); try { return fn( div ); - } catch (e) { + } catch ( e ) { return false; } finally { + // release memory in IE div = null; } @@ -3890,6 +4018,7 @@ function assert( fn ) { function Sizzle( selector, context, results, seed ) { var match, elem, m, nodeType, + // QSA vars i, groups, old, nid, newContext, newSelector; @@ -3904,21 +4033,24 @@ function Sizzle( selector, context, results, seed ) { return results; } - if ( (nodeType = context.nodeType) !== 1 && nodeType !== 9 ) { + if ( ( nodeType = context.nodeType ) !== 1 && nodeType !== 9 ) { return []; } if ( !documentIsXML && !seed ) { // Shortcuts - if ( (match = rquickExpr.exec( selector )) ) { + if ( ( match = rquickExpr.exec( selector ) ) ) { + // Speed-up: Sizzle("#ID") - if ( (m = match[1]) ) { + if ( ( m = match[ 1 ] ) ) { if ( nodeType === 9 ) { elem = context.getElementById( m ); + // Check parentNode to catch when Blackberry 4.6 returns // nodes that are no longer in the document #6963 if ( elem && elem.parentNode ) { + // Handle the case where IE, Opera, and Webkit return items // by name instead of ID if ( elem.id === m ) { @@ -3929,8 +4061,9 @@ function Sizzle( selector, context, results, seed ) { return results; } } else { + // Context is not a document - if ( context.ownerDocument && (elem = context.ownerDocument.getElementById( m )) && + if ( context.ownerDocument && ( elem = context.ownerDocument.getElementById( m ) ) && contains( context, elem ) && elem.id === m ) { results.push( elem ); return results; @@ -3938,19 +4071,19 @@ function Sizzle( selector, context, results, seed ) { } // Speed-up: Sizzle("TAG") - } else if ( match[2] ) { - push.apply( results, slice.call(context.getElementsByTagName( selector ), 0) ); + } else if ( match[ 2 ] ) { + push.apply( results, slice.call( context.getElementsByTagName( selector ), 0 ) ); return results; // Speed-up: Sizzle(".CLASS") - } else if ( (m = match[3]) && support.getByClassName && context.getElementsByClassName ) { - push.apply( results, slice.call(context.getElementsByClassName( m ), 0) ); + } else if ( ( m = match[ 3 ] ) && support.getByClassName && context.getElementsByClassName ) { + push.apply( results, slice.call( context.getElementsByClassName( m ), 0 ) ); return results; } } // QSA path - if ( support.qsa && !rbuggyQSA.test(selector) ) { + if ( support.qsa && !rbuggyQSA.test( selector ) ) { old = true; nid = expando; newContext = context; @@ -3963,7 +4096,7 @@ function Sizzle( selector, context, results, seed ) { if ( nodeType === 1 && context.nodeName.toLowerCase() !== "object" ) { groups = tokenize( selector ); - if ( (old = context.getAttribute("id")) ) { + if ( ( old = context.getAttribute( "id" ) ) ) { nid = old.replace( rescape, "\\$&" ); } else { context.setAttribute( "id", nid ); @@ -3972,10 +4105,10 @@ function Sizzle( selector, context, results, seed ) { i = groups.length; while ( i-- ) { - groups[i] = nid + toSelector( groups[i] ); + groups[ i ] = nid + toSelector( groups[ i ] ); } newContext = rsibling.test( selector ) && context.parentNode || context; - newSelector = groups.join(","); + newSelector = groups.join( "," ); } if ( newSelector ) { @@ -3984,10 +4117,10 @@ function Sizzle( selector, context, results, seed ) { newSelector ), 0 ) ); return results; - } catch(qsaError) { + } catch ( qsaError ) { } finally { if ( !old ) { - context.removeAttribute("id"); + context.removeAttribute( "id" ); } } } @@ -4003,9 +4136,10 @@ function Sizzle( selector, context, results, seed ) { * @param {Element|Object} elem An element or a document */ isXML = Sizzle.isXML = function( elem ) { + // documentElement is verified for cases where it doesn't yet exist // (such as loading iframes in IE - #4833) - var documentElement = elem && (elem.ownerDocument || elem).documentElement; + var documentElement = elem && ( elem.ownerDocument || elem ).documentElement; return documentElement ? documentElement.nodeName !== "HTML" : false; }; @@ -4030,35 +4164,38 @@ setDocument = Sizzle.setDocument = function( node ) { documentIsXML = isXML( doc ); // Check if getElementsByTagName("*") returns only elements - support.tagNameNoComments = assert(function( div ) { - div.appendChild( doc.createComment("") ); - return !div.getElementsByTagName("*").length; - }); + support.tagNameNoComments = assert( function( div ) { + div.appendChild( doc.createComment( "" ) ); + return !div.getElementsByTagName( "*" ).length; + } ); // Check if attributes should be retrieved by attribute nodes - support.attributes = assert(function( div ) { + support.attributes = assert( function( div ) { div.innerHTML = "<select></select>"; - var type = typeof div.lastChild.getAttribute("multiple"); + var type = typeof div.lastChild.getAttribute( "multiple" ); + // IE8 returns a string for some attributes even when not present return type !== "boolean" && type !== "string"; - }); + } ); // Check if getElementsByClassName can be trusted - support.getByClassName = assert(function( div ) { + support.getByClassName = assert( function( div ) { + // Opera can't find a second classname (in 9.6) div.innerHTML = "<div class='hidden e'></div><div class='hidden'></div>"; - if ( !div.getElementsByClassName || !div.getElementsByClassName("e").length ) { + if ( !div.getElementsByClassName || !div.getElementsByClassName( "e" ).length ) { return false; } // Safari 3.2 caches class attributes and doesn't catch changes div.lastChild.className = "e"; - return div.getElementsByClassName("e").length === 2; - }); + return div.getElementsByClassName( "e" ).length === 2; + } ); // Check if getElementById returns elements by name // Check if getElementsByName privileges form controls or returns elements by ID - support.getByName = assert(function( div ) { + support.getByName = assert( function( div ) { + // Inject content div.id = expando + 0; div.innerHTML = "<a name='" + expando + "'></a><div name='" + expando + "'></div>"; @@ -4066,8 +4203,10 @@ setDocument = Sizzle.setDocument = function( node ) { // Test var pass = doc.getElementsByName && + // buggy browsers will return fewer than the correct 2 doc.getElementsByName( expando ).length === 2 + + // buggy browsers will return more than the correct 0 doc.getElementsByName( expando + 0 ).length; support.getIdNotName = !doc.getElementById( expando ); @@ -4076,63 +4215,64 @@ setDocument = Sizzle.setDocument = function( node ) { docElem.removeChild( div ); return pass; - }); + } ); // IE6/7 return modified attributes - Expr.attrHandle = assert(function( div ) { + Expr.attrHandle = assert( function( div ) { div.innerHTML = "<a href='#'></a>"; return div.firstChild && typeof div.firstChild.getAttribute !== strundefined && - div.firstChild.getAttribute("href") === "#"; - }) ? + div.firstChild.getAttribute( "href" ) === "#"; + } ) ? {} : { "href": function( elem ) { return elem.getAttribute( "href", 2 ); }, "type": function( elem ) { - return elem.getAttribute("type"); + return elem.getAttribute( "type" ); } }; // ID find and filter if ( support.getIdNotName ) { - Expr.find["ID"] = function( id, context ) { + Expr.find[ "ID" ] = function( id, context ) { if ( typeof context.getElementById !== strundefined && !documentIsXML ) { var m = context.getElementById( id ); + // Check parentNode to catch when Blackberry 4.6 returns // nodes that are no longer in the document #6963 - return m && m.parentNode ? [m] : []; + return m && m.parentNode ? [ m ] : []; } }; - Expr.filter["ID"] = function( id ) { + Expr.filter[ "ID" ] = function( id ) { var attrId = id.replace( runescape, funescape ); return function( elem ) { - return elem.getAttribute("id") === attrId; + return elem.getAttribute( "id" ) === attrId; }; }; } else { - Expr.find["ID"] = function( id, context ) { + Expr.find[ "ID" ] = function( id, context ) { if ( typeof context.getElementById !== strundefined && !documentIsXML ) { var m = context.getElementById( id ); return m ? - m.id === id || typeof m.getAttributeNode !== strundefined && m.getAttributeNode("id").value === id ? - [m] : + m.id === id || typeof m.getAttributeNode !== strundefined && m.getAttributeNode( "id" ).value === id ? + [ m ] : undefined : []; } }; - Expr.filter["ID"] = function( id ) { + Expr.filter[ "ID" ] = function( id ) { var attrId = id.replace( runescape, funescape ); return function( elem ) { - var node = typeof elem.getAttributeNode !== strundefined && elem.getAttributeNode("id"); + var node = typeof elem.getAttributeNode !== strundefined && elem.getAttributeNode( "id" ); return node && node.value === attrId; }; }; } // Tag - Expr.find["TAG"] = support.tagNameNoComments ? + Expr.find[ "TAG" ] = support.tagNameNoComments ? function( tag, context ) { if ( typeof context.getElementsByTagName !== strundefined ) { return context.getElementsByTagName( tag ); @@ -4146,7 +4286,7 @@ setDocument = Sizzle.setDocument = function( node ) { // Filter out possible comments if ( tag === "*" ) { - while ( (elem = results[i++]) ) { + while ( ( elem = results[ i++ ] ) ) { if ( elem.nodeType === 1 ) { tmp.push( elem ); } @@ -4158,14 +4298,14 @@ setDocument = Sizzle.setDocument = function( node ) { }; // Name - Expr.find["NAME"] = support.getByName && function( tag, context ) { + Expr.find[ "NAME" ] = support.getByName && function( tag, context ) { if ( typeof context.getElementsByName !== strundefined ) { return context.getElementsByName( name ); } }; // Class - Expr.find["CLASS"] = support.getByClassName && function( className, context ) { + Expr.find[ "CLASS" ] = support.getByClassName && function( className, context ) { if ( typeof context.getElementsByClassName !== strundefined && !documentIsXML ) { return context.getElementsByClassName( className ); } @@ -4181,10 +4321,12 @@ setDocument = Sizzle.setDocument = function( node ) { // A support test would require too much code (would include document ready) rbuggyQSA = [ ":focus" ]; - if ( (support.qsa = isNative(doc.querySelectorAll)) ) { + if ( ( support.qsa = isNative( doc.querySelectorAll ) ) ) { + // Build QSA regex // Regex strategy adopted from Diego Perini - assert(function( div ) { + assert( function( div ) { + // Select is set to empty string on purpose // This is to test IE's treatment of not explictly // setting a boolean content attribute, @@ -4193,46 +4335,47 @@ setDocument = Sizzle.setDocument = function( node ) { div.innerHTML = "<select><option selected=''></option></select>"; // IE8 - Some boolean attributes are not treated correctly - if ( !div.querySelectorAll("[selected]").length ) { + if ( !div.querySelectorAll( "[selected]" ).length ) { rbuggyQSA.push( "\\[" + whitespace + "*(?:checked|disabled|ismap|multiple|readonly|selected|value)" ); } // Webkit/Opera - :checked should return selected option elements // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked // IE8 throws error here and will not see later tests - if ( !div.querySelectorAll(":checked").length ) { - rbuggyQSA.push(":checked"); + if ( !div.querySelectorAll( ":checked" ).length ) { + rbuggyQSA.push( ":checked" ); } - }); + } ); - assert(function( div ) { + assert( function( div ) { // Opera 10-12/IE8 - ^= $= *= and empty values // Should not select anything div.innerHTML = "<input type='hidden' i=''/>"; - if ( div.querySelectorAll("[i^='']").length ) { + if ( div.querySelectorAll( "[i^='']" ).length ) { rbuggyQSA.push( "[*^$]=" + whitespace + "*(?:\"\"|'')" ); } // FF 3.5 - :enabled/:disabled and hidden elements (hidden elements are still enabled) // IE8 throws error here and will not see later tests - if ( !div.querySelectorAll(":enabled").length ) { + if ( !div.querySelectorAll( ":enabled" ).length ) { rbuggyQSA.push( ":enabled", ":disabled" ); } // Opera 10-11 does not throw on post-comma invalid pseudos - div.querySelectorAll("*,:x"); - rbuggyQSA.push(",.*:"); - }); + div.querySelectorAll( "*,:x" ); + rbuggyQSA.push( ",.*:" ); + } ); } - if ( (support.matchesSelector = isNative( (matches = docElem.matchesSelector || + if ( ( support.matchesSelector = isNative( ( matches = docElem.matchesSelector || docElem.mozMatchesSelector || docElem.webkitMatchesSelector || docElem.oMatchesSelector || - docElem.msMatchesSelector) )) ) { + docElem.msMatchesSelector ) ) ) ) { + + assert( function( div ) { - assert(function( div ) { // Check to see if it's possible to do matchesSelector // on a disconnected node (IE 9) support.disconnectedMatch = matches.call( div, "div" ); @@ -4241,16 +4384,16 @@ setDocument = Sizzle.setDocument = function( node ) { // Gecko does not error, returns false instead matches.call( div, "[s!='']:x" ); rbuggyMatches.push( "!=", pseudos ); - }); + } ); } - rbuggyQSA = new RegExp( rbuggyQSA.join("|") ); - rbuggyMatches = new RegExp( rbuggyMatches.join("|") ); + rbuggyQSA = new RegExp( rbuggyQSA.join( "|" ) ); + rbuggyMatches = new RegExp( rbuggyMatches.join( "|" ) ); // Element contains another // Purposefully does not implement inclusive descendent // As in, an element does not contain itself - contains = isNative(docElem.contains) || docElem.compareDocumentPosition ? + contains = isNative( docElem.contains ) || docElem.compareDocumentPosition ? function( a, b ) { var adown = a.nodeType === 9 ? a.documentElement : a, bup = b && b.parentNode; @@ -4258,11 +4401,11 @@ setDocument = Sizzle.setDocument = function( node ) { adown.contains ? adown.contains( bup ) : a.compareDocumentPosition && a.compareDocumentPosition( bup ) & 16 - )); + ) ); } : function( a, b ) { if ( b ) { - while ( (b = b.parentNode) ) { + while ( ( b = b.parentNode ) ) { if ( b === a ) { return true; } @@ -4281,7 +4424,7 @@ setDocument = Sizzle.setDocument = function( node ) { return 0; } - if ( (compare = b.compareDocumentPosition && a.compareDocumentPosition && a.compareDocumentPosition( b )) ) { + if ( ( compare = b.compareDocumentPosition && a.compareDocumentPosition && a.compareDocumentPosition( b ) ) ) { if ( compare & 1 || a.parentNode && a.parentNode.nodeType === 11 ) { if ( a === doc || contains( preferredDoc, a ) ) { return -1; @@ -4324,33 +4467,34 @@ setDocument = Sizzle.setDocument = function( node ) { // Otherwise we need full lists of their ancestors for comparison cur = a; - while ( (cur = cur.parentNode) ) { + while ( ( cur = cur.parentNode ) ) { ap.unshift( cur ); } cur = b; - while ( (cur = cur.parentNode) ) { + while ( ( cur = cur.parentNode ) ) { bp.unshift( cur ); } // Walk down the tree looking for a discrepancy - while ( ap[i] === bp[i] ) { + while ( ap[ i ] === bp[ i ] ) { i++; } return i ? + // Do a sibling check if the nodes have a common ancestor - siblingCheck( ap[i], bp[i] ) : + siblingCheck( ap[ i ], bp[ i ] ) : // Otherwise nodes in our document sort first - ap[i] === preferredDoc ? -1 : - bp[i] === preferredDoc ? 1 : + ap[ i ] === preferredDoc ? -1 : + bp[ i ] === preferredDoc ? 1 : 0; }; // Always assume the presence of duplicates if sort doesn't // pass them to our comparison function (as in Google Chrome). hasDuplicate = false; - [0, 0].sort( sortOrder ); + [ 0, 0 ].sort( sortOrder ); support.detectDuplicates = hasDuplicate; return document; @@ -4361,6 +4505,7 @@ Sizzle.matches = function( expr, elements ) { }; Sizzle.matchesSelector = function( elem, expr ) { + // Set document vars if needed if ( ( elem.ownerDocument || elem ) !== document ) { setDocument( elem ); @@ -4370,24 +4515,26 @@ Sizzle.matchesSelector = function( elem, expr ) { expr = expr.replace( rattributeQuotes, "='$1']" ); // rbuggyQSA always contains :focus, so no need for an existence check - if ( support.matchesSelector && !documentIsXML && (!rbuggyMatches || !rbuggyMatches.test(expr)) && !rbuggyQSA.test(expr) ) { + if ( support.matchesSelector && !documentIsXML && ( !rbuggyMatches || !rbuggyMatches.test( expr ) ) && !rbuggyQSA.test( expr ) ) { try { var ret = matches.call( elem, expr ); // IE 9's matchesSelector returns false on disconnected nodes if ( ret || support.disconnectedMatch || + // As well, disconnected nodes are said to be in a document // fragment in IE 9 elem.document && elem.document.nodeType !== 11 ) { return ret; } - } catch(e) {} + } catch ( e ) {} } - return Sizzle( expr, document, null, [elem] ).length > 0; + return Sizzle( expr, document, null, [ elem ] ).length > 0; }; Sizzle.contains = function( context, elem ) { + // Set document vars if needed if ( ( context.ownerDocument || context ) !== document ) { setDocument( context ); @@ -4406,13 +4553,13 @@ Sizzle.attr = function( elem, name ) { if ( !documentIsXML ) { name = name.toLowerCase(); } - if ( (val = Expr.attrHandle[ name ]) ) { + if ( ( val = Expr.attrHandle[ name ] ) ) { return val( elem ); } if ( documentIsXML || support.attributes ) { return elem.getAttribute( name ); } - return ( (val = elem.getAttributeNode( name )) || elem.getAttribute( name ) ) && elem[ name ] === true ? + return ( ( val = elem.getAttributeNode( name ) ) || elem.getAttribute( name ) ) && elem[ name ] === true ? name : val && val.specified ? val.value : null; }; @@ -4433,7 +4580,7 @@ Sizzle.uniqueSort = function( results ) { results.sort( sortOrder ); if ( hasDuplicate ) { - for ( ; (elem = results[i]); i++ ) { + for ( ; ( elem = results[ i ] ); i++ ) { if ( elem === results[ i - 1 ] ) { j = duplicates.push( i ); } @@ -4457,7 +4604,7 @@ function siblingCheck( a, b ) { // Check if b follows a if ( cur ) { - while ( (cur = cur.nextSibling) ) { + while ( ( cur = cur.nextSibling ) ) { if ( cur === b ) { return -1; } @@ -4479,27 +4626,27 @@ function createInputPseudo( type ) { function createButtonPseudo( type ) { return function( elem ) { var name = elem.nodeName.toLowerCase(); - return (name === "input" || name === "button") && elem.type === type; + return ( name === "input" || name === "button" ) && elem.type === type; }; } // Returns a function to use in pseudos for positionals function createPositionalPseudo( fn ) { - return markFunction(function( argument ) { + return markFunction( function( argument ) { argument = +argument; - return markFunction(function( seed, matches ) { + return markFunction( function( seed, matches ) { var j, matchIndexes = fn( [], seed.length, argument ), i = matchIndexes.length; // Match elements found at the specified indexes while ( i-- ) { - if ( seed[ (j = matchIndexes[i]) ] ) { - seed[j] = !(matches[j] = seed[j]); + if ( seed[ ( j = matchIndexes[ i ] ) ] ) { + seed[ j ] = !( matches[ j ] = seed[ j ] ); } } - }); - }); + } ); + } ); } /** @@ -4513,17 +4660,21 @@ getText = Sizzle.getText = function( elem ) { nodeType = elem.nodeType; if ( !nodeType ) { + // If no nodeType, this is expected to be an array - for ( ; (node = elem[i]); i++ ) { + for ( ; ( node = elem[ i ] ); i++ ) { + // Do not traverse comment nodes ret += getText( node ); } } else if ( nodeType === 1 || nodeType === 9 || nodeType === 11 ) { + // Use textContent for elements // innerText usage removed for consistency of new lines (see #11153) if ( typeof elem.textContent === "string" ) { return elem.textContent; } else { + // Traverse its children for ( elem = elem.firstChild; elem; elem = elem.nextSibling ) { ret += getText( elem ); @@ -4532,6 +4683,7 @@ getText = Sizzle.getText = function( elem ) { } else if ( nodeType === 3 || nodeType === 4 ) { return elem.nodeValue; } + // Do not include comment or processing instruction nodes return ret; @@ -4557,13 +4709,13 @@ Expr = Sizzle.selectors = { preFilter: { "ATTR": function( match ) { - match[1] = match[1].replace( runescape, funescape ); + match[ 1 ] = match[ 1 ].replace( runescape, funescape ); // Move the given value to match[3] whether quoted or unquoted - match[3] = ( match[4] || match[5] || "" ).replace( runescape, funescape ); + match[ 3 ] = ( match[ 4 ] || match[ 5 ] || "" ).replace( runescape, funescape ); - if ( match[2] === "~=" ) { - match[3] = " " + match[3] + " "; + if ( match[ 2 ] === "~=" ) { + match[ 3 ] = " " + match[ 3 ] + " "; } return match.slice( 0, 4 ); @@ -4580,22 +4732,23 @@ Expr = Sizzle.selectors = { 7 sign of y-component 8 y of y-component */ - match[1] = match[1].toLowerCase(); + match[ 1 ] = match[ 1 ].toLowerCase(); + + if ( match[ 1 ].slice( 0, 3 ) === "nth" ) { - if ( match[1].slice( 0, 3 ) === "nth" ) { // nth-* requires argument - if ( !match[3] ) { - Sizzle.error( match[0] ); + if ( !match[ 3 ] ) { + Sizzle.error( match[ 0 ] ); } // numeric x and y parameters for Expr.filter.CHILD // remember that false/true cast respectively to 0/1 - match[4] = +( match[4] ? match[5] + (match[6] || 1) : 2 * ( match[3] === "even" || match[3] === "odd" ) ); - match[5] = +( ( match[7] + match[8] ) || match[3] === "odd" ); + match[ 4 ] = +( match[ 4 ] ? match[ 5 ] + ( match[ 6 ] || 1 ) : 2 * ( match[ 3 ] === "even" || match[ 3 ] === "odd" ) ); + match[ 5 ] = +( ( match[ 7 ] + match[ 8 ] ) || match[ 3 ] === "odd" ); // other types prohibit arguments - } else if ( match[3] ) { - Sizzle.error( match[0] ); + } else if ( match[ 3 ] ) { + Sizzle.error( match[ 0 ] ); } return match; @@ -4603,26 +4756,28 @@ Expr = Sizzle.selectors = { "PSEUDO": function( match ) { var excess, - unquoted = !match[5] && match[2]; + unquoted = !match[ 5 ] && match[ 2 ]; - if ( matchExpr["CHILD"].test( match[0] ) ) { + if ( matchExpr[ "CHILD" ].test( match[ 0 ] ) ) { return null; } // Accept quoted arguments as-is - if ( match[4] ) { - match[2] = match[4]; + if ( match[ 4 ] ) { + match[ 2 ] = match[ 4 ]; // Strip excess characters from unquoted arguments } else if ( unquoted && rpseudo.test( unquoted ) && + // Get excess from tokenize (recursively) - (excess = tokenize( unquoted, true )) && + ( excess = tokenize( unquoted, true ) ) && + // advance to the next closing parenthesis - (excess = unquoted.indexOf( ")", unquoted.length - excess ) - unquoted.length) ) { + ( excess = unquoted.indexOf( ")", unquoted.length - excess ) - unquoted.length ) ) { // excess is a negative index - match[0] = match[0].slice( 0, excess ); - match[2] = unquoted.slice( 0, excess ); + match[ 0 ] = match[ 0 ].slice( 0, excess ); + match[ 2 ] = unquoted.slice( 0, excess ); } // Return only captures needed by the pseudo filter method (type and argument) @@ -4647,10 +4802,10 @@ Expr = Sizzle.selectors = { var pattern = classCache[ className + " " ]; return pattern || - (pattern = new RegExp( "(^|" + whitespace + ")" + className + "(" + whitespace + "|$)" )) && + ( pattern = new RegExp( "(^|" + whitespace + ")" + className + "(" + whitespace + "|$)" ) ) && classCache( className, function( elem ) { - return pattern.test( elem.className || (typeof elem.getAttribute !== strundefined && elem.getAttribute("class")) || "" ); - }); + return pattern.test( elem.className || ( typeof elem.getAttribute !== strundefined && elem.getAttribute( "class" ) ) || "" ); + } ); }, "ATTR": function( name, operator, check ) { @@ -4702,11 +4857,12 @@ Expr = Sizzle.selectors = { if ( simple ) { while ( dir ) { node = elem; - while ( (node = node[ dir ]) ) { + while ( ( node = node[ dir ] ) ) { if ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) { return false; } } + // Reverse direction for :only-* (if we haven't yet done so) start = dir = type === "only" && !start && "nextSibling"; } @@ -4717,17 +4873,18 @@ Expr = Sizzle.selectors = { // non-xml :nth-child(...) stores cache data on `parent` if ( forward && useCache ) { + // Seek `elem` from a previously-cached index - outerCache = parent[ expando ] || (parent[ expando ] = {}); + outerCache = parent[ expando ] || ( parent[ expando ] = {} ); cache = outerCache[ type ] || []; - nodeIndex = cache[0] === dirruns && cache[1]; - diff = cache[0] === dirruns && cache[2]; + nodeIndex = cache[ 0 ] === dirruns && cache[ 1 ]; + diff = cache[ 0 ] === dirruns && cache[ 2 ]; node = nodeIndex && parent.childNodes[ nodeIndex ]; - while ( (node = ++nodeIndex && node && node[ dir ] || + while ( ( node = ++nodeIndex && node && node[ dir ] || // Fallback to seeking `elem` from the start - (diff = nodeIndex = 0) || start.pop()) ) { + ( diff = nodeIndex = 0 ) || start.pop() ) ) { // When found, cache indexes on `parent` and break if ( node.nodeType === 1 && ++diff && node === elem ) { @@ -4737,19 +4894,21 @@ Expr = Sizzle.selectors = { } // Use previously-cached element index if available - } else if ( useCache && (cache = (elem[ expando ] || (elem[ expando ] = {}))[ type ]) && cache[0] === dirruns ) { - diff = cache[1]; + } else if ( useCache && ( cache = ( elem[ expando ] || ( elem[ expando ] = {} ) )[ type ] ) && cache[ 0 ] === dirruns ) { + diff = cache[ 1 ]; // xml :nth-child(...) or :nth-last-child(...) or :nth(-last)?-of-type(...) } else { + // Use the same loop as above to seek `elem` from the start - while ( (node = ++nodeIndex && node && node[ dir ] || - (diff = nodeIndex = 0) || start.pop()) ) { + while ( ( node = ++nodeIndex && node && node[ dir ] || + ( diff = nodeIndex = 0 ) || start.pop() ) ) { if ( ( ofType ? node.nodeName.toLowerCase() === name : node.nodeType === 1 ) && ++diff ) { + // Cache the index of each encountered element if ( useCache ) { - (node[ expando ] || (node[ expando ] = {}))[ type ] = [ dirruns, diff ]; + ( node[ expando ] || ( node[ expando ] = {} ) )[ type ] = [ dirruns, diff ]; } if ( node === elem ) { @@ -4767,6 +4926,7 @@ Expr = Sizzle.selectors = { }, "PSEUDO": function( pseudo, argument ) { + // pseudo-class names are case-insensitive // http://www.w3.org/TR/selectors/#pseudo-classes // Prioritize by case sensitivity in case custom pseudos are added with uppercase letters @@ -4786,15 +4946,15 @@ Expr = Sizzle.selectors = { if ( fn.length > 1 ) { args = [ pseudo, pseudo, "", argument ]; return Expr.setFilters.hasOwnProperty( pseudo.toLowerCase() ) ? - markFunction(function( seed, matches ) { + markFunction( function( seed, matches ) { var idx, matched = fn( seed, argument ), i = matched.length; while ( i-- ) { - idx = indexOf.call( seed, matched[i] ); - seed[ idx ] = !( matches[ idx ] = matched[i] ); + idx = indexOf.call( seed, matched[ i ] ); + seed[ idx ] = !( matches[ idx ] = matched[ i ] ); } - }) : + } ) : function( elem ) { return fn( elem, 0, args ); }; @@ -4805,8 +4965,10 @@ Expr = Sizzle.selectors = { }, pseudos: { + // Potentially complex pseudos - "not": markFunction(function( selector ) { + "not": markFunction( function( selector ) { + // Trim the selector passed to compile // to avoid treating leading and trailing // spaces as combinators @@ -4815,36 +4977,36 @@ Expr = Sizzle.selectors = { matcher = compile( selector.replace( rtrim, "$1" ) ); return matcher[ expando ] ? - markFunction(function( seed, matches, context, xml ) { + markFunction( function( seed, matches, context, xml ) { var elem, unmatched = matcher( seed, null, xml, [] ), i = seed.length; // Match elements unmatched by `matcher` while ( i-- ) { - if ( (elem = unmatched[i]) ) { - seed[i] = !(matches[i] = elem); + if ( ( elem = unmatched[ i ] ) ) { + seed[ i ] = !( matches[ i ] = elem ); } } - }) : + } ) : function( elem, context, xml ) { - input[0] = elem; + input[ 0 ] = elem; matcher( input, null, xml, results ); return !results.pop(); }; - }), + } ), - "has": markFunction(function( selector ) { + "has": markFunction( function( selector ) { return function( elem ) { return Sizzle( selector, elem ).length > 0; }; - }), + } ), - "contains": markFunction(function( text ) { + "contains": markFunction( function( text ) { return function( elem ) { return ( elem.textContent || elem.innerText || getText( elem ) ).indexOf( text ) > -1; }; - }), + } ), // "Whether an element is represented by a :lang() selector // is based solely on the element's language value @@ -4854,25 +5016,26 @@ Expr = Sizzle.selectors = { // The identifier C does not have to be a valid language name." // http://www.w3.org/TR/selectors/#lang-pseudo "lang": markFunction( function( lang ) { + // lang value must be a valid identifider - if ( !ridentifier.test(lang || "") ) { + if ( !ridentifier.test( lang || "" ) ) { Sizzle.error( "unsupported lang: " + lang ); } lang = lang.replace( runescape, funescape ).toLowerCase(); return function( elem ) { var elemLang; do { - if ( (elemLang = documentIsXML ? - elem.getAttribute("xml:lang") || elem.getAttribute("lang") : - elem.lang) ) { + if ( ( elemLang = documentIsXML ? + elem.getAttribute( "xml:lang" ) || elem.getAttribute( "lang" ) : + elem.lang ) ) { elemLang = elemLang.toLowerCase(); return elemLang === lang || elemLang.indexOf( lang + "-" ) === 0; } - } while ( (elem = elem.parentNode) && elem.nodeType === 1 ); + } while ( ( elem = elem.parentNode ) && elem.nodeType === 1 ); return false; }; - }), + } ), // Miscellaneous "target": function( elem ) { @@ -4885,7 +5048,7 @@ Expr = Sizzle.selectors = { }, "focus": function( elem ) { - return elem === document.activeElement && (!document.hasFocus || document.hasFocus()) && !!(elem.type || elem.href || ~elem.tabIndex); + return elem === document.activeElement && ( !document.hasFocus || document.hasFocus() ) && !!( elem.type || elem.href || ~elem.tabIndex ); }, // Boolean properties @@ -4898,13 +5061,15 @@ Expr = Sizzle.selectors = { }, "checked": function( elem ) { + // In CSS3, :checked should return both checked and selected elements // http://www.w3.org/TR/2011/REC-css3-selectors-20110929/#checked var nodeName = elem.nodeName.toLowerCase(); - return (nodeName === "input" && !!elem.checked) || (nodeName === "option" && !!elem.selected); + return ( nodeName === "input" && !!elem.checked ) || ( nodeName === "option" && !!elem.selected ); }, "selected": function( elem ) { + // Accessing this property makes selected-by-default // options in Safari work properly if ( elem.parentNode ) { @@ -4916,6 +5081,7 @@ Expr = Sizzle.selectors = { // Contents "empty": function( elem ) { + // http://www.w3.org/TR/selectors/#empty-pseudo // :empty is only affected by element nodes and content nodes(including text(3), cdata(4)), // not comment, processing instructions, or others @@ -4930,7 +5096,7 @@ Expr = Sizzle.selectors = { }, "parent": function( elem ) { - return !Expr.pseudos["empty"]( elem ); + return !Expr.pseudos[ "empty" ]( elem ); }, // Element/input types @@ -4949,57 +5115,58 @@ Expr = Sizzle.selectors = { "text": function( elem ) { var attr; + // IE6 and 7 will map elem.type to 'text' for new HTML5 types (search, etc) // use getAttribute instead to test this case return elem.nodeName.toLowerCase() === "input" && elem.type === "text" && - ( (attr = elem.getAttribute("type")) == null || attr.toLowerCase() === elem.type ); + ( ( attr = elem.getAttribute( "type" ) ) == null || attr.toLowerCase() === elem.type ); }, // Position-in-collection - "first": createPositionalPseudo(function() { + "first": createPositionalPseudo( function() { return [ 0 ]; - }), + } ), - "last": createPositionalPseudo(function( matchIndexes, length ) { + "last": createPositionalPseudo( function( matchIndexes, length ) { return [ length - 1 ]; - }), + } ), - "eq": createPositionalPseudo(function( matchIndexes, length, argument ) { + "eq": createPositionalPseudo( function( matchIndexes, length, argument ) { return [ argument < 0 ? argument + length : argument ]; - }), + } ), - "even": createPositionalPseudo(function( matchIndexes, length ) { + "even": createPositionalPseudo( function( matchIndexes, length ) { var i = 0; for ( ; i < length; i += 2 ) { matchIndexes.push( i ); } return matchIndexes; - }), + } ), - "odd": createPositionalPseudo(function( matchIndexes, length ) { + "odd": createPositionalPseudo( function( matchIndexes, length ) { var i = 1; for ( ; i < length; i += 2 ) { matchIndexes.push( i ); } return matchIndexes; - }), + } ), - "lt": createPositionalPseudo(function( matchIndexes, length, argument ) { + "lt": createPositionalPseudo( function( matchIndexes, length, argument ) { var i = argument < 0 ? argument + length : argument; for ( ; --i >= 0; ) { matchIndexes.push( i ); } return matchIndexes; - }), + } ), - "gt": createPositionalPseudo(function( matchIndexes, length, argument ) { + "gt": createPositionalPseudo( function( matchIndexes, length, argument ) { var i = argument < 0 ? argument + length : argument; for ( ; ++i < length; ) { matchIndexes.push( i ); } return matchIndexes; - }) + } ) } }; @@ -5027,10 +5194,11 @@ function tokenize( selector, parseOnly ) { while ( soFar ) { // Comma and first run - if ( !matched || (match = rcomma.exec( soFar )) ) { + if ( !matched || ( match = rcomma.exec( soFar ) ) ) { if ( match ) { + // Don't consume trailing commas as valid - soFar = soFar.slice( match[0].length ) || soFar; + soFar = soFar.slice( match[ 0 ].length ) || soFar; } groups.push( tokens = [] ); } @@ -5038,20 +5206,21 @@ function tokenize( selector, parseOnly ) { matched = false; // Combinators - if ( (match = rcombinators.exec( soFar )) ) { + if ( ( match = rcombinators.exec( soFar ) ) ) { matched = match.shift(); tokens.push( { value: matched, + // Cast descendant combinators to space - type: match[0].replace( rtrim, " " ) + type: match[ 0 ].replace( rtrim, " " ) } ); soFar = soFar.slice( matched.length ); } // Filters for ( type in Expr.filter ) { - if ( (match = matchExpr[ type ].exec( soFar )) && (!preFilters[ type ] || - (match = preFilters[ type ]( match ))) ) { + if ( ( match = matchExpr[ type ].exec( soFar ) ) && ( !preFilters[ type ] || + ( match = preFilters[ type ]( match ) ) ) ) { matched = match.shift(); tokens.push( { value: matched, @@ -5074,6 +5243,7 @@ function tokenize( selector, parseOnly ) { soFar.length : soFar ? Sizzle.error( selector ) : + // Cache the tokens tokenCache( selector, groups ).slice( 0 ); } @@ -5083,7 +5253,7 @@ function toSelector( tokens ) { len = tokens.length, selector = ""; for ( ; i < len; i++ ) { - selector += tokens[i].value; + selector += tokens[ i ].value; } return selector; } @@ -5094,9 +5264,10 @@ function addCombinator( matcher, combinator, base ) { doneName = done++; return combinator.first ? + // Check against closest ancestor/preceding element function( elem, context, xml ) { - while ( (elem = elem[ dir ]) ) { + while ( ( elem = elem[ dir ] ) ) { if ( elem.nodeType === 1 || checkNonElements ) { return matcher( elem, context, xml ); } @@ -5110,7 +5281,7 @@ function addCombinator( matcher, combinator, base ) { // We can't set arbitrary data on XML nodes, so they don't benefit from dir caching if ( xml ) { - while ( (elem = elem[ dir ]) ) { + while ( ( elem = elem[ dir ] ) ) { if ( elem.nodeType === 1 || checkNonElements ) { if ( matcher( elem, context, xml ) ) { return true; @@ -5118,17 +5289,17 @@ function addCombinator( matcher, combinator, base ) { } } } else { - while ( (elem = elem[ dir ]) ) { + while ( ( elem = elem[ dir ] ) ) { if ( elem.nodeType === 1 || checkNonElements ) { - outerCache = elem[ expando ] || (elem[ expando ] = {}); - if ( (cache = outerCache[ dir ]) && cache[0] === dirkey ) { - if ( (data = cache[1]) === true || data === cachedruns ) { + outerCache = elem[ expando ] || ( elem[ expando ] = {} ); + if ( ( cache = outerCache[ dir ] ) && cache[ 0 ] === dirkey ) { + if ( ( data = cache[ 1 ] ) === true || data === cachedruns ) { return data === true; } } else { cache = outerCache[ dir ] = [ dirkey ]; - cache[1] = matcher( elem, context, xml ) || cachedruns; - if ( cache[1] === true ) { + cache[ 1 ] = matcher( elem, context, xml ) || cachedruns; + if ( cache[ 1 ] === true ) { return true; } } @@ -5143,13 +5314,13 @@ function elementMatcher( matchers ) { function( elem, context, xml ) { var i = matchers.length; while ( i-- ) { - if ( !matchers[i]( elem, context, xml ) ) { + if ( !matchers[ i ]( elem, context, xml ) ) { return false; } } return true; } : - matchers[0]; + matchers[ 0 ]; } function condense( unmatched, map, filter, context, xml ) { @@ -5160,7 +5331,7 @@ function condense( unmatched, map, filter, context, xml ) { mapped = map != null; for ( ; i < len; i++ ) { - if ( (elem = unmatched[i]) ) { + if ( ( elem = unmatched[ i ] ) ) { if ( !filter || filter( elem, context, xml ) ) { newUnmatched.push( elem ); if ( mapped ) { @@ -5180,7 +5351,7 @@ function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postS if ( postFinder && !postFinder[ expando ] ) { postFinder = setMatcher( postFinder, postSelector ); } - return markFunction(function( seed, results, context, xml ) { + return markFunction( function( seed, results, context, xml ) { var temp, i, elem, preMap = [], postMap = [], @@ -5195,6 +5366,7 @@ function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postS elems, matcherOut = matcher ? + // If we have a postFinder, or filtered seed, or non-seed postFilter or preexisting results, postFinder || ( seed ? preFilter : preexisting || postFilter ) ? @@ -5218,8 +5390,8 @@ function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postS // Un-match failing elements by moving them back to matcherIn i = temp.length; while ( i-- ) { - if ( (elem = temp[i]) ) { - matcherOut[ postMap[i] ] = !(matcherIn[ postMap[i] ] = elem); + if ( ( elem = temp[ i ] ) ) { + matcherOut[ postMap[ i ] ] = !( matcherIn[ postMap[ i ] ] = elem ); } } } @@ -5227,25 +5399,27 @@ function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postS if ( seed ) { if ( postFinder || preFilter ) { if ( postFinder ) { + // Get the final matcherOut by condensing this intermediate into postFinder contexts temp = []; i = matcherOut.length; while ( i-- ) { - if ( (elem = matcherOut[i]) ) { + if ( ( elem = matcherOut[ i ] ) ) { + // Restore matcherIn since elem is not yet a final match - temp.push( (matcherIn[i] = elem) ); + temp.push( ( matcherIn[ i ] = elem ) ); } } - postFinder( null, (matcherOut = []), temp, xml ); + postFinder( null, ( matcherOut = [] ), temp, xml ); } // Move matched elements from seed to results to keep them synchronized i = matcherOut.length; while ( i-- ) { - if ( (elem = matcherOut[i]) && - (temp = postFinder ? indexOf.call( seed, elem ) : preMap[i]) > -1 ) { + if ( ( elem = matcherOut[ i ] ) && + ( temp = postFinder ? indexOf.call( seed, elem ) : preMap[ i ] ) > -1 ) { - seed[temp] = !(results[temp] = elem); + seed[ temp ] = !( results[ temp ] = elem ); } } } @@ -5263,14 +5437,14 @@ function setMatcher( preFilter, selector, matcher, postFilter, postFinder, postS push.apply( results, matcherOut ); } } - }); + } ); } function matcherFromTokens( tokens ) { var checkContext, matcher, j, len = tokens.length, - leadingRelative = Expr.relative[ tokens[0].type ], - implicitRelative = leadingRelative || Expr.relative[" "], + leadingRelative = Expr.relative[ tokens[ 0 ].type ], + implicitRelative = leadingRelative || Expr.relative[ " " ], i = leadingRelative ? 1 : 0, // The foundational matcher ensures that elements are reachable from top-level context(s) @@ -5282,23 +5456,24 @@ function matcherFromTokens( tokens ) { }, implicitRelative, true ), matchers = [ function( elem, context, xml ) { return ( !leadingRelative && ( xml || context !== outermostContext ) ) || ( - (checkContext = context).nodeType ? + ( checkContext = context ).nodeType ? matchContext( elem, context, xml ) : matchAnyContext( elem, context, xml ) ); } ]; for ( ; i < len; i++ ) { - if ( (matcher = Expr.relative[ tokens[i].type ]) ) { - matchers = [ addCombinator(elementMatcher( matchers ), matcher) ]; + if ( ( matcher = Expr.relative[ tokens[ i ].type ] ) ) { + matchers = [ addCombinator( elementMatcher( matchers ), matcher ) ]; } else { - matcher = Expr.filter[ tokens[i].type ].apply( null, tokens[i].matches ); + matcher = Expr.filter[ tokens[ i ].type ].apply( null, tokens[ i ].matches ); // Return special upon seeing a positional matcher if ( matcher[ expando ] ) { + // Find the next relative operator (if any) for proper handling j = ++i; for ( ; j < len; j++ ) { - if ( Expr.relative[ tokens[j].type ] ) { + if ( Expr.relative[ tokens[ j ].type ] ) { break; } } @@ -5307,7 +5482,7 @@ function matcherFromTokens( tokens ) { i > 1 && toSelector( tokens.slice( 0, i - 1 ) ).replace( rtrim, "$1" ), matcher, i < j && matcherFromTokens( tokens.slice( i, j ) ), - j < len && matcherFromTokens( (tokens = tokens.slice( j )) ), + j < len && matcherFromTokens( ( tokens = tokens.slice( j ) ) ), j < len && toSelector( tokens ) ); } @@ -5319,6 +5494,7 @@ function matcherFromTokens( tokens ) { } function matcherFromGroupMatchers( elementMatchers, setMatchers ) { + // A counter to specify which element is currently being matched var matcherCachedRuns = 0, bySet = setMatchers.length > 0, @@ -5331,10 +5507,12 @@ function matcherFromGroupMatchers( elementMatchers, setMatchers ) { unmatched = seed && [], outermost = expandContext != null, contextBackup = outermostContext, + // We must always have either seed elements or context - elems = seed || byElement && Expr.find["TAG"]( "*", expandContext && context.parentNode || context ), + elems = seed || byElement && Expr.find[ "TAG" ]( "*", expandContext && context.parentNode || context ), + // Use integer dirruns iff this is the outermost matcher - dirrunsUnique = (dirruns += contextBackup == null ? 1 : Math.random() || 0.1); + dirrunsUnique = ( dirruns += contextBackup == null ? 1 : Math.random() || 0.1 ); if ( outermost ) { outermostContext = context !== document && context; @@ -5343,10 +5521,10 @@ function matcherFromGroupMatchers( elementMatchers, setMatchers ) { // Add elements passing elementMatchers directly to results // Keep `i` a string if there are no elements so `matchedCount` will be "00" below - for ( ; (elem = elems[i]) != null; i++ ) { + for ( ; ( elem = elems[ i ] ) != null; i++ ) { if ( byElement && elem ) { j = 0; - while ( (matcher = elementMatchers[j++]) ) { + while ( ( matcher = elementMatchers[ j++ ] ) ) { if ( matcher( elem, context, xml ) ) { results.push( elem ); break; @@ -5360,8 +5538,9 @@ function matcherFromGroupMatchers( elementMatchers, setMatchers ) { // Track unmatched elements for set filters if ( bySet ) { + // They will have gone through all possible matchers - if ( (elem = !matcher && elem) ) { + if ( ( elem = !matcher && elem ) ) { matchedCount--; } @@ -5376,16 +5555,17 @@ function matcherFromGroupMatchers( elementMatchers, setMatchers ) { matchedCount += i; if ( bySet && i !== matchedCount ) { j = 0; - while ( (matcher = setMatchers[j++]) ) { + while ( ( matcher = setMatchers[ j++ ] ) ) { matcher( unmatched, setMatched, context, xml ); } if ( seed ) { + // Reintegrate element matches to eliminate the need for sorting if ( matchedCount > 0 ) { while ( i-- ) { - if ( !(unmatched[i] || setMatched[i]) ) { - setMatched[i] = pop.call( results ); + if ( !( unmatched[ i ] || setMatched[ i ] ) ) { + setMatched[ i ] = pop.call( results ); } } } @@ -5426,13 +5606,14 @@ compile = Sizzle.compile = function( selector, group /* Internal Use Only */ ) { cached = compilerCache[ selector + " " ]; if ( !cached ) { + // Generate a function of recursive functions that can be used to check each element if ( !group ) { group = tokenize( selector ); } i = group.length; while ( i-- ) { - cached = matcherFromTokens( group[i] ); + cached = matcherFromTokens( group[ i ] ); if ( cached[ expando ] ) { setMatchers.push( cached ); } else { @@ -5450,7 +5631,7 @@ function multipleContexts( selector, contexts, results ) { var i = 0, len = contexts.length; for ( ; i < len; i++ ) { - Sizzle( selector, contexts[i], results ); + Sizzle( selector, contexts[ i ], results ); } return results; } @@ -5460,16 +5641,17 @@ function select( selector, context, results, seed ) { match = tokenize( selector ); if ( !seed ) { + // Try to minimize operations if there is only one group if ( match.length === 1 ) { // Take a shortcut and set the context if the root selector is an ID - tokens = match[0] = match[0].slice( 0 ); - if ( tokens.length > 2 && (token = tokens[0]).type === "ID" && + tokens = match[ 0 ] = match[ 0 ].slice( 0 ); + if ( tokens.length > 2 && ( token = tokens[ 0 ] ).type === "ID" && context.nodeType === 9 && !documentIsXML && - Expr.relative[ tokens[1].type ] ) { + Expr.relative[ tokens[ 1 ].type ] ) { - context = Expr.find["ID"]( token.matches[0].replace( runescape, funescape ), context )[0]; + context = Expr.find[ "ID" ]( token.matches[ 0 ].replace( runescape, funescape ), context )[ 0 ]; if ( !context ) { return results; } @@ -5478,20 +5660,21 @@ function select( selector, context, results, seed ) { } // Fetch a seed set for right-to-left matching - i = matchExpr["needsContext"].test( selector ) ? 0 : tokens.length; + i = matchExpr[ "needsContext" ].test( selector ) ? 0 : tokens.length; while ( i-- ) { - token = tokens[i]; + token = tokens[ i ]; // Abort if we hit a combinator - if ( Expr.relative[ (type = token.type) ] ) { + if ( Expr.relative[ ( type = token.type ) ] ) { break; } - if ( (find = Expr.find[ type ]) ) { + if ( ( find = Expr.find[ type ] ) ) { + // Search, expanding context for leading sibling combinators - if ( (seed = find( - token.matches[0].replace( runescape, funescape ), - rsibling.test( tokens[0].type ) && context.parentNode || context - )) ) { + if ( ( seed = find( + token.matches[ 0 ].replace( runescape, funescape ), + rsibling.test( tokens[ 0 ].type ) && context.parentNode || context + ) ) ) { // If seed is empty or no tokens remain, we can return early tokens.splice( i, 1 ); @@ -5521,7 +5704,7 @@ function select( selector, context, results, seed ) { } // Deprecated -Expr.pseudos["nth"] = Expr.pseudos["eq"]; +Expr.pseudos[ "nth" ] = Expr.pseudos[ "eq" ]; // Easy API for creating new setFilters function setFilters() {} @@ -5535,18 +5718,18 @@ setDocument(); Sizzle.attr = jQuery.attr; jQuery.find = Sizzle; jQuery.expr = Sizzle.selectors; -jQuery.expr[":"] = jQuery.expr.pseudos; +jQuery.expr[ ":" ] = jQuery.expr.pseudos; jQuery.unique = Sizzle.uniqueSort; jQuery.text = Sizzle.getText; jQuery.isXMLDoc = Sizzle.isXML; jQuery.contains = Sizzle.contains; - -})( window ); +} )( window ); var runtil = /Until$/, rparentsprev = /^(?:parents|prev(?:Until|All))/, isSimple = /^.[^:#\[\.,]*$/, rneedsContext = jQuery.expr.match.needsContext, + // methods guaranteed to produce a unique set when starting from a unique set guaranteedUnique = { children: true, @@ -5555,20 +5738,20 @@ var runtil = /Until$/, prev: true }; -jQuery.fn.extend({ +jQuery.fn.extend( { find: function( selector ) { var i, ret, self, len = this.length; if ( typeof selector !== "string" ) { self = this; - return this.pushStack( jQuery( selector ).filter(function() { + return this.pushStack( jQuery( selector ).filter( function() { for ( i = 0; i < len; i++ ) { if ( jQuery.contains( self[ i ], this ) ) { return true; } } - }) ); + } ) ); } ret = []; @@ -5587,30 +5770,31 @@ jQuery.fn.extend({ targets = jQuery( target, this ), len = targets.length; - return this.filter(function() { + return this.filter( function() { for ( i = 0; i < len; i++ ) { - if ( jQuery.contains( this, targets[i] ) ) { + if ( jQuery.contains( this, targets[ i ] ) ) { return true; } } - }); + } ); }, not: function( selector ) { - return this.pushStack( winnow(this, selector, false) ); + return this.pushStack( winnow( this, selector, false ) ); }, filter: function( selector ) { - return this.pushStack( winnow(this, selector, true) ); + return this.pushStack( winnow( this, selector, true ) ); }, is: function( selector ) { return !!selector && ( typeof selector === "string" ? + // If this is a positional/relative selector, check membership in the returned set // so $("p:first").is("p:last") won't return true for a doc with two "p". rneedsContext.test( selector ) ? - jQuery( selector, this.context ).index( this[0] ) >= 0 : + jQuery( selector, this.context ).index( this[ 0 ] ) >= 0 : jQuery.filter( selector, this ).length > 0 : this.filter( selector ).length > 0 ); }, @@ -5625,10 +5809,10 @@ jQuery.fn.extend({ 0; for ( ; i < l; i++ ) { - cur = this[i]; + cur = this[ i ]; while ( cur && cur.ownerDocument && cur !== context && cur.nodeType !== 11 ) { - if ( pos ? pos.index(cur) > -1 : jQuery.find.matchesSelector(cur, selectors) ) { + if ( pos ? pos.index( cur ) > -1 : jQuery.find.matchesSelector( cur, selectors ) ) { ret.push( cur ); break; } @@ -5645,18 +5829,19 @@ jQuery.fn.extend({ // No argument, return index in parent if ( !elem ) { - return ( this[0] && this[0].parentNode ) ? this.first().prevAll().length : -1; + return ( this[ 0 ] && this[ 0 ].parentNode ) ? this.first().prevAll().length : -1; } // index in selector if ( typeof elem === "string" ) { - return jQuery.inArray( this[0], jQuery( elem ) ); + return jQuery.inArray( this[ 0 ], jQuery( elem ) ); } // Locate the position of the desired element return jQuery.inArray( + // If it receives a jQuery object, the first element is used - elem.jquery ? elem[0] : elem, this ); + elem.jquery ? elem[ 0 ] : elem, this ); }, add: function( selector, context ) { @@ -5665,15 +5850,15 @@ jQuery.fn.extend({ jQuery.makeArray( selector && selector.nodeType ? [ selector ] : selector ), all = jQuery.merge( this.get(), set ); - return this.pushStack( jQuery.unique(all) ); + return this.pushStack( jQuery.unique( all ) ); }, addBack: function( selector ) { return this.add( selector == null ? - this.prevObject : this.prevObject.filter(selector) + this.prevObject : this.prevObject.filter( selector ) ); } -}); +} ); jQuery.fn.andSelf = jQuery.fn.addBack; @@ -5685,7 +5870,7 @@ function sibling( cur, dir ) { return cur; } -jQuery.each({ +jQuery.each( { parent: function( elem ) { var parent = elem.parentNode; return parent && parent.nodeType !== 11 ? parent : null; @@ -5745,28 +5930,28 @@ jQuery.each({ return this.pushStack( ret ); }; -}); +} ); -jQuery.extend({ +jQuery.extend( { filter: function( expr, elems, not ) { if ( not ) { expr = ":not(" + expr + ")"; } return elems.length === 1 ? - jQuery.find.matchesSelector(elems[0], expr) ? [ elems[0] ] : [] : - jQuery.find.matches(expr, elems); + jQuery.find.matchesSelector( elems[ 0 ], expr ) ? [ elems[ 0 ] ] : [] : + jQuery.find.matches( expr, elems ); }, dir: function( elem, dir, until ) { var matched = [], cur = elem[ dir ]; - while ( cur && cur.nodeType !== 9 && (until === undefined || cur.nodeType !== 1 || !jQuery( cur ).is( until )) ) { + while ( cur && cur.nodeType !== 9 && ( until === undefined || cur.nodeType !== 1 || !jQuery( cur ).is( until ) ) ) { if ( cur.nodeType === 1 ) { matched.push( cur ); } - cur = cur[dir]; + cur = cur[ dir ]; } return matched; }, @@ -5782,7 +5967,7 @@ jQuery.extend({ return r; } -}); +} ); // Implement the identical functionality for filter and not function winnow( elements, qualifier, keep ) { @@ -5792,31 +5977,31 @@ function winnow( elements, qualifier, keep ) { qualifier = qualifier || 0; if ( jQuery.isFunction( qualifier ) ) { - return jQuery.grep(elements, function( elem, i ) { + return jQuery.grep( elements, function( elem, i ) { var retVal = !!qualifier.call( elem, i, elem ); return retVal === keep; - }); + } ); } else if ( qualifier.nodeType ) { - return jQuery.grep(elements, function( elem ) { + return jQuery.grep( elements, function( elem ) { return ( elem === qualifier ) === keep; - }); + } ); } else if ( typeof qualifier === "string" ) { - var filtered = jQuery.grep(elements, function( elem ) { + var filtered = jQuery.grep( elements, function( elem ) { return elem.nodeType === 1; - }); + } ); if ( isSimple.test( qualifier ) ) { - return jQuery.filter(qualifier, filtered, !keep); + return jQuery.filter( qualifier, filtered, !keep ); } else { qualifier = jQuery.filter( qualifier, filtered ); } } - return jQuery.grep(elements, function( elem ) { + return jQuery.grep( elements, function( elem ) { return ( jQuery.inArray( elem, qualifier ) >= 0 ) === keep; - }); + } ); } function createSafeFragment( document ) { var list = nodeNames.split( "|" ), @@ -5835,7 +6020,7 @@ function createSafeFragment( document ) { var nodeNames = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figcaption|figure|footer|" + "header|hgroup|mark|meter|nav|output|progress|section|summary|time|video", rinlinejQuery = / jQuery\d+="(?:null|\d+)"/g, - rnoshimcache = new RegExp("<(?:" + nodeNames + ")[\\s/>]", "i"), + rnoshimcache = new RegExp( "<(?:" + nodeNames + ")[\\s/>]", "i" ), rleadingWhitespace = /^\s+/, rxhtmlTag = /<(?!area|br|col|embed|hr|img|input|link|meta|param)(([\w:]+)[^>]*)\/>/gi, rtagName = /<([\w:]+)/, @@ -5843,6 +6028,7 @@ var nodeNames = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figca rhtml = /<|&#?\w+;/, rnoInnerhtml = /<(?:script|style|link)/i, manipulation_rcheckableType = /^(?:checkbox|radio)$/i, + // checked="checked" or checked rchecked = /checked\s*(?:[^=]|=\s*.checked.)/i, rscriptType = /^$|\/(?:java|ecma)script/i, @@ -5862,40 +6048,41 @@ var nodeNames = "abbr|article|aside|audio|bdi|canvas|data|datalist|details|figca // IE6-8 can't serialize link, script, style, or any html5 (NoScope) tags, // unless wrapped in a div with non-breaking characters in front of it. - _default: jQuery.support.htmlSerialize ? [ 0, "", "" ] : [ 1, "X<div>", "</div>" ] + _default: jQuery.support.htmlSerialize ? [ 0, "", "" ] : [ 1, "X<div>", "</div>" ] }, safeFragment = createSafeFragment( document ), - fragmentDiv = safeFragment.appendChild( document.createElement("div") ); + fragmentDiv = safeFragment.appendChild( document.createElement( "div" ) ); wrapMap.optgroup = wrapMap.option; wrapMap.tbody = wrapMap.tfoot = wrapMap.colgroup = wrapMap.caption = wrapMap.thead; wrapMap.th = wrapMap.td; -jQuery.fn.extend({ +jQuery.fn.extend( { text: function( value ) { return jQuery.access( this, function( value ) { return value === undefined ? jQuery.text( this ) : - this.empty().append( ( this[0] && this[0].ownerDocument || document ).createTextNode( value ) ); + this.empty().append( ( this[ 0 ] && this[ 0 ].ownerDocument || document ).createTextNode( value ) ); }, null, value, arguments.length ); }, wrapAll: function( html ) { if ( jQuery.isFunction( html ) ) { - return this.each(function(i) { - jQuery(this).wrapAll( html.call(this, i) ); - }); + return this.each( function( i ) { + jQuery( this ).wrapAll( html.call( this, i ) ); + } ); } - if ( this[0] ) { + if ( this[ 0 ] ) { + // The elements to wrap the target around - var wrap = jQuery( html, this[0].ownerDocument ).eq(0).clone(true); + var wrap = jQuery( html, this[ 0 ].ownerDocument ).eq( 0 ).clone( true ); - if ( this[0].parentNode ) { - wrap.insertBefore( this[0] ); + if ( this[ 0 ].parentNode ) { + wrap.insertBefore( this[ 0 ] ); } - wrap.map(function() { + wrap.map( function() { var elem = this; while ( elem.firstChild && elem.firstChild.nodeType === 1 ) { @@ -5903,7 +6090,7 @@ jQuery.fn.extend({ } return elem; - }).append( this ); + } ).append( this ); } return this; @@ -5911,12 +6098,12 @@ jQuery.fn.extend({ wrapInner: function( html ) { if ( jQuery.isFunction( html ) ) { - return this.each(function(i) { - jQuery(this).wrapInner( html.call(this, i) ); - }); + return this.each( function( i ) { + jQuery( this ).wrapInner( html.call( this, i ) ); + } ); } - return this.each(function() { + return this.each( function() { var self = jQuery( this ), contents = self.contents(); @@ -5926,39 +6113,39 @@ jQuery.fn.extend({ } else { self.append( html ); } - }); + } ); }, wrap: function( html ) { var isFunction = jQuery.isFunction( html ); - return this.each(function(i) { - jQuery( this ).wrapAll( isFunction ? html.call(this, i) : html ); - }); + return this.each( function( i ) { + jQuery( this ).wrapAll( isFunction ? html.call( this, i ) : html ); + } ); }, unwrap: function() { - return this.parent().each(function() { + return this.parent().each( function() { if ( !jQuery.nodeName( this, "body" ) ) { jQuery( this ).replaceWith( this.childNodes ); } - }).end(); + } ).end(); }, append: function() { - return this.domManip(arguments, true, function( elem ) { + return this.domManip( arguments, true, function( elem ) { if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { this.appendChild( elem ); } - }); + } ); }, prepend: function() { - return this.domManip(arguments, true, function( elem ) { + return this.domManip( arguments, true, function( elem ) { if ( this.nodeType === 1 || this.nodeType === 11 || this.nodeType === 9 ) { this.insertBefore( elem, this.firstChild ); } - }); + } ); }, before: function() { @@ -5966,7 +6153,7 @@ jQuery.fn.extend({ if ( this.parentNode ) { this.parentNode.insertBefore( elem, this ); } - }); + } ); }, after: function() { @@ -5974,7 +6161,7 @@ jQuery.fn.extend({ if ( this.parentNode ) { this.parentNode.insertBefore( elem, this.nextSibling ); } - }); + } ); }, // keepData is for internal use only--do not document @@ -5982,7 +6169,7 @@ jQuery.fn.extend({ var elem, i = 0; - for ( ; (elem = this[i]) != null; i++ ) { + for ( ; ( elem = this[ i ] ) != null; i++ ) { if ( !selector || jQuery.filter( selector, [ elem ] ).length > 0 ) { if ( !keepData && elem.nodeType === 1 ) { jQuery.cleanData( getAll( elem ) ); @@ -6004,7 +6191,8 @@ jQuery.fn.extend({ var elem, i = 0; - for ( ; (elem = this[i]) != null; i++ ) { + for ( ; ( elem = this[ i ] ) != null; i++ ) { + // Remove element nodes and prevent memory leaks if ( elem.nodeType === 1 ) { jQuery.cleanData( getAll( elem, false ) ); @@ -6029,14 +6217,14 @@ jQuery.fn.extend({ dataAndEvents = dataAndEvents == null ? false : dataAndEvents; deepDataAndEvents = deepDataAndEvents == null ? dataAndEvents : deepDataAndEvents; - return this.map( function () { + return this.map( function() { return jQuery.clone( this, dataAndEvents, deepDataAndEvents ); - }); + } ); }, html: function( value ) { return jQuery.access( this, function( value ) { - var elem = this[0] || {}, + var elem = this[ 0 ] || {}, i = 0, l = this.length; @@ -6050,14 +6238,15 @@ jQuery.fn.extend({ if ( typeof value === "string" && !rnoInnerhtml.test( value ) && ( jQuery.support.htmlSerialize || !rnoshimcache.test( value ) ) && ( jQuery.support.leadingWhitespace || !rleadingWhitespace.test( value ) ) && - !wrapMap[ ( rtagName.exec( value ) || ["", ""] )[1].toLowerCase() ] ) { + !wrapMap[ ( rtagName.exec( value ) || [ "", "" ] )[ 1 ].toLowerCase() ] ) { value = value.replace( rxhtmlTag, "<$1></$2>" ); try { - for (; i < l; i++ ) { + for ( ; i < l; i++ ) { + // Remove element nodes and prevent memory leaks - elem = this[i] || {}; + elem = this[ i ] || {}; if ( elem.nodeType === 1 ) { jQuery.cleanData( getAll( elem, false ) ); elem.innerHTML = value; @@ -6067,7 +6256,7 @@ jQuery.fn.extend({ elem = 0; // If using innerHTML throws an exception, use the fallback method - } catch(e) {} + } catch ( e ) {} } if ( elem ) { @@ -6093,7 +6282,7 @@ jQuery.fn.extend({ jQuery( this ).remove(); parent.insertBefore( elem, next ); } - }); + } ); }, detach: function( selector ) { @@ -6111,18 +6300,18 @@ jQuery.fn.extend({ l = this.length, set = this, iNoClone = l - 1, - value = args[0], + value = args[ 0 ], isFunction = jQuery.isFunction( value ); // We can't cloneNode fragments that contain checked, in WebKit if ( isFunction || !( l <= 1 || typeof value !== "string" || jQuery.support.checkClone || !rchecked.test( value ) ) ) { - return this.each(function( index ) { + return this.each( function( index ) { var self = set.eq( index ); if ( isFunction ) { - args[0] = value.call( this, index, table ? self.html() : undefined ); + args[ 0 ] = value.call( this, index, table ? self.html() : undefined ); } self.domManip( args, table, callback ); - }); + } ); } if ( l ) { @@ -6153,9 +6342,9 @@ jQuery.fn.extend({ } callback.call( - table && jQuery.nodeName( this[i], "table" ) ? - findOrAppend( this[i], "tbody" ) : - this[i], + table && jQuery.nodeName( this[ i ], "table" ) ? + findOrAppend( this[ i ], "tbody" ) : + this[ i ], node, i ); @@ -6174,15 +6363,16 @@ jQuery.fn.extend({ !jQuery._data( node, "globalEval" ) && jQuery.contains( doc, node ) ) { if ( node.src ) { + // Hope ajax is available... - jQuery.ajax({ + jQuery.ajax( { url: node.src, type: "GET", dataType: "script", async: false, global: false, "throws": true - }); + } ); } else { jQuery.globalEval( ( node.text || node.textContent || node.innerHTML || "" ).replace( rcleanScript, "" ) ); } @@ -6197,24 +6387,24 @@ jQuery.fn.extend({ return this; } -}); +} ); function findOrAppend( elem, tag ) { - return elem.getElementsByTagName( tag )[0] || elem.appendChild( elem.ownerDocument.createElement( tag ) ); + return elem.getElementsByTagName( tag )[ 0 ] || elem.appendChild( elem.ownerDocument.createElement( tag ) ); } // Replace/restore the type attribute of script elements for safe DOM manipulation function disableScript( elem ) { - var attr = elem.getAttributeNode("type"); + var attr = elem.getAttributeNode( "type" ); elem.type = ( attr && attr.specified ) + "/" + elem.type; return elem; } function restoreScript( elem ) { var match = rscriptTypeMasked.exec( elem.type ); if ( match ) { - elem.type = match[1]; + elem.type = match[ 1 ]; } else { - elem.removeAttribute("type"); + elem.removeAttribute( "type" ); } return elem; } @@ -6223,8 +6413,8 @@ function restoreScript( elem ) { function setGlobalEval( elems, refElements ) { var elem, i = 0; - for ( ; (elem = elems[i]) != null; i++ ) { - jQuery._data( elem, "globalEval", !refElements || jQuery._data( refElements[i], "globalEval" ) ); + for ( ; ( elem = elems[ i ] ) != null; i++ ) { + jQuery._data( elem, "globalEval", !refElements || jQuery._data( refElements[ i ], "globalEval" ) ); } } @@ -6294,11 +6484,12 @@ function fixCloneNodeIssues( src, dest ) { // element in IE9, the outerHTML strategy above is not sufficient. // If the src has innerHTML and the destination does not, // copy the src.innerHTML into the dest.innerHTML. #10324 - if ( jQuery.support.html5Clone && ( src.innerHTML && !jQuery.trim(dest.innerHTML) ) ) { + if ( jQuery.support.html5Clone && ( src.innerHTML && !jQuery.trim( dest.innerHTML ) ) ) { dest.innerHTML = src.innerHTML; } } else if ( nodeName === "input" && manipulation_rcheckableType.test( src.type ) ) { + // IE6-8 fails to persist the checked state of a cloned checkbox // or radio button. Worse, IE6-7 fail to give the cloned element // a checked appearance if the defaultChecked value isn't also set @@ -6323,7 +6514,7 @@ function fixCloneNodeIssues( src, dest ) { } } -jQuery.each({ +jQuery.each( { appendTo: "append", prependTo: "prepend", insertBefore: "before", @@ -6338,8 +6529,8 @@ jQuery.each({ last = insert.length - 1; for ( ; i <= last; i++ ) { - elems = i === last ? this : this.clone(true); - jQuery( insert[i] )[ original ]( elems ); + elems = i === last ? this : this.clone( true ); + jQuery( insert[ i ] )[ original ]( elems ); // Modern browsers can apply jQuery collections as arrays, but oldIE needs a .get() core_push.apply( ret, elems.get() ); @@ -6347,7 +6538,7 @@ jQuery.each({ return this.pushStack( ret ); }; -}); +} ); function getAll( context, tag ) { var elems, elem, @@ -6357,7 +6548,7 @@ function getAll( context, tag ) { undefined; if ( !found ) { - for ( found = [], elems = context.childNodes || context; (elem = elems[i]) != null; i++ ) { + for ( found = [], elems = context.childNodes || context; ( elem = elems[ i ] ) != null; i++ ) { if ( !tag || jQuery.nodeName( elem, tag ) ) { found.push( elem ); } else { @@ -6378,12 +6569,12 @@ function fixDefaultChecked( elem ) { } } -jQuery.extend({ +jQuery.extend( { clone: function( elem, dataAndEvents, deepDataAndEvents ) { var destElements, node, clone, i, srcElements, inPage = jQuery.contains( elem.ownerDocument, elem ); - if ( jQuery.support.html5Clone || jQuery.isXMLDoc(elem) || !rnoshimcache.test( "<" + elem.nodeName + ">" ) ) { + if ( jQuery.support.html5Clone || jQuery.isXMLDoc( elem ) || !rnoshimcache.test( "<" + elem.nodeName + ">" ) ) { clone = elem.cloneNode( true ); // IE<=8 does not properly clone detached, unknown element nodes @@ -6392,18 +6583,19 @@ jQuery.extend({ fragmentDiv.removeChild( clone = fragmentDiv.firstChild ); } - if ( (!jQuery.support.noCloneEvent || !jQuery.support.noCloneChecked) && - (elem.nodeType === 1 || elem.nodeType === 11) && !jQuery.isXMLDoc(elem) ) { + if ( ( !jQuery.support.noCloneEvent || !jQuery.support.noCloneChecked ) && + ( elem.nodeType === 1 || elem.nodeType === 11 ) && !jQuery.isXMLDoc( elem ) ) { // We eschew Sizzle here for performance reasons: http://jsperf.com/getall-vs-sizzle/2 destElements = getAll( clone ); srcElements = getAll( elem ); // Fix all IE cloning issues - for ( i = 0; (node = srcElements[i]) != null; ++i ) { + for ( i = 0; ( node = srcElements[ i ] ) != null; ++i ) { + // Ensure that the destination node is not null; Fixes #9587 - if ( destElements[i] ) { - fixCloneNodeIssues( node, destElements[i] ); + if ( destElements[ i ] ) { + fixCloneNodeIssues( node, destElements[ i ] ); } } } @@ -6414,8 +6606,8 @@ jQuery.extend({ srcElements = srcElements || getAll( elem ); destElements = destElements || getAll( clone ); - for ( i = 0; (node = srcElements[i]) != null; i++ ) { - cloneCopyEvent( node, destElements[i] ); + for ( i = 0; ( node = srcElements[ i ] ) != null; i++ ) { + cloneCopyEvent( node, destElements[ i ] ); } } else { cloneCopyEvent( elem, clone ); @@ -6460,23 +6652,23 @@ jQuery.extend({ // Convert html into DOM nodes } else { - tmp = tmp || safe.appendChild( context.createElement("div") ); + tmp = tmp || safe.appendChild( context.createElement( "div" ) ); // Deserialize a standard representation - tag = ( rtagName.exec( elem ) || ["", ""] )[1].toLowerCase(); + tag = ( rtagName.exec( elem ) || [ "", "" ] )[ 1 ].toLowerCase(); wrap = wrapMap[ tag ] || wrapMap._default; - tmp.innerHTML = wrap[1] + elem.replace( rxhtmlTag, "<$1></$2>" ) + wrap[2]; + tmp.innerHTML = wrap[ 1 ] + elem.replace( rxhtmlTag, "<$1></$2>" ) + wrap[ 2 ]; // Descend through wrappers to the right content - j = wrap[0]; + j = wrap[ 0 ]; while ( j-- ) { tmp = tmp.lastChild; } // Manually add leading whitespace removed by IE if ( !jQuery.support.leadingWhitespace && rleadingWhitespace.test( elem ) ) { - nodes.push( context.createTextNode( rleadingWhitespace.exec( elem )[0] ) ); + nodes.push( context.createTextNode( rleadingWhitespace.exec( elem )[ 0 ] ) ); } // Remove IE's autoinserted <tbody> from table fragments @@ -6487,13 +6679,13 @@ jQuery.extend({ tmp.firstChild : // String was a bare <thead> or <tfoot> - wrap[1] === "<table>" && !rtbody.test( elem ) ? + wrap[ 1 ] === "<table>" && !rtbody.test( elem ) ? tmp : 0; j = elem && elem.childNodes.length; while ( j-- ) { - if ( jQuery.nodeName( (tbody = elem.childNodes[j]), "tbody" ) && !tbody.childNodes.length ) { + if ( jQuery.nodeName( ( tbody = elem.childNodes[ j ] ), "tbody" ) && !tbody.childNodes.length ) { elem.removeChild( tbody ); } } @@ -6527,7 +6719,7 @@ jQuery.extend({ } i = 0; - while ( (elem = nodes[ i++ ]) ) { + while ( ( elem = nodes[ i++ ] ) ) { // #4087 - If origin and destination elements are the same, and this is // that element, do not do anything @@ -6548,7 +6740,7 @@ jQuery.extend({ // Capture executables if ( scripts ) { j = 0; - while ( (elem = tmp[ j++ ]) ) { + while ( ( elem = tmp[ j++ ] ) ) { if ( rscriptType.test( elem.type || "" ) ) { scripts.push( elem ); } @@ -6569,7 +6761,7 @@ jQuery.extend({ deleteExpando = jQuery.support.deleteExpando, special = jQuery.event.special; - for ( ; (elem = elems[i]) != null; i++ ) { + for ( ; ( elem = elems[ i ] ) != null; i++ ) { if ( acceptData || jQuery.acceptData( elem ) ) { @@ -6613,11 +6805,12 @@ jQuery.extend({ } } } -}); +} ); var iframe, getStyles, curCSS, ralpha = /alpha\([^)]*\)/i, ropacity = /opacity\s*=\s*([^)]*)/, rposition = /^(top|right|bottom|left)$/, + // swappable if display is none or starts with table except "table", "table-cell", or "table-caption" // see here for display values: https://developer.mozilla.org/en-US/docs/CSS/display rdisplayswap = /^(none|table(?!-c[ea]).+)/, @@ -6645,7 +6838,7 @@ function vendorPropName( style, name ) { } // check for vendor prefixed names - var capName = name.charAt(0).toUpperCase() + name.slice(1), + var capName = name.charAt( 0 ).toUpperCase() + name.slice( 1 ), origName = name, i = cssPrefixes.length; @@ -6660,6 +6853,7 @@ function vendorPropName( style, name ) { } function isHidden( elem, el ) { + // isHidden might be called from jQuery#filter function; // in that case, element will be second argument elem = el || elem; @@ -6681,6 +6875,7 @@ function showHide( elements, show ) { values[ index ] = jQuery._data( elem, "olddisplay" ); display = elem.style.display; if ( show ) { + // Reset the inline display of this element to learn if it is // being hidden by cascaded rules or not if ( !values[ index ] && display === "none" ) { @@ -6691,7 +6886,7 @@ function showHide( elements, show ) { // in a stylesheet to whatever the default browser style is // for such an element if ( elem.style.display === "" && isHidden( elem ) ) { - values[ index ] = jQuery._data( elem, "olddisplay", css_defaultDisplay(elem.nodeName) ); + values[ index ] = jQuery._data( elem, "olddisplay", css_defaultDisplay( elem.nodeName ) ); } } else { @@ -6720,7 +6915,7 @@ function showHide( elements, show ) { return elements; } -jQuery.fn.extend({ +jQuery.fn.extend( { css: function( name, value ) { return jQuery.access( this, function( elem, name, value ) { var len, styles, @@ -6752,23 +6947,25 @@ jQuery.fn.extend({ toggle: function( state ) { var bool = typeof state === "boolean"; - return this.each(function() { + return this.each( function() { if ( bool ? state : isHidden( this ) ) { jQuery( this ).show(); } else { jQuery( this ).hide(); } - }); + } ); } -}); +} ); + +jQuery.extend( { -jQuery.extend({ // Add in style property hooks for overriding the default // behavior of getting and setting a style property cssHooks: { opacity: { get: function( elem, computed ) { if ( computed ) { + // We should always get a number back from opacity var ret = curCSS( elem, "opacity" ); return ret === "" ? "1" : ret; @@ -6793,12 +6990,14 @@ jQuery.extend({ // Add in properties whose names you wish to fix before // setting or getting the value cssProps: { + // normalize float css property "float": jQuery.support.cssFloat ? "cssFloat" : "styleFloat" }, // Get and set the style property on a DOM Node style: function( elem, name, value, extra ) { + // Don't set styles on text and comment nodes if ( !elem || elem.nodeType === 3 || elem.nodeType === 8 || !elem.style ) { return; @@ -6820,8 +7019,9 @@ jQuery.extend({ type = typeof value; // convert relative number strings (+= or -=) to relative numbers. #7345 - if ( type === "string" && (ret = rrelNum.exec( value )) ) { - value = ( ret[1] + 1 ) * ret[2] + parseFloat( jQuery.css( elem, name ) ); + if ( type === "string" && ( ret = rrelNum.exec( value ) ) ) { + value = ( ret[ 1 ] + 1 ) * ret[ 2 ] + parseFloat( jQuery.css( elem, name ) ); + // Fixes bug #9237 type = "number"; } @@ -6838,23 +7038,24 @@ jQuery.extend({ // Fixes #8908, it can be done more correctly by specifing setters in cssHooks, // but it would mean to define eight (for every problematic property) identical functions - if ( !jQuery.support.clearCloneStyle && value === "" && name.indexOf("background") === 0 ) { + if ( !jQuery.support.clearCloneStyle && value === "" && name.indexOf( "background" ) === 0 ) { style[ name ] = "inherit"; } // If a hook was provided, use that value, otherwise just set the specified value - if ( !hooks || !("set" in hooks) || (value = hooks.set( elem, value, extra )) !== undefined ) { + if ( !hooks || !( "set" in hooks ) || ( value = hooks.set( elem, value, extra ) ) !== undefined ) { // Wrapped to prevent IE from throwing errors when 'invalid' values are provided // Fixes bug #5509 try { style[ name ] = value; - } catch(e) {} + } catch ( e ) {} } } else { + // If a hook was provided get the non-computed value from there - if ( hooks && "get" in hooks && (ret = hooks.get( elem, false, extra )) !== undefined ) { + if ( hooks && "get" in hooks && ( ret = hooks.get( elem, false, extra ) ) !== undefined ) { return ret; } @@ -6917,7 +7118,7 @@ jQuery.extend({ return ret; } -}); +} ); // NOTE: we've included the "window" in window.getComputedStyle // because jsdom on node.js will break without it. @@ -7016,6 +7217,7 @@ if ( window.getComputedStyle ) { function setPositiveNumber( elem, value, subtract ) { var matches = rnumsplit.exec( value ); return matches ? + // Guard against undefined "subtract", e.g., when used as in cssHooks Math.max( 0, matches[ 1 ] - ( subtract || 0 ) ) + ( matches[ 2 ] || "px" ) : value; @@ -7023,20 +7225,24 @@ function setPositiveNumber( elem, value, subtract ) { function augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) { var i = extra === ( isBorderBox ? "border" : "content" ) ? + // If we already have the right measurement, avoid augmentation 4 : + // Otherwise initialize for horizontal or vertical properties name === "width" ? 1 : 0, val = 0; for ( ; i < 4; i += 2 ) { + // both box models exclude margin, so add it if we want it if ( extra === "margin" ) { val += jQuery.css( elem, extra + cssExpand[ i ], true, styles ); } if ( isBorderBox ) { + // border-box includes padding, so remove it if we want content if ( extra === "content" ) { val -= jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); @@ -7047,6 +7253,7 @@ function augmentWidthOrHeight( elem, name, extra, isBorderBox, styles ) { val -= jQuery.css( elem, "border" + cssExpand[ i ] + "Width", true, styles ); } } else { + // at this point, extra isn't content, so add padding val += jQuery.css( elem, "padding" + cssExpand[ i ], true, styles ); @@ -7072,6 +7279,7 @@ function getWidthOrHeight( elem, name, extra ) { // svg - https://bugzilla.mozilla.org/show_bug.cgi?id=649285 // MathML - https://bugzilla.mozilla.org/show_bug.cgi?id=491668 if ( val <= 0 || val == null ) { + // Fall back to computed then uncomputed css if necessary val = curCSS( elem, name, styles ); if ( val < 0 || val == null ) { @@ -7079,7 +7287,7 @@ function getWidthOrHeight( elem, name, extra ) { } // Computed unit is not pixels. Stop here and return. - if ( rnumnonpx.test(val) ) { + if ( rnumnonpx.test( val ) ) { return val; } @@ -7113,15 +7321,16 @@ function css_defaultDisplay( nodeName ) { // If the simple way fails, read from inside an iframe if ( display === "none" || !display ) { + // Use the already-created iframe if possible iframe = ( iframe || - jQuery("<iframe frameborder='0' width='0' height='0'/>") + jQuery( "<iframe frameborder='0' width='0' height='0'/>" ) .css( "cssText", "display:block !important" ) ).appendTo( doc.documentElement ); // Always write a new HTML skeleton so Webkit and Firefox don't choke on reuse - doc = ( iframe[0].contentWindow || iframe[0].contentDocument ).document; - doc.write("<!doctype html><html><body>"); + doc = ( iframe[ 0 ].contentWindow || iframe[ 0 ].contentDocument ).document; + doc.write( "<!doctype html><html><body>" ); doc.close(); display = actualDisplay( nodeName, doc ); @@ -7138,21 +7347,22 @@ function css_defaultDisplay( nodeName ) { // Called ONLY from within css_defaultDisplay function actualDisplay( name, doc ) { var elem = jQuery( doc.createElement( name ) ).appendTo( doc.body ), - display = jQuery.css( elem[0], "display" ); + display = jQuery.css( elem[ 0 ], "display" ); elem.remove(); return display; } -jQuery.each([ "height", "width" ], function( i, name ) { +jQuery.each( [ "height", "width" ], function( i, name ) { jQuery.cssHooks[ name ] = { get: function( elem, computed, extra ) { if ( computed ) { + // certain elements can have dimension info if we invisibly show them // however, it must have a current display style that would benefit from this return elem.offsetWidth === 0 && rdisplayswap.test( jQuery.css( elem, "display" ) ) ? jQuery.swap( elem, cssShow, function() { return getWidthOrHeight( elem, name, extra ); - }) : + } ) : getWidthOrHeight( elem, name, extra ); } }, @@ -7170,13 +7380,14 @@ jQuery.each([ "height", "width" ], function( i, name ) { ); } }; -}); +} ); if ( !jQuery.support.opacity ) { jQuery.cssHooks.opacity = { get: function( elem, computed ) { + // IE uses filters for opacity - return ropacity.test( (computed && elem.currentStyle ? elem.currentStyle.filter : elem.style.filter) || "" ) ? + return ropacity.test( ( computed && elem.currentStyle ? elem.currentStyle.filter : elem.style.filter ) || "" ) ? ( 0.01 * parseFloat( RegExp.$1 ) ) + "" : computed ? "1" : ""; }, @@ -7218,11 +7429,12 @@ if ( !jQuery.support.opacity ) { // These hooks cannot be added until DOM ready because the support test // for it is not run until after DOM ready -jQuery(function() { +jQuery( function() { if ( !jQuery.support.reliableMarginRight ) { jQuery.cssHooks.marginRight = { get: function( elem, computed ) { if ( computed ) { + // WebKit Bug 13343 - getComputedStyle returns wrong value for margin-right // Work around by temporarily setting element display to inline-block return jQuery.swap( elem, { "display": "inline-block" }, @@ -7241,6 +7453,7 @@ jQuery(function() { get: function( elem, computed ) { if ( computed ) { computed = curCSS( elem, prop ); + // if curCSS returns percentage, fallback to offset return rnumnonpx.test( computed ) ? jQuery( elem ).position()[ prop ] + "px" : @@ -7248,17 +7461,18 @@ jQuery(function() { } } }; - }); + } ); } -}); +} ); if ( jQuery.expr && jQuery.expr.filters ) { jQuery.expr.filters.hidden = function( elem ) { + // Support: Opera <= 12.12 // Opera reports offsetWidths and offsetHeights less than zero on some elements return elem.offsetWidth <= 0 && elem.offsetHeight <= 0 || - (!jQuery.support.reliableHiddenOffsets && ((elem.style && elem.style.display) || jQuery.css( elem, "display" )) === "none"); + ( !jQuery.support.reliableHiddenOffsets && ( ( elem.style && elem.style.display ) || jQuery.css( elem, "display" ) ) === "none" ); }; jQuery.expr.filters.visible = function( elem ) { @@ -7267,7 +7481,7 @@ if ( jQuery.expr && jQuery.expr.filters ) { } // These hooks are used by animate to expand properties -jQuery.each({ +jQuery.each( { margin: "", padding: "", border: "Width" @@ -7278,7 +7492,7 @@ jQuery.each({ expanded = {}, // assumes a single number if not a string - parts = typeof value === "string" ? value.split(" ") : [ value ]; + parts = typeof value === "string" ? value.split( " " ) : [ value ]; for ( ; i < 4; i++ ) { expanded[ prefix + cssExpand[ i ] + suffix ] = @@ -7292,43 +7506,45 @@ jQuery.each({ if ( !rmargin.test( prefix ) ) { jQuery.cssHooks[ prefix + suffix ].set = setPositiveNumber; } -}); +} ); var r20 = /%20/g, rbracket = /\[\]$/, rCRLF = /\r?\n/g, rsubmitterTypes = /^(?:submit|button|image|reset|file)$/i, rsubmittable = /^(?:input|select|textarea|keygen)/i; -jQuery.fn.extend({ +jQuery.fn.extend( { serialize: function() { return jQuery.param( this.serializeArray() ); }, serializeArray: function() { - return this.map(function(){ + return this.map( function() { + // Can add propHook for "elements" to filter or add form elements var elements = jQuery.prop( this, "elements" ); return elements ? jQuery.makeArray( elements ) : this; - }) - .filter(function(){ + } ) + .filter( function() { var type = this.type; + // Use .is(":disabled") so that fieldset[disabled] works return this.name && !jQuery( this ).is( ":disabled" ) && rsubmittable.test( this.nodeName ) && !rsubmitterTypes.test( type ) && ( this.checked || !manipulation_rcheckableType.test( type ) ); - }) - .map(function( i, elem ){ + } ) + .map( function( i, elem ) { var val = jQuery( this ).val(); return val == null ? null : jQuery.isArray( val ) ? - jQuery.map( val, function( val ){ + jQuery.map( val, function( val ) { return { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; - }) : + } ) : { name: elem.name, value: val.replace( rCRLF, "\r\n" ) }; - }).get(); + } ).get(); } -}); +} ); //Serialize an array of form elements or a set of //key/values into a query string @@ -7336,6 +7552,7 @@ jQuery.param = function( a, traditional ) { var prefix, s = [], add = function( key, value ) { + // If value is a function, invoke it and return its value value = jQuery.isFunction( value ) ? value() : ( value == null ? "" : value ); s[ s.length ] = encodeURIComponent( key ) + "=" + encodeURIComponent( value ); @@ -7348,12 +7565,14 @@ jQuery.param = function( a, traditional ) { // If an array was passed in, assume that it is an array of form elements. if ( jQuery.isArray( a ) || ( a.jquery && !jQuery.isPlainObject( a ) ) ) { + // Serialize the form elements jQuery.each( a, function() { add( this.name, this.value ); - }); + } ); } else { + // If traditional, encode the "old" way (the way 1.3.2 or older // did it), otherwise encode params recursively. for ( prefix in a ) { @@ -7369,32 +7588,37 @@ function buildParams( prefix, obj, traditional, add ) { var name; if ( jQuery.isArray( obj ) ) { + // Serialize array item. jQuery.each( obj, function( i, v ) { if ( traditional || rbracket.test( prefix ) ) { + // Treat each array item as a scalar. add( prefix, v ); } else { + // Item is non-scalar (array or object), encode its numeric index. buildParams( prefix + "[" + ( typeof v === "object" ? i : "" ) + "]", v, traditional, add ); } - }); + } ); } else if ( !traditional && jQuery.type( obj ) === "object" ) { + // Serialize object item. for ( name in obj ) { buildParams( prefix + "[" + name + "]", obj[ name ], traditional, add ); } } else { + // Serialize scalar item. add( prefix, obj ); } } -jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblclick " + +jQuery.each( ( "blur focus focusin focusout load resize scroll unload click dblclick " + "mousedown mouseup mousemove mouseover mouseout mouseenter mouseleave " + - "change select submit keydown keypress keyup error contextmenu").split(" "), function( i, name ) { + "change select submit keydown keypress keyup error contextmenu" ).split( " " ), function( i, name ) { // Handle event binding jQuery.fn[ name ] = function( data, fn ) { @@ -7402,12 +7626,13 @@ jQuery.each( ("blur focus focusin focusout load resize scroll unload click dblcl this.on( name, null, data, fn ) : this.trigger( name ); }; -}); +} ); jQuery.fn.hover = function( fnOver, fnOut ) { return this.mouseenter( fnOver ).mouseleave( fnOut || fnOver ); }; var + // Document location ajaxLocParts, ajaxLocation, @@ -7445,13 +7670,14 @@ var transports = {}, // Avoid comment-prolog char sequence (#10098); must appease lint and evade compression - allTypes = "*/".concat("*"); + allTypes = "*/".concat( "*" ); // #8138, IE may throw an exception when accessing // a field from window.location if document.domain has been set try { ajaxLocation = location.href; -} catch( e ) { +} catch ( e ) { + // Use the href attribute of an A element // since IE will modify it given document.location ajaxLocation = document.createElement( "a" ); @@ -7478,16 +7704,18 @@ function addToPrefiltersOrTransports( structure ) { dataTypes = dataTypeExpression.toLowerCase().match( core_rnotwhite ) || []; if ( jQuery.isFunction( func ) ) { + // For each dataType in the dataTypeExpression - while ( (dataType = dataTypes[i++]) ) { + while ( ( dataType = dataTypes[ i++ ] ) ) { + // Prepend if requested - if ( dataType[0] === "+" ) { + if ( dataType[ 0 ] === "+" ) { dataType = dataType.slice( 1 ) || "*"; - (structure[ dataType ] = structure[ dataType ] || []).unshift( func ); + ( structure[ dataType ] = structure[ dataType ] || [] ).unshift( func ); // Otherwise append } else { - (structure[ dataType ] = structure[ dataType ] || []).push( func ); + ( structure[ dataType ] = structure[ dataType ] || [] ).push( func ); } } } @@ -7505,14 +7733,14 @@ function inspectPrefiltersOrTransports( structure, options, originalOptions, jqX inspected[ dataType ] = true; jQuery.each( structure[ dataType ] || [], function( _, prefilterOrFactory ) { var dataTypeOrTransport = prefilterOrFactory( options, originalOptions, jqXHR ); - if( typeof dataTypeOrTransport === "string" && !seekingTransport && !inspected[ dataTypeOrTransport ] ) { + if ( typeof dataTypeOrTransport === "string" && !seekingTransport && !inspected[ dataTypeOrTransport ] ) { options.dataTypes.unshift( dataTypeOrTransport ); inspect( dataTypeOrTransport ); return false; } else if ( seekingTransport ) { return !( selected = dataTypeOrTransport ); } - }); + } ); return selected; } @@ -7528,7 +7756,7 @@ function ajaxExtend( target, src ) { for ( key in src ) { if ( src[ key ] !== undefined ) { - ( flatOptions[ key ] ? target : ( deep || (deep = {}) ) )[ key ] = src[ key ]; + ( flatOptions[ key ] ? target : ( deep || ( deep = {} ) ) )[ key ] = src[ key ]; } } if ( deep ) { @@ -7545,7 +7773,7 @@ jQuery.fn.load = function( url, params, callback ) { var selector, response, type, self = this, - off = url.indexOf(" "); + off = url.indexOf( " " ); if ( off >= 0 ) { selector = url.slice( off, url.length ); @@ -7566,14 +7794,14 @@ jQuery.fn.load = function( url, params, callback ) { // If we have elements to modify, make the request if ( self.length > 0 ) { - jQuery.ajax({ + jQuery.ajax( { url: url, // if "type" variable is undefined, then "GET" method will be used type: type, dataType: "html", data: params - }).done(function( responseText ) { + } ).done( function( responseText ) { // Save response for use in complete callback response = arguments; @@ -7582,28 +7810,29 @@ jQuery.fn.load = function( url, params, callback ) { // If a selector was specified, locate the right elements in a dummy div // Exclude scripts to avoid IE 'Permission Denied' errors - jQuery("<div>").append( jQuery.parseHTML( responseText ) ).find( selector ) : + jQuery( "<div>" ).append( jQuery.parseHTML( responseText ) ).find( selector ) : // Otherwise use the full result responseText ); - }).complete( callback && function( jqXHR, status ) { + } ).complete( callback && function( jqXHR, status ) { self.each( callback, response || [ jqXHR.responseText, status, jqXHR ] ); - }); + } ); } return this; }; // Attach a bunch of functions for handling common AJAX events -jQuery.each( [ "ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend" ], function( i, type ){ - jQuery.fn[ type ] = function( fn ){ +jQuery.each( [ "ajaxStart", "ajaxStop", "ajaxComplete", "ajaxError", "ajaxSuccess", "ajaxSend" ], function( i, type ) { + jQuery.fn[ type ] = function( fn ) { return this.on( type, fn ); }; -}); +} ); jQuery.each( [ "get", "post" ], function( i, method ) { jQuery[ method ] = function( url, data, callback, type ) { + // shift arguments if data argument was omitted if ( jQuery.isFunction( data ) ) { type = type || callback; @@ -7611,17 +7840,17 @@ jQuery.each( [ "get", "post" ], function( i, method ) { data = undefined; } - return jQuery.ajax({ + return jQuery.ajax( { url: url, type: method, dataType: type, data: data, success: callback - }); + } ); }; -}); +} ); -jQuery.extend({ +jQuery.extend( { // Counter for holding the number of active queries active: 0, @@ -7726,12 +7955,16 @@ jQuery.extend({ var // Cross-domain detection vars parts, + // Loop variable i, + // URL without anti-cache param cacheURL, + // Response headers as string responseHeadersString, + // timeout handle timeoutTimer, @@ -7739,28 +7972,38 @@ jQuery.extend({ fireGlobals, transport, + // Response headers responseHeaders, + // Create the final options object s = jQuery.ajaxSetup( {}, options ), + // Callbacks context callbackContext = s.context || s, + // Context for global events is callbackContext if it is a DOM node or jQuery collection globalEventContext = s.context && ( callbackContext.nodeType || callbackContext.jquery ) ? jQuery( callbackContext ) : jQuery.event, + // Deferreds deferred = jQuery.Deferred(), - completeDeferred = jQuery.Callbacks("once memory"), + completeDeferred = jQuery.Callbacks( "once memory" ), + // Status-dependent callbacks statusCode = s.statusCode || {}, + // Headers (they are sent all at once) requestHeaders = {}, requestHeadersNames = {}, + // The jqXHR state state = 0, + // Default abort message strAbort = "canceled", + // Fake xhr jqXHR = { readyState: 0, @@ -7771,8 +8014,8 @@ jQuery.extend({ if ( state === 2 ) { if ( !responseHeaders ) { responseHeaders = {}; - while ( (match = rheaders.exec( responseHeadersString )) ) { - responseHeaders[ match[1].toLowerCase() ] = match[ 2 ]; + while ( ( match = rheaders.exec( responseHeadersString ) ) ) { + responseHeaders[ match[ 1 ].toLowerCase() ] = match[ 2 ]; } } match = responseHeaders[ key.toLowerCase() ]; @@ -7809,10 +8052,12 @@ jQuery.extend({ if ( map ) { if ( state < 2 ) { for ( code in map ) { + // Lazy-add the new callback in a way that preserves old ones statusCode[ code ] = [ statusCode[ code ], map[ code ] ]; } } else { + // Execute the appropriate callbacks jqXHR.always( map[ jqXHR.status ] ); } @@ -7846,7 +8091,7 @@ jQuery.extend({ s.type = options.method || options.type || s.method || s.type; // Extract dataTypes list - s.dataTypes = jQuery.trim( s.dataType || "*" ).toLowerCase().match( core_rnotwhite ) || [""]; + s.dataTypes = jQuery.trim( s.dataType || "*" ).toLowerCase().match( core_rnotwhite ) || [ "" ]; // A cross-domain request is in order when we have a protocol:host:port mismatch if ( s.crossDomain == null ) { @@ -7876,7 +8121,7 @@ jQuery.extend({ // Watch for a new set of requests if ( fireGlobals && jQuery.active++ === 0 ) { - jQuery.event.trigger("ajaxStart"); + jQuery.event.trigger( "ajaxStart" ); } // Uppercase the type @@ -7895,6 +8140,7 @@ jQuery.extend({ // If data is available, append data to url if ( s.data ) { cacheURL = ( s.url += ( ajax_rquery.test( cacheURL ) ? "&" : "?" ) + s.data ); + // #9682: remove data so that it's not used in an eventual retry delete s.data; } @@ -7929,8 +8175,8 @@ jQuery.extend({ // Set the Accepts header for the server, depending on the dataType jqXHR.setRequestHeader( "Accept", - s.dataTypes[ 0 ] && s.accepts[ s.dataTypes[0] ] ? - s.accepts[ s.dataTypes[0] ] + ( s.dataTypes[ 0 ] !== "*" ? ", " + allTypes + "; q=0.01" : "" ) : + s.dataTypes[ 0 ] && s.accepts[ s.dataTypes[ 0 ] ] ? + s.accepts[ s.dataTypes[ 0 ] ] + ( s.dataTypes[ 0 ] !== "*" ? ", " + allTypes + "; q=0.01" : "" ) : s.accepts[ "*" ] ); @@ -7941,6 +8187,7 @@ jQuery.extend({ // Allow custom headers/mimetypes and early abort if ( s.beforeSend && ( s.beforeSend.call( callbackContext, jqXHR, s ) === false || state === 2 ) ) { + // Abort if not done already and return return jqXHR.abort(); } @@ -7966,10 +8213,11 @@ jQuery.extend({ if ( fireGlobals ) { globalEventContext.trigger( "ajaxSend", [ jqXHR, s ] ); } + // Timeout if ( s.async && s.timeout > 0 ) { - timeoutTimer = setTimeout(function() { - jqXHR.abort("timeout"); + timeoutTimer = setTimeout( function() { + jqXHR.abort( "timeout" ); }, s.timeout ); } @@ -7977,9 +8225,11 @@ jQuery.extend({ state = 1; transport.send( requestHeaders, done ); } catch ( e ) { + // Propagate exception as error if not done if ( state < 2 ) { done( -1, e ); + // Simply rethrow otherwise } else { throw e; @@ -8025,11 +8275,11 @@ jQuery.extend({ // Set the If-Modified-Since and/or If-None-Match header, if in ifModified mode. if ( s.ifModified ) { - modified = jqXHR.getResponseHeader("Last-Modified"); + modified = jqXHR.getResponseHeader( "Last-Modified" ); if ( modified ) { jQuery.lastModified[ cacheURL ] = modified; } - modified = jqXHR.getResponseHeader("etag"); + modified = jqXHR.getResponseHeader( "etag" ); if ( modified ) { jQuery.etag[ cacheURL ] = modified; } @@ -8054,6 +8304,7 @@ jQuery.extend({ isSuccess = !error; } } else { + // We extract error from statusText // then normalize statusText and status for non-aborts error = statusText; @@ -8090,9 +8341,10 @@ jQuery.extend({ if ( fireGlobals ) { globalEventContext.trigger( "ajaxComplete", [ jqXHR, s ] ); + // Handle the global AJAX counter if ( !( --jQuery.active ) ) { - jQuery.event.trigger("ajaxStop"); + jQuery.event.trigger( "ajaxStop" ); } } } @@ -8107,7 +8359,7 @@ jQuery.extend({ getJSON: function( url, data, callback ) { return jQuery.get( url, data, callback, "json" ); } -}); +} ); /* Handles responses to an ajax request: * - sets all responseXXX fields accordingly @@ -8123,15 +8375,15 @@ function ajaxHandleResponses( s, jqXHR, responses ) { // Fill responseXXX fields for ( type in responseFields ) { if ( type in responses ) { - jqXHR[ responseFields[type] ] = responses[ type ]; + jqXHR[ responseFields[ type ] ] = responses[ type ]; } } // Remove auto dataType and get content-type in the process - while( dataTypes[ 0 ] === "*" ) { + while ( dataTypes[ 0 ] === "*" ) { dataTypes.shift(); if ( ct === undefined ) { - ct = s.mimeType || jqXHR.getResponseHeader("Content-Type"); + ct = s.mimeType || jqXHR.getResponseHeader( "Content-Type" ); } } @@ -8149,9 +8401,10 @@ function ajaxHandleResponses( s, jqXHR, responses ) { if ( dataTypes[ 0 ] in responses ) { finalDataType = dataTypes[ 0 ]; } else { + // Try convertible dataTypes for ( type in responses ) { - if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[0] ] ) { + if ( !dataTypes[ 0 ] || s.converters[ type + " " + dataTypes[ 0 ] ] ) { finalDataType = type; break; } @@ -8159,6 +8412,7 @@ function ajaxHandleResponses( s, jqXHR, responses ) { firstDataType = type; } } + // Or just use first one finalDataType = finalDataType || firstDataType; } @@ -8179,6 +8433,7 @@ function ajaxConvert( s, response ) { var conv2, current, conv, tmp, converters = {}, i = 0, + // Work with a copy of dataTypes in case we need to modify it for conversion dataTypes = s.dataTypes.slice(), prev = dataTypes[ 0 ]; @@ -8196,7 +8451,7 @@ function ajaxConvert( s, response ) { } // Convert to each sequential dataType, tolerating list modification - for ( ; (current = dataTypes[++i]); ) { + for ( ; ( current = dataTypes[ ++i ] ); ) { // There's only work to do if current dataType is non-auto if ( current !== "*" ) { @@ -8212,13 +8467,14 @@ function ajaxConvert( s, response ) { for ( conv2 in converters ) { // If conv2 outputs current - tmp = conv2.split(" "); + tmp = conv2.split( " " ); if ( tmp[ 1 ] === current ) { // If prev can be converted to accepted input conv = converters[ prev + " " + tmp[ 0 ] ] || converters[ "* " + tmp[ 0 ] ]; if ( conv ) { + // Condense equivalence converters if ( conv === true ) { conv = converters[ conv2 ]; @@ -8239,7 +8495,7 @@ function ajaxConvert( s, response ) { if ( conv !== true ) { // Unless errors are allowed to bubble, catch and return them - if ( conv && s["throws"] ) { + if ( conv && s[ "throws" ] ) { response = conv( response ); } else { try { @@ -8258,8 +8514,9 @@ function ajaxConvert( s, response ) { return { state: "success", data: response }; } + // Install script dataType -jQuery.ajaxSetup({ +jQuery.ajaxSetup( { accepts: { script: "text/javascript, application/javascript, application/ecmascript, application/x-ecmascript" }, @@ -8272,7 +8529,7 @@ jQuery.ajaxSetup({ return text; } } -}); +} ); // Handle cache's special case and global jQuery.ajaxPrefilter( "script", function( s ) { @@ -8283,22 +8540,22 @@ jQuery.ajaxPrefilter( "script", function( s ) { s.type = "GET"; s.global = false; } -}); +} ); // Bind script tag hack transport -jQuery.ajaxTransport( "script", function(s) { +jQuery.ajaxTransport( "script", function( s ) { // This transport only deals with cross domain requests if ( s.crossDomain ) { var script, - head = document.head || jQuery("head")[0] || document.documentElement; + head = document.head || jQuery( "head" )[ 0 ] || document.documentElement; return { send: function( _, callback ) { - script = document.createElement("script"); + script = document.createElement( "script" ); script.async = true; @@ -8343,19 +8600,19 @@ jQuery.ajaxTransport( "script", function(s) { } }; } -}); +} ); var oldCallbacks = [], rjsonp = /(=)\?(?=&|$)|\?\?/; // Default jsonp settings -jQuery.ajaxSetup({ +jQuery.ajaxSetup( { jsonp: "callback", jsonpCallback: function() { var callback = oldCallbacks.pop() || ( jQuery.expando + "_" + ( ajax_nonce++ ) ); this[ callback ] = true; return callback; } -}); +} ); // Detect, normalize options and install callbacks for jsonp requests jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { @@ -8363,7 +8620,7 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { var callbackName, overwritten, responseContainer, jsonProp = s.jsonp !== false && ( rjsonp.test( s.url ) ? "url" : - typeof s.data === "string" && !( s.contentType || "" ).indexOf("application/x-www-form-urlencoded") && rjsonp.test( s.data ) && "data" + typeof s.data === "string" && !( s.contentType || "" ).indexOf( "application/x-www-form-urlencoded" ) && rjsonp.test( s.data ) && "data" ); // Handle iff the expected data type is "jsonp" or we have a parameter to set @@ -8382,7 +8639,7 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { } // Use data converter to retrieve json after script execution - s.converters["script json"] = function() { + s.converters[ "script json" ] = function() { if ( !responseContainer ) { jQuery.error( callbackName + " was not called" ); } @@ -8399,12 +8656,14 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { }; // Clean-up function (fires after converters) - jqXHR.always(function() { + jqXHR.always( function() { + // Restore preexisting value window[ callbackName ] = overwritten; // Save back as free if ( s[ callbackName ] ) { + // make sure that re-using the options doesn't screw things around s.jsonpCallback = originalSettings.jsonpCallback; @@ -8418,16 +8677,18 @@ jQuery.ajaxPrefilter( "json jsonp", function( s, originalSettings, jqXHR ) { } responseContainer = overwritten = undefined; - }); + } ); // Delegate to script return "script"; } -}); +} ); var xhrCallbacks, xhrSupported, xhrId = 0, + // #5280: Internet Explorer will keep connections alive if we don't abort on unload xhrOnUnloadAbort = window.ActiveXObject && function() { + // Abort all pending requests var key; for ( key in xhrCallbacks ) { @@ -8439,13 +8700,13 @@ var xhrCallbacks, xhrSupported, function createStandardXHR() { try { return new window.XMLHttpRequest(); - } catch( e ) {} + } catch ( e ) {} } function createActiveXHR() { try { - return new window.ActiveXObject("Microsoft.XMLHTTP"); - } catch( e ) {} + return new window.ActiveXObject( "Microsoft.XMLHTTP" ); + } catch ( e ) {} } // Create the request object @@ -8460,6 +8721,7 @@ jQuery.ajaxSettings.xhr = window.ActiveXObject ? function() { return !this.isLocal && createStandardXHR() || createActiveXHR(); } : + // For all other browsers, use the standard XMLHttpRequest object createStandardXHR; @@ -8471,7 +8733,8 @@ xhrSupported = jQuery.support.ajax = !!xhrSupported; // Create transport if the browser can provide an xhr if ( xhrSupported ) { - jQuery.ajaxTransport(function( s ) { + jQuery.ajaxTransport( function( s ) { + // Cross domain only allowed if supported through XMLHttpRequest if ( !s.crossDomain || jQuery.support.cors ) { @@ -8509,8 +8772,8 @@ if ( xhrSupported ) { // akin to a jigsaw puzzle, we simply never set it to be sure. // (it can always be set on a per-request basis or even using ajaxSetup) // For same-domain requests, won't change header if already provided. - if ( !s.crossDomain && !headers["X-Requested-With"] ) { - headers["X-Requested-With"] = "XMLHttpRequest"; + if ( !s.crossDomain && !headers[ "X-Requested-With" ] ) { + headers[ "X-Requested-With" ] = "XMLHttpRequest"; } // Need an extra try/catch for cross domain requests in Firefox 3 @@ -8518,7 +8781,7 @@ if ( xhrSupported ) { for ( i in headers ) { xhr.setRequestHeader( i, headers[ i ] ); } - } catch( err ) {} + } catch ( err ) {} // Do send the request // This may raise an exception which is actually @@ -8550,6 +8813,7 @@ if ( xhrSupported ) { // If it's an abort if ( isAbort ) { + // Abort it manually if needed if ( xhr.readyState !== 4 ) { xhr.abort(); @@ -8569,7 +8833,8 @@ if ( xhrSupported ) { // statusText for faulty cross-domain requests try { statusText = xhr.statusText; - } catch( e ) { + } catch ( e ) { + // We normalize with Webkit giving an empty statusText statusText = ""; } @@ -8581,13 +8846,14 @@ if ( xhrSupported ) { // can do given current implementations) if ( !status && s.isLocal && !s.crossDomain ) { status = responses.text ? 200 : 404; + // IE - #1450: sometimes returns 1223 when it should be 204 } else if ( status === 1223 ) { status = 204; } } } - } catch( firefoxAccessException ) { + } catch ( firefoxAccessException ) { if ( !isAbort ) { complete( -1, firefoxAccessException ); } @@ -8600,21 +8866,25 @@ if ( xhrSupported ) { }; if ( !s.async ) { + // if we're in sync mode we fire the callback callback(); } else if ( xhr.readyState === 4 ) { + // (IE6 & IE7) if it's in cache and has been // retrieved directly we need to fire the callback setTimeout( callback ); } else { handle = ++xhrId; if ( xhrOnUnloadAbort ) { + // Create the active xhrs callbacks list if needed // and attach the unload handler if ( !xhrCallbacks ) { xhrCallbacks = {}; jQuery( window ).unload( xhrOnUnloadAbort ); } + // Add to list of active xhrs callbacks xhrCallbacks[ handle ] = callback; } @@ -8629,7 +8899,7 @@ if ( xhrSupported ) { } }; } - }); + } ); } var fxNow, timerId, rfxtypes = /^(?:toggle|show|hide)$/, @@ -8637,7 +8907,7 @@ var fxNow, timerId, rrun = /queueHooks$/, animationPrefilters = [ defaultPrefilter ], tweeners = { - "*": [function( prop, value ) { + "*": [ function( prop, value ) { var end, unit, tween = this.createTween( prop, value ), parts = rfxnum.exec( value ), @@ -8647,17 +8917,19 @@ var fxNow, timerId, maxIterations = 20; if ( parts ) { - end = +parts[2]; - unit = parts[3] || ( jQuery.cssNumber[ prop ] ? "" : "px" ); + end = +parts[ 2 ]; + unit = parts[ 3 ] || ( jQuery.cssNumber[ prop ] ? "" : "px" ); // We need to compute starting value if ( unit !== "px" && start ) { + // Iteratively approximate from a nonzero starting point // Prefer the current property, because this process will be trivial if it uses the same units // Fallback to end or a simple constant start = jQuery.css( tween.elem, prop, true ) || end || 1; do { + // If previous iteration zeroed out, double until we get *something* // Use a string for doubling factor so we don't accidentally see scale as unchanged below scale = scale || ".5"; @@ -8668,23 +8940,24 @@ var fxNow, timerId, // Update scale, tolerating zero or NaN from tween.cur() // And breaking the loop if scale is unchanged or perfect, or if we've just had enough - } while ( scale !== (scale = tween.cur() / target) && scale !== 1 && --maxIterations ); + } while ( scale !== ( scale = tween.cur() / target ) && scale !== 1 && --maxIterations ); } tween.unit = unit; tween.start = start; + // If a +=/-= token was provided, we're doing a relative animation - tween.end = parts[1] ? start + ( parts[1] + 1 ) * end : end; + tween.end = parts[ 1 ] ? start + ( parts[ 1 ] + 1 ) * end : end; } return tween; - }] + } ] }; // Animations created synchronously will run synchronously function createFxNow() { - setTimeout(function() { + setTimeout( function() { fxNow = undefined; - }); + } ); return ( fxNow = jQuery.now() ); } @@ -8700,7 +8973,7 @@ function createTweens( animation, props ) { return; } } - }); + } ); } function Animation( elem, properties, options ) { @@ -8709,15 +8982,17 @@ function Animation( elem, properties, options ) { index = 0, length = animationPrefilters.length, deferred = jQuery.Deferred().always( function() { + // don't match elem in the :animated selector delete tick.elem; - }), + } ), tick = function() { if ( stopped ) { return false; } var currentTime = fxNow || createFxNow(), remaining = Math.max( 0, animation.startTime + animation.duration - currentTime ), + // archaic crash bug won't allow us to use 1 - ( 0.5 || 0 ) (#12497) temp = remaining / animation.duration || 0, percent = 1 - temp, @@ -8728,7 +9003,7 @@ function Animation( elem, properties, options ) { animation.tweens[ index ].run( percent ); } - deferred.notifyWith( elem, [ animation, percent, remaining ]); + deferred.notifyWith( elem, [ animation, percent, remaining ] ); if ( percent < 1 && length ) { return remaining; @@ -8737,7 +9012,7 @@ function Animation( elem, properties, options ) { return false; } }, - animation = deferred.promise({ + animation = deferred.promise( { elem: elem, props: jQuery.extend( {}, properties ), opts: jQuery.extend( true, { specialEasing: {} }, options ), @@ -8754,6 +9029,7 @@ function Animation( elem, properties, options ) { }, stop: function( gotoEnd ) { var index = 0, + // if we are going to the end, we want to run all the tweens // otherwise we skip this part length = gotoEnd ? animation.tweens.length : 0; @@ -8774,7 +9050,7 @@ function Animation( elem, properties, options ) { } return this; } - }), + } ), props = animation.props; propFilter( props, animation.opts.specialEasing ); @@ -8797,7 +9073,7 @@ function Animation( elem, properties, options ) { elem: elem, anim: animation, queue: animation.opts.queue - }) + } ) ); // attach callbacks from options @@ -8851,7 +9127,7 @@ jQuery.Animation = jQuery.extend( Animation, { callback = props; props = [ "*" ]; } else { - props = props.split(" "); + props = props.split( " " ); } var prop, @@ -8872,7 +9148,7 @@ jQuery.Animation = jQuery.extend( Animation, { animationPrefilters.push( callback ); } } -}); +} ); function defaultPrefilter( elem, props, opts ) { /*jshint validthis:true */ @@ -8899,20 +9175,22 @@ function defaultPrefilter( elem, props, opts ) { } hooks.unqueued++; - anim.always(function() { + anim.always( function() { + // doing this makes sure that the complete handler will be called // before this completes - anim.always(function() { + anim.always( function() { hooks.unqueued--; if ( !jQuery.queue( elem, "fx" ).length ) { hooks.empty.fire(); } - }); - }); + } ); + } ); } // height/width overflow pass if ( elem.nodeType === 1 && ( "height" in props || "width" in props ) ) { + // Make sure that nothing sneaks out // Record all 3 overflow attributes because IE does not // change the overflow attribute when overflowX and @@ -8938,15 +9216,14 @@ function defaultPrefilter( elem, props, opts ) { if ( opts.overflow ) { style.overflow = "hidden"; if ( !jQuery.support.shrinkWrapBlocks ) { - anim.always(function() { + anim.always( function() { style.overflow = opts.overflow[ 0 ]; style.overflowX = opts.overflow[ 1 ]; style.overflowY = opts.overflow[ 2 ]; - }); + } ); } } - // show/hide pass for ( index in props ) { value = props[ index ]; @@ -8974,17 +9251,17 @@ function defaultPrefilter( elem, props, opts ) { if ( hidden ) { jQuery( elem ).show(); } else { - anim.done(function() { + anim.done( function() { jQuery( elem ).hide(); - }); + } ); } - anim.done(function() { + anim.done( function() { var prop; jQuery._removeData( elem, "fxshow" ); for ( prop in orig ) { jQuery.style( elem, prop, orig[ prop ] ); } - }); + } ); for ( index = 0 ; index < length ; index++ ) { prop = handled[ index ]; tween = anim.createTween( prop, hidden ? dataShow[ prop ] : 0 ); @@ -9058,7 +9335,7 @@ Tween.propHooks = { var result; if ( tween.elem[ tween.prop ] != null && - (!tween.elem.style || tween.elem.style[ tween.prop ] == null) ) { + ( !tween.elem.style || tween.elem.style[ tween.prop ] == null ) ) { return tween.elem[ tween.prop ]; } @@ -9067,10 +9344,12 @@ Tween.propHooks = { // so, simple values such as "10px" are parsed to Float. // complex values such as "rotate(1rad)" are returned as is. result = jQuery.css( tween.elem, tween.prop, "" ); + // Empty strings, null, undefined and "auto" are converted to 0. return !result || result === "auto" ? 0 : result; }, set: function( tween ) { + // use step hook for back compat - use cssHook if its there - use .style if its // available and use plain properties where available if ( jQuery.fx.step[ tween.prop ] ) { @@ -9095,33 +9374,35 @@ Tween.propHooks.scrollTop = Tween.propHooks.scrollLeft = { } }; -jQuery.each([ "toggle", "show", "hide" ], function( i, name ) { +jQuery.each( [ "toggle", "show", "hide" ], function( i, name ) { var cssFn = jQuery.fn[ name ]; jQuery.fn[ name ] = function( speed, easing, callback ) { return speed == null || typeof speed === "boolean" ? cssFn.apply( this, arguments ) : this.animate( genFx( name, true ), speed, easing, callback ); }; -}); +} ); -jQuery.fn.extend({ +jQuery.fn.extend( { fadeTo: function( speed, to, easing, callback ) { // show any hidden elements after setting opacity to 0 return this.filter( isHidden ).css( "opacity", 0 ).show() // animate to the value specified - .end().animate({ opacity: to }, speed, easing, callback ); + .end().animate( { opacity: to }, speed, easing, callback ); }, animate: function( prop, speed, easing, callback ) { var empty = jQuery.isEmptyObject( prop ), optall = jQuery.speed( speed, easing, callback ), doAnimation = function() { + // Operate on a copy of prop so per-property easing won't be lost var anim = Animation( this, jQuery.extend( {}, prop ), optall ); doAnimation.finish = function() { anim.stop( true ); }; + // Empty animations, or finishing resolves immediately if ( empty || jQuery._data( this, "finish" ) ) { anim.stop( true ); @@ -9149,7 +9430,7 @@ jQuery.fn.extend({ this.queue( type || "fx", [] ); } - return this.each(function() { + return this.each( function() { var dequeue = true, index = type != null && type + "queueHooks", timers = jQuery.timers, @@ -9168,7 +9449,7 @@ jQuery.fn.extend({ } for ( index = timers.length; index--; ) { - if ( timers[ index ].elem === this && (type == null || timers[ index ].queue === type) ) { + if ( timers[ index ].elem === this && ( type == null || timers[ index ].queue === type ) ) { timers[ index ].anim.stop( gotoEnd ); dequeue = false; timers.splice( index, 1 ); @@ -9181,13 +9462,13 @@ jQuery.fn.extend({ if ( dequeue || !gotoEnd ) { jQuery.dequeue( this, type ); } - }); + } ); }, finish: function( type ) { if ( type !== false ) { type = type || "fx"; } - return this.each(function() { + return this.each( function() { var index, data = jQuery._data( this ), queue = data[ type + "queue" ], @@ -9222,9 +9503,9 @@ jQuery.fn.extend({ // turn off finishing flag delete data.finish; - }); + } ); } -}); +} ); // Generate parameters to create a standard animation function genFx( type, includeWidth ) { @@ -9234,8 +9515,8 @@ function genFx( type, includeWidth ) { // if we include width, step value is 1 to do all cssExpand values, // if we don't include width, step value is 2 to skip over Left and Right - includeWidth = includeWidth? 1 : 0; - for( ; i < 4 ; i += 2 - includeWidth ) { + includeWidth = includeWidth ? 1 : 0; + for ( ; i < 4 ; i += 2 - includeWidth ) { which = cssExpand[ i ]; attrs[ "margin" + which ] = attrs[ "padding" + which ] = type; } @@ -9248,10 +9529,10 @@ function genFx( type, includeWidth ) { } // Generate shortcuts for custom animations -jQuery.each({ - slideDown: genFx("show"), - slideUp: genFx("hide"), - slideToggle: genFx("toggle"), +jQuery.each( { + slideDown: genFx( "show" ), + slideUp: genFx( "hide" ), + slideToggle: genFx( "toggle" ), fadeIn: { opacity: "show" }, fadeOut: { opacity: "hide" }, fadeToggle: { opacity: "toggle" } @@ -9259,7 +9540,7 @@ jQuery.each({ jQuery.fn[ name ] = function( speed, easing, callback ) { return this.animate( props, speed, easing, callback ); }; -}); +} ); jQuery.speed = function( speed, easing, fn ) { var opt = speed && typeof speed === "object" ? jQuery.extend( {}, speed ) : { @@ -9298,7 +9579,7 @@ jQuery.easing = { return p; }, swing: function( p ) { - return 0.5 - Math.cos( p*Math.PI ) / 2; + return 0.5 - Math.cos( p * Math.PI ) / 2; } }; @@ -9313,6 +9594,7 @@ jQuery.fx.tick = function() { for ( ; i < timers.length; i++ ) { timer = timers[ i ]; + // Checks the timer has not already been removed if ( !timer() && timers[ i ] === timer ) { timers.splice( i--, 1 ); @@ -9347,6 +9629,7 @@ jQuery.fx.stop = function() { jQuery.fx.speeds = { slow: 600, fast: 200, + // Default speed _default: 400 }; @@ -9356,18 +9639,18 @@ jQuery.fx.step = {}; if ( jQuery.expr && jQuery.expr.filters ) { jQuery.expr.filters.animated = function( elem ) { - return jQuery.grep(jQuery.timers, function( fn ) { + return jQuery.grep( jQuery.timers, function( fn ) { return elem === fn.elem; - }).length; + } ).length; }; } jQuery.fn.offset = function( options ) { if ( arguments.length ) { return options === undefined ? this : - this.each(function( i ) { + this.each( function( i ) { jQuery.offset.setOffset( this, options, i ); - }); + } ); } var docElem, win, @@ -9412,7 +9695,7 @@ jQuery.offset = { curOffset = curElem.offset(), curCSSTop = jQuery.css( elem, "top" ), curCSSLeft = jQuery.css( elem, "left" ), - calculatePosition = ( position === "absolute" || position === "fixed" ) && jQuery.inArray("auto", [curCSSTop, curCSSLeft]) > -1, + calculatePosition = ( position === "absolute" || position === "fixed" ) && jQuery.inArray( "auto", [ curCSSTop, curCSSLeft ] ) > -1, props = {}, curPosition = {}, curTop, curLeft; // need to be able to calculate position if either top or left is auto and position is either absolute or fixed @@ -9444,8 +9727,7 @@ jQuery.offset = { } }; - -jQuery.fn.extend({ +jQuery.fn.extend( { position: function() { if ( !this[ 0 ] ) { @@ -9458,9 +9740,11 @@ jQuery.fn.extend({ // fixed elements are offset from window (parentOffset = {top:0, left: 0}, because it is it's only offset parent if ( jQuery.css( elem, "position" ) === "fixed" ) { + // we assume that getBoundingClientRect is available when computed position is fixed offset = elem.getBoundingClientRect(); } else { + // Get *real* offsetParent offsetParent = this.offsetParent(); @@ -9480,24 +9764,23 @@ jQuery.fn.extend({ // are the same in Safari causing offset.left to incorrectly be 0 return { top: offset.top - parentOffset.top - jQuery.css( elem, "marginTop", true ), - left: offset.left - parentOffset.left - jQuery.css( elem, "marginLeft", true) + left: offset.left - parentOffset.left - jQuery.css( elem, "marginLeft", true ) }; }, offsetParent: function() { - return this.map(function() { + return this.map( function() { var offsetParent = this.offsetParent || document.documentElement; - while ( offsetParent && ( !jQuery.nodeName( offsetParent, "html" ) && jQuery.css( offsetParent, "position") === "static" ) ) { + while ( offsetParent && ( !jQuery.nodeName( offsetParent, "html" ) && jQuery.css( offsetParent, "position" ) === "static" ) ) { offsetParent = offsetParent.offsetParent; } return offsetParent || document.documentElement; - }); + } ); } -}); - +} ); // Create scrollLeft and scrollTop methods -jQuery.each( {scrollLeft: "pageXOffset", scrollTop: "pageYOffset"}, function( method, prop ) { +jQuery.each( { scrollLeft: "pageXOffset", scrollTop: "pageYOffset" }, function( method, prop ) { var top = /Y/.test( prop ); jQuery.fn[ method ] = function( val ) { @@ -9505,7 +9788,7 @@ jQuery.each( {scrollLeft: "pageXOffset", scrollTop: "pageYOffset"}, function( me var win = getWindow( elem ); if ( val === undefined ) { - return win ? (prop in win) ? win[ prop ] : + return win ? ( prop in win ) ? win[ prop ] : win.document.documentElement[ method ] : elem[ method ]; } @@ -9521,7 +9804,7 @@ jQuery.each( {scrollLeft: "pageXOffset", scrollTop: "pageYOffset"}, function( me } }, method, val, arguments.length, null ); }; -}); +} ); function getWindow( elem ) { return jQuery.isWindow( elem ) ? @@ -9530,9 +9813,11 @@ function getWindow( elem ) { elem.defaultView || elem.parentWindow : false; } + // Create innerHeight, innerWidth, height, width, outerHeight and outerWidth methods jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { jQuery.each( { padding: "inner" + name, content: type, "": "outer" + name }, function( defaultExtra, funcName ) { + // margin is only for outerHeight, outerWidth jQuery.fn[ funcName ] = function( margin, value ) { var chainable = arguments.length && ( defaultExtra || typeof margin !== "boolean" ), @@ -9542,6 +9827,7 @@ jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { var doc; if ( jQuery.isWindow( elem ) ) { + // As of 5/8/2012 this will yield incorrect results for Mobile Safari, but there // isn't a whole lot we can do. See pull request at this URL for discussion: // https://github.com/jquery/jquery/pull/764 @@ -9562,6 +9848,7 @@ jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { } return value === undefined ? + // Get width or height on the element, requesting but not forcing parseFloat jQuery.css( elem, type, extra ) : @@ -9569,8 +9856,9 @@ jQuery.each( { Height: "height", Width: "width" }, function( name, type ) { jQuery.style( elem, type, value, extra ); }, type, chainable ? margin : undefined, chainable, null ); }; - }); -}); + } ); +} ); + // Limit scope pollution from any deprecated API // (function() { @@ -9591,7 +9879,7 @@ window.jQuery = window.$ = jQuery; // Do this after creating the global so that if an AMD module wants to call // noConflict to hide this version of jQuery, it will work. if ( typeof define === "function" && define.amd && define.amd.jQuery ) { - define( "jquery", [], function () { return jQuery; } ); + define( "jquery", [], function() { return jQuery; } ); } -})( window ); +} )( window ); diff --git a/test/data/readywaitloader.js b/test/data/readywaitloader.js index e07dac7a9..8f4a3452e 100644 --- a/test/data/readywaitloader.js +++ b/test/data/readywaitloader.js @@ -1,19 +1,19 @@ // Simple script loader that uses jQuery.readyWait via jQuery.holdReady() //Hold on jQuery! -jQuery.holdReady(true); +jQuery.holdReady( true ); var readyRegExp = /^(complete|loaded)$/; -function assetLoaded( evt ){ +function assetLoaded( evt ) { var node = evt.currentTarget || evt.srcElement; - if ( evt.type === "load" || readyRegExp.test(node.readyState) ) { - jQuery.holdReady(false); + if ( evt.type === "load" || readyRegExp.test( node.readyState ) ) { + jQuery.holdReady( false ); } } setTimeout( function() { - var script = document.createElement("script"); + var script = document.createElement( "script" ); script.type = "text/javascript"; if ( script.addEventListener ) { script.addEventListener( "load", assetLoaded, false ); @@ -21,5 +21,5 @@ setTimeout( function() { script.attachEvent( "onreadystatechange", assetLoaded ); } script.src = "data/readywaitasset.js"; - document.getElementsByTagName("head")[0].appendChild(script); + document.getElementsByTagName( "head" )[ 0 ].appendChild( script ); }, 2000 ); diff --git a/test/data/support/csp.js b/test/data/support/csp.js index a25bd8ae5..5ebdcea08 100644 --- a/test/data/support/csp.js +++ b/test/data/support/csp.js @@ -1,3 +1,3 @@ -jQuery(function() { +jQuery( function() { parent.iframeCallback( getComputedSupport( jQuery.support ) ); -}); +} ); diff --git a/test/data/testinit.js b/test/data/testinit.js index f56dba736..273436cf9 100644 --- a/test/data/testinit.js +++ b/test/data/testinit.js @@ -3,6 +3,7 @@ var fireNative, originaljQuery, original$, baseURL = "", supportjQuery = this.jQuery, + // see RFC 2606 externalHost = "example.com"; @@ -24,7 +25,7 @@ this.q = function() { i = 0; for ( ; i < arguments.length; i++ ) { - r.push( document.getElementById( arguments[i] ) ); + r.push( document.getElementById( arguments[ i ] ) ); } return r; }; @@ -38,7 +39,7 @@ this.q = function() { * @result returns true if "//[a]" return two elements with the IDs 'foo' and 'baar' */ this.t = function( a, b, c ) { - var f = jQuery(b).get(), + var f = jQuery( b ).get(), s = "", i = 0; @@ -46,7 +47,7 @@ this.t = function( a, b, c ) { s += ( s && "," ) + '"' + f[ i ].id + '"'; } - deepEqual(f, q.apply( q, c ), a + " (" + b + ")"); + deepEqual( f, q.apply( q, c ), a + " (" + b + ")" ); }; this.createDashboardXML = function() { @@ -62,7 +63,7 @@ this.createDashboardXML = function() { </locations> \ </dashboard>'; - return jQuery.parseXML(string); + return jQuery.parseXML( string ); }; this.createWithFriesXML = function() { @@ -98,13 +99,13 @@ this.createWithFriesXML = function() { this.createXMLFragment = function() { var xml, frag; if ( window.ActiveXObject ) { - xml = new ActiveXObject("msxml2.domdocument"); + xml = new ActiveXObject( "msxml2.domdocument" ); } else { xml = document.implementation.createDocument( "", "", null ); } if ( xml ) { - frag = xml.createElement("data"); + frag = xml.createElement( "data" ); } return frag; @@ -112,13 +113,13 @@ this.createXMLFragment = function() { fireNative = document.createEvent ? function( node, type ) { - var event = document.createEvent('HTMLEvents'); + var event = document.createEvent( "HTMLEvents" ); event.initEvent( type, true, true ); node.dispatchEvent( event ); } : function( node, type ) { var event = document.createEventObject(); - node.fireEvent( 'on' + type, event ); + node.fireEvent( "on" + type, event ); }; /** @@ -131,7 +132,7 @@ fireNative = document.createEvent ? * @result "data/test.php?foo=bar&10538358345554" */ function url( value ) { - return baseURL + value + (/\?/.test( value ) ? "&" : "?") + + return baseURL + value + ( /\?/.test( value ) ? "&" : "?" ) + new Date().getTime() + "" + parseInt( Math.random() * 100000, 10 ); } @@ -186,7 +187,7 @@ this.ajaxTest = function( title, expect, options ) { .done( callIfDefined( "done", "success" ) ) .fail( callIfDefined( "fail", "error" ) ) .always( complete ); - }); + } ); ajaxTest.abort = function( reason ) { if ( !completed ) { @@ -195,19 +196,19 @@ this.ajaxTest = function( title, expect, options ) { ok( false, "aborted " + reason ); jQuery.each( requests, function( i, request ) { request.abort(); - }); + } ); } }; - }); + } ); }; this.testIframe = function( fileName, name, fn ) { - asyncTest(name, function() { + asyncTest( name, function() { // load fixture in iframe var iframe = loadFixture(), win = iframe.contentWindow, - interval = setInterval(function() { + interval = setInterval( function() { if ( win && win.jQuery && win.jQuery.isReady ) { clearInterval( interval ); @@ -219,7 +220,7 @@ this.testIframe = function( fileName, name, fn ) { iframe = null; } }, 15 ); - }); + } ); function loadFixture() { var src = url( "./data/" + fileName + ".html" ), @@ -244,7 +245,7 @@ this.testIframeWithCallback = function( title, fileName, func ) { window.iframeCallback = function() { var self = this, args = arguments; - setTimeout(function() { + setTimeout( function() { window.iframeCallback = undefined; iframe.remove(); func.apply( self, args ); @@ -252,10 +253,10 @@ this.testIframeWithCallback = function( title, fileName, func ) { start(); }, 0 ); }; - iframe = jQuery( "<div/>" ).css({ position: "absolute", width: "500px", left: "-600px" }) + iframe = jQuery( "<div/>" ).css( { position: "absolute", width: "500px", left: "-600px" } ) .append( jQuery( "<iframe/>" ).attr( "src", url( "./data/" + fileName ) ) ) .appendTo( "#qunit-fixture" ); - }); + } ); }; window.iframeCallback = undefined; @@ -269,7 +270,7 @@ this.loadTests = function() { loadSwarm = url && url.indexOf( "http" ) === 0; // Get testSubproject from testrunner first - require([ "data/testrunner.js" ], function() { + require( [ "data/testrunner.js" ], function() { var tests = [ "unit/core.js", "unit/callbacks.js", @@ -294,7 +295,7 @@ this.loadTests = function() { ]; // Ensure load order (to preserve test numbers) - (function loadDep() { + ( function loadDep() { var dep = tests.shift(); if ( dep ) { @@ -312,14 +313,14 @@ this.loadTests = function() { // Load the TestSwarm listener if swarmURL is in the address. if ( loadSwarm ) { - require( [ "http://swarm.jquery.org/js/inject.js?" + (new Date()).getTime() ], + require( [ "http://swarm.jquery.org/js/inject.js?" + ( new Date() ).getTime() ], function() { QUnit.start(); - }); + } ); } else { QUnit.start(); } } - })(); - }); + } )(); + } ); }; diff --git a/test/data/testrunner.js b/test/data/testrunner.js index d1e8b8fa8..c60b152b1 100644 --- a/test/data/testrunner.js +++ b/test/data/testrunner.js @@ -1,4 +1,4 @@ -define(function() { +define( function() { // Store the old counts so that we only assert on tests that have actually leaked, // instead of asserting every time a test has leaked sometime in the past @@ -68,6 +68,7 @@ QUnit.expectJqData = function( env, elems, key ) { // be available as long as the object is not garbage collected by // the js engine, and when it is, the data will be removed with it. if ( !elem.nodeType ) { + // Fixes false positives for dataTests(window), dataTests({}). continue; } @@ -75,6 +76,7 @@ QUnit.expectJqData = function( env, elems, key ) { expando = elem[ jQuery.expando ]; if ( expando === undefined ) { + // In this case the element exists fine, but // jQuery.data (or internal data) was never (in)directly // called. @@ -98,12 +100,12 @@ QUnit.expectJqData = function( env, elems, key ) { } }; -QUnit.config.urlConfig.push({ +QUnit.config.urlConfig.push( { id: "jqdata", label: "Always check jQuery.data", tooltip: "Trigger QUnit.expectJqData detection for all tests " + "instead of just the ones that call it" -}); +} ); /** * Ensures that tests have cleaned up properly after themselves. Should be passed as the @@ -126,6 +128,7 @@ window.moduleTeardown = function() { delete jQuery.cache[ i ]; delete expectedDataKeys[ i ]; } + // In case it was removed from cache before (or never there in the first place) for ( i in expectedDataKeys ) { deepEqual( @@ -170,16 +173,18 @@ window.moduleTeardown = function() { } }; -QUnit.done(function() { +QUnit.done( function() { + // Remove our own fixtures outside #qunit-fixture supportjQuery( "#qunit ~ *" ).remove(); -}); +} ); // jQuery-specific post-test cleanup reset = function() { // Ensure jQuery events and data on the fixture are properly removed jQuery( "#qunit-fixture" ).empty(); + // ...even if the jQuery under test has a broken .empty() supportjQuery( "#qunit-fixture" ).empty(); @@ -199,7 +204,7 @@ QUnit.testDone( reset ); // Register globals for cleanup and the cleanup code itself // Explanation at http://perfectionkills.com/understanding-delete/#ie_bugs -window.Globals = (function() { +window.Globals = ( function() { var globals = {}; return { register: function( name ) { @@ -218,6 +223,6 @@ window.Globals = (function() { } } }; -})(); +} )(); -}); +} ); diff --git a/test/integration/data/gh-1764-fullscreen.js b/test/integration/data/gh-1764-fullscreen.js index c13c609f3..b2bb4cdb5 100644 --- a/test/integration/data/gh-1764-fullscreen.js +++ b/test/integration/data/gh-1764-fullscreen.js @@ -17,10 +17,10 @@ function bootstrapFrom( mainSelector, mode ) { document.webkitExitFullscreen; function isFullscreen() { - return !!(document.fullscreenElement || + return !!( document.fullscreenElement || document.mozFullScreenElement || document.webkitFullscreenElement || - document.msFullscreenElement); + document.msFullscreenElement ); } function requestFullscreen( element ) { @@ -82,7 +82,7 @@ function bootstrapFrom( mainSelector, mode ) { if ( isFullscreen() ) { exitFullscreen(); } else { - requestFullscreen( jQuery( mainSelector + " .container" )[0] ); + requestFullscreen( jQuery( mainSelector + " .container" )[ 0 ] ); } } diff --git a/test/jquery.js b/test/jquery.js index 2c1f15d6a..a595e3b47 100644 --- a/test/jquery.js +++ b/test/jquery.js @@ -1,5 +1,5 @@ // Use the right jQuery source on the test page (and iframes) -(function() { +( function() { /* global loadTests: false */ var src, @@ -8,11 +8,11 @@ require = window.require || parent.require; // Config parameter to force basic code paths - QUnit.config.urlConfig.push({ + QUnit.config.urlConfig.push( { id: "basic", label: "Bypass optimizations", tooltip: "Force use of the most basic code by disabling native querySelectorAll; contains; compareDocumentPosition; JSON.parse" - }); + } ); if ( QUnit.urlParams.basic ) { document.querySelectorAll = null; document.documentElement.contains = null; @@ -21,21 +21,23 @@ } // iFrames won't load AMD (the iframe tests synchronously expect jQuery to be there) - QUnit.config.urlConfig.push({ + QUnit.config.urlConfig.push( { id: "amd", label: "Load with AMD", tooltip: "Load the AMD jQuery file (and its dependencies)" - }); + } ); + // If QUnit is on window, this is the main window // This detection allows AMD tests to be run in an iframe if ( QUnit.urlParams.amd && window.QUnit ) { - require.config({ + require.config( { baseUrl: path, paths: { sizzle: "external/sizzle/dist/sizzle" } - }); + } ); src = "src/jquery"; + // Include tests if specified if ( typeof loadTests !== "undefined" ) { require( [ src ], loadTests ); @@ -46,11 +48,11 @@ } // Config parameter to use minified jQuery - QUnit.config.urlConfig.push({ + QUnit.config.urlConfig.push( { id: "dev", label: "Load unminified", tooltip: "Load the development (unminified) jQuery file" - }); + } ); if ( QUnit.urlParams.dev ) { src = "dist/jquery.js"; } else { @@ -63,7 +65,7 @@ // Synchronous-only tests // Other tests are loaded from the test page if ( typeof loadTests !== "undefined" ) { - document.write( "<script src='" + path + "test/unit/ready.js'><\x2Fscript>"); + document.write( "<script src='" + path + "test/unit/ready.js'><\x2Fscript>" ); } -})(); +} )(); diff --git a/test/node_smoke_tests/document_missing.js b/test/node_smoke_tests/document_missing.js index 4a0ad2e2b..348e9a4ef 100644 --- a/test/node_smoke_tests/document_missing.js +++ b/test/node_smoke_tests/document_missing.js @@ -4,7 +4,7 @@ var assert = require( "assert" ), ensureGlobalNotCreated = require( "./lib/ensure_global_not_created" ), jQueryFactory = require( "../../dist/jquery.js" ); -assert.throws( function () { +assert.throws( function() { jQueryFactory( {} ); }, /jQuery requires a window with a document/ ); diff --git a/test/promises-aplus-adapter.js b/test/promises-aplus-adapter.js index bb1587337..7768e2c85 100644 --- a/test/promises-aplus-adapter.js +++ b/test/promises-aplus-adapter.js @@ -1,7 +1,7 @@ /*jshint es3:false, node:true */ "use strict"; -require( "jsdom" ).env( "", function ( errors, window ) { +require( "jsdom" ).env( "", function( errors, window ) { if ( errors ) { console.error( errors ); return; @@ -9,7 +9,7 @@ require( "jsdom" ).env( "", function ( errors, window ) { var jQuery = require( ".." )( window ); - exports.deferred = function () { + exports.deferred = function() { var deferred = jQuery.Deferred(); return { @@ -20,4 +20,4 @@ require( "jsdom" ).env( "", function ( errors, window ) { reject: deferred.reject.bind( deferred ) }; }; -}); +} ); diff --git a/test/promises_aplus_adapter.js b/test/promises_aplus_adapter.js index decc3e0f0..c7440b969 100644 --- a/test/promises_aplus_adapter.js +++ b/test/promises_aplus_adapter.js @@ -2,7 +2,7 @@ "use strict"; -require( "jsdom" ).env( "", function ( errors, window ) { +require( "jsdom" ).env( "", function( errors, window ) { if ( errors ) { console.error( errors ); return; @@ -10,7 +10,7 @@ require( "jsdom" ).env( "", function ( errors, window ) { var jQuery = require( ".." )( window ); - exports.deferred = function () { + exports.deferred = function() { var deferred = jQuery.Deferred(); return { diff --git a/test/unit/ajax.js b/test/unit/ajax.js index a08a3755f..0dceb0251 100644 --- a/test/unit/ajax.js +++ b/test/unit/ajax.js @@ -17,15 +17,15 @@ module( "ajax", { jQuery( document ).off( "ajaxStart ajaxStop ajaxSend ajaxComplete ajaxError ajaxSuccess" ); moduleTeardown.apply( this, arguments ); } -}); +} ); -(function() { - test("Unit Testing Environment", function () { +( function() { + test( "Unit Testing Environment", function() { expect( 2 ); ok( hasPHP, "Running in an environment with PHP support. The AJAX tests only run if the environment supports PHP!" ); ok( !isLocal, "Unit tests are not ran from file:// (especially in Chrome. If you must test from file:// with Chrome, run it with the --allow-file-access-from-files flag!)" ); - }); + } ); if ( !jQuery.ajax || ( isLocal && !hasPHP ) ) { return; @@ -35,16 +35,16 @@ module( "ajax", { return function() { expected = expected || ""; jQuery( document ).on( "ajaxStart ajaxStop ajaxSend ajaxComplete ajaxError ajaxSuccess", function( e ) { - ok( expected.indexOf(e.type) !== -1, e.type ); - }); + ok( expected.indexOf( e.type ) !== -1, e.type ); + } ); }; } //----------- jQuery.ajax() ajaxTest( "jQuery.ajax() - success callbacks", 8, { - setup: addGlobalEvents("ajaxStart ajaxStop ajaxSend ajaxComplete ajaxSuccess"), - url: url("data/name.html"), + setup: addGlobalEvents( "ajaxStart ajaxStop ajaxSend ajaxComplete ajaxSuccess" ), + url: url( "data/name.html" ), beforeSend: function() { ok( true, "beforeSend" ); }, @@ -52,14 +52,14 @@ module( "ajax", { ok( true, "success" ); }, complete: function() { - ok( true, "complete"); + ok( true, "complete" ); } - }); + } ); ajaxTest( "jQuery.ajax() - success callbacks - (url, options) syntax", 8, { - setup: addGlobalEvents("ajaxStart ajaxStop ajaxSend ajaxComplete ajaxSuccess"), + setup: addGlobalEvents( "ajaxStart ajaxStop ajaxSend ajaxComplete ajaxSuccess" ), create: function( options ) { - return jQuery.ajax( url("data/name.html"), options ); + return jQuery.ajax( url( "data/name.html" ), options ); }, beforeSend: function() { ok( true, "beforeSend" ); @@ -70,47 +70,47 @@ module( "ajax", { complete: function() { ok( true, "complete" ); } - }); + } ); ajaxTest( "jQuery.ajax() - success callbacks (late binding)", 8, { - setup: addGlobalEvents("ajaxStart ajaxStop ajaxSend ajaxComplete ajaxSuccess"), - url: url("data/name.html"), + setup: addGlobalEvents( "ajaxStart ajaxStop ajaxSend ajaxComplete ajaxSuccess" ), + url: url( "data/name.html" ), beforeSend: function() { ok( true, "beforeSend" ); }, success: true, afterSend: function( request ) { - request.always(function() { + request.always( function() { ok( true, "complete" ); - }).done(function() { + } ).done( function() { ok( true, "success" ); - }).fail(function() { + } ).fail( function() { ok( false, "error" ); - }); + } ); } - }); + } ); ajaxTest( "jQuery.ajax() - success callbacks (oncomplete binding)", 8, { - setup: addGlobalEvents("ajaxStart ajaxStop ajaxSend ajaxComplete ajaxSuccess"), - url: url("data/name.html"), + setup: addGlobalEvents( "ajaxStart ajaxStop ajaxSend ajaxComplete ajaxSuccess" ), + url: url( "data/name.html" ), beforeSend: function() { ok( true, "beforeSend" ); }, success: true, complete: function( xhr ) { - xhr.always(function() { + xhr.always( function() { ok( true, "complete" ); - }).done(function() { + } ).done( function() { ok( true, "success" ); - }).fail(function() { + } ).fail( function() { ok( false, "error" ); - }); + } ); } - }); + } ); ajaxTest( "jQuery.ajax() - error callbacks", 8, { - setup: addGlobalEvents("ajaxStart ajaxStop ajaxSend ajaxComplete ajaxError"), - url: url("data/name.php?wait=5"), + setup: addGlobalEvents( "ajaxStart ajaxStop ajaxSend ajaxComplete ajaxError" ), + url: url( "data/name.php?wait=5" ), beforeSend: function() { ok( true, "beforeSend" ); }, @@ -123,11 +123,11 @@ module( "ajax", { complete: function() { ok( true, "complete" ); } - }); + } ); ajaxTest( "jQuery.ajax() - textStatus and errorThrown values", 4, [ { - url: url("data/name.php?wait=5"), + url: url( "data/name.php?wait=5" ), error: function( _, textStatus, errorThrown ) { strictEqual( textStatus, "abort", "textStatus is 'abort' for abort" ); strictEqual( errorThrown, "abort", "errorThrown is 'abort' for abort" ); @@ -137,37 +137,37 @@ module( "ajax", { } }, { - url: url("data/name.php?wait=5"), + url: url( "data/name.php?wait=5" ), error: function( _, textStatus, errorThrown ) { strictEqual( textStatus, "mystatus", "textStatus is 'mystatus' for abort('mystatus')" ); strictEqual( errorThrown, "mystatus", "errorThrown is 'mystatus' for abort('mystatus')" ); }, afterSend: function( request ) { - request.abort("mystatus"); + request.abort( "mystatus" ); } } - ]); + ] ); ajaxTest( "jQuery.ajax() - responseText on error", 1, { - url: url("data/errorWithText.php"), + url: url( "data/errorWithText.php" ), error: function( xhr ) { strictEqual( xhr.responseText, "plain text message", "Test jqXHR.responseText is filled for HTTP errors" ); } - }); + } ); asyncTest( "jQuery.ajax() - retry with jQuery.ajax( this )", 2, function() { var previousUrl, firstTime = true; - jQuery.ajax({ - url: url("data/errorWithText.php"), + jQuery.ajax( { + url: url( "data/errorWithText.php" ), error: function() { if ( firstTime ) { firstTime = false; jQuery.ajax( this ); } else { ok ( true, "Test retrying with jQuery.ajax(this) works" ); - jQuery.ajax({ - url: url("data/errorWithText.php"), + jQuery.ajax( { + url: url( "data/errorWithText.php" ), data: { "x": 1 }, @@ -183,19 +183,19 @@ module( "ajax", { error: function() { jQuery.ajax( this ); } - }); + } ); } } - }); - }); + } ); + } ); ajaxTest( "jQuery.ajax() - headers", 5, { setup: function() { - jQuery( document ).ajaxSend(function( evt, xhr ) { + jQuery( document ).ajaxSend( function( evt, xhr ) { xhr.setRequestHeader( "ajax-send", "test" ); - }); + } ); }, - url: url("data/headers.php?keys=siMPle_SometHing-elsE_OthEr_Nullable_undefined_Empty_ajax-send"), + url: url( "data/headers.php?keys=siMPle_SometHing-elsE_OthEr_Nullable_undefined_Empty_ajax-send" ), headers: { "siMPle": "value", "SometHing-elsE": "other value", @@ -212,58 +212,59 @@ module( "ajax", { var i, emptyHeader, requestHeaders = jQuery.extend( this.headers, { "ajax-send": "test" - }), + } ), tmp = []; for ( i in requestHeaders ) { tmp.push( i, ": ", requestHeaders[ i ] + "", "\n" ); } - tmp = tmp.join(""); + tmp = tmp.join( "" ); strictEqual( data, tmp, "Headers were sent" ); - strictEqual( xhr.getResponseHeader("Sample-Header"), "Hello World", "Sample header received" ); - ok( data.indexOf( "undefined" ) < 0 , "Undefined header value was not sent" ); + strictEqual( xhr.getResponseHeader( "Sample-Header" ), "Hello World", "Sample header received" ); + ok( data.indexOf( "undefined" ) < 0, "Undefined header value was not sent" ); - emptyHeader = xhr.getResponseHeader("Empty-Header"); + emptyHeader = xhr.getResponseHeader( "Empty-Header" ); if ( emptyHeader === null ) { ok( true, "Firefox doesn't support empty headers" ); } else { strictEqual( emptyHeader, "", "Empty header received" ); } - strictEqual( xhr.getResponseHeader("Sample-Header2"), "Hello World 2", "Second sample header received" ); + strictEqual( xhr.getResponseHeader( "Sample-Header2" ), "Hello World 2", "Second sample header received" ); } - }); + } ); ajaxTest( "jQuery.ajax() - Accept header", 1, { - url: url("data/headers.php?keys=accept"), + url: url( "data/headers.php?keys=accept" ), headers: { Accept: "very wrong accept value" }, beforeSend: function( xhr ) { - xhr.setRequestHeader("Accept", "*/*"); + xhr.setRequestHeader( "Accept", "*/*" ); }, success: function( data ) { strictEqual( data, "accept: */*\n", "Test Accept header is set to last value provided" ); } - }); + } ); ajaxTest( "jQuery.ajax() - contentType", 2, [ { - url: url("data/headers.php?keys=content-type"), + url: url( "data/headers.php?keys=content-type" ), contentType: "test", success: function( data ) { strictEqual( data, "content-type: test\n", "Test content-type is sent when options.contentType is set" ); } }, { - url: url("data/headers.php?keys=content-type"), + url: url( "data/headers.php?keys=content-type" ), contentType: false, success: function( data ) { + // Some server/interpreter combinations always supply a Content-Type to scripts data = data || "content-type: \n"; strictEqual( data, "content-type: \n", "Test content-type is not set when options.contentType===false" ); } } - ]); + ] ); ajaxTest( "jQuery.ajax() - protocol-less urls", 1, { url: "//somedomain.com", @@ -272,7 +273,7 @@ module( "ajax", { return false; }, error: true - }); + } ); ajaxTest( "jQuery.ajax() - hash", 3, [ { @@ -302,7 +303,7 @@ module( "ajax", { }, error: true } - ]); + ] ); ajaxTest( "jQuery.ajax() - cross-domain detection", 8, function() { function request( url, title, crossDomainOrOptions ) { @@ -360,11 +361,11 @@ module( "ajax", { "Cross-domain url with leading space is detected as cross-domain" ) ]; - }); + } ); ajaxTest( "jQuery.ajax() - abort", 9, { - setup: addGlobalEvents("ajaxStart ajaxStop ajaxSend ajaxError ajaxComplete"), - url: url("data/name.php?wait=5"), + setup: addGlobalEvents( "ajaxStart ajaxStop ajaxSend ajaxError ajaxComplete" ), + url: url( "data/name.php?wait=5" ), beforeSend: function() { ok( true, "beforeSend" ); }, @@ -377,11 +378,11 @@ module( "ajax", { complete: function() { ok( true, "complete" ); } - }); + } ); ajaxTest( "jQuery.ajax() - events with context", 12, function() { - var context = document.createElement("div"); + var context = document.createElement( "div" ); function event( e ) { equal( this, context, e.type ); @@ -395,27 +396,27 @@ module( "ajax", { return { setup: function() { - jQuery( context ).appendTo("#foo") + jQuery( context ).appendTo( "#foo" ) .ajaxSend( event ) .ajaxComplete( event ) .ajaxError( event ) .ajaxSuccess( event ); }, - requests: [{ - url: url("data/name.html"), + requests: [ { + url: url( "data/name.html" ), context: context, - beforeSend: callback("beforeSend"), - success: callback("success"), - complete: callback("complete") + beforeSend: callback( "beforeSend" ), + success: callback( "success" ), + complete: callback( "complete" ) }, { - url: url("data/404.html"), + url: url( "data/404.html" ), context: context, - beforeSend: callback("beforeSend"), - error: callback("error"), - complete: callback("complete") - }] + beforeSend: callback( "beforeSend" ), + error: callback( "error" ), + complete: callback( "complete" ) + } ] }; - }); + } ); ajaxTest( "jQuery.ajax() - events without context", 3, function() { function nocallback( msg ) { @@ -424,12 +425,12 @@ module( "ajax", { }; } return { - url: url("data/404.html"), - beforeSend: nocallback("beforeSend"), - error: nocallback("error"), - complete: nocallback("complete") + url: url( "data/404.html" ), + beforeSend: nocallback( "beforeSend" ), + error: nocallback( "error" ), + complete: nocallback( "complete" ) }; - }); + } ); ajaxTest( "#15118 - jQuery.ajax() - function without jQuery.event", 1, function() { var holder; @@ -445,27 +446,27 @@ module( "ajax", { }, success: true }; - }); + } ); ajaxTest( "#15160 - jQuery.ajax() - request manually aborted in ajaxSend", 3, { setup: function() { jQuery( document ).on( "ajaxSend", function( e, jqXHR ) { jqXHR.abort(); - }); + } ); jQuery( document ).on( "ajaxError ajaxComplete", function( e, jqXHR ) { equal( jqXHR.statusText, "abort", "jqXHR.statusText equals abort on global ajaxComplete and ajaxError events" ); - }); + } ); }, - url: url("data/name.html"), + url: url( "data/name.html" ), error: true, complete: function() { ok( true, "complete" ); } - }); + } ); ajaxTest( "jQuery.ajax() - context modification", 1, { - url: url("data/name.html"), + url: url( "data/name.html" ), context: {}, beforeSend: function() { this.test = "foo"; @@ -474,36 +475,36 @@ module( "ajax", { strictEqual( this.context.test, "foo", "Make sure the original object is maintained." ); }, success: true - }); + } ); ajaxTest( "jQuery.ajax() - context modification through ajaxSetup", 3, function() { var obj = {}; return { setup: function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { context: obj - }); + } ); strictEqual( jQuery.ajaxSettings.context, obj, "Make sure the context is properly set in ajaxSettings." ); }, - requests: [{ - url: url("data/name.html"), + requests: [ { + url: url( "data/name.html" ), success: function() { strictEqual( this, obj, "Make sure the original object is maintained." ); } }, { - url: url("data/name.html"), + url: url( "data/name.html" ), context: {}, success: function() { ok( this !== obj, "Make sure overriding context is possible." ); } - }] + } ] }; - }); + } ); ajaxTest( "jQuery.ajax() - disabled globals", 3, { - setup: addGlobalEvents(""), + setup: addGlobalEvents( "" ), global: false, - url: url("data/name.html"), + url: url( "data/name.html" ), beforeSend: function() { ok( true, "beforeSend" ); }, @@ -513,38 +514,38 @@ module( "ajax", { complete: function() { ok( true, "complete" ); } - }); + } ); ajaxTest( "jQuery.ajax() - xml: non-namespace elements inside namespaced elements", 3, { - url: url("data/with_fries.xml"), + url: url( "data/with_fries.xml" ), dataType: "xml", success: function( resp ) { equal( jQuery( "properties", resp ).length, 1, "properties in responseXML" ); equal( jQuery( "jsconf", resp ).length, 1, "jsconf in responseXML" ); equal( jQuery( "thing", resp ).length, 2, "things in responseXML" ); } - }); + } ); ajaxTest( "jQuery.ajax() - xml: non-namespace elements inside namespaced elements (over JSONP)", 3, { - url: url("data/with_fries_over_jsonp.php"), + url: url( "data/with_fries_over_jsonp.php" ), dataType: "jsonp xml", success: function( resp ) { equal( jQuery( "properties", resp ).length, 1, "properties in responseXML" ); equal( jQuery( "jsconf", resp ).length, 1, "jsconf in responseXML" ); equal( jQuery( "thing", resp ).length, 2, "things in responseXML" ); } - }); + } ); ajaxTest( "jQuery.ajax() - HEAD requests", 2, [ { - url: url("data/name.html"), + url: url( "data/name.html" ), type: "HEAD", success: function( data, status, xhr ) { ok( /Date/i.test( xhr.getAllResponseHeaders() ), "No Date in HEAD response" ); } }, { - url: url("data/name.html"), + url: url( "data/name.html" ), data: { "whip_it": "good" }, @@ -553,22 +554,22 @@ module( "ajax", { ok( /Date/i.test( xhr.getAllResponseHeaders() ), "No Date in HEAD response with data" ); } } - ]); + ] ); ajaxTest( "jQuery.ajax() - beforeSend", 1, { - url: url("data/name.html"), + url: url( "data/name.html" ), beforeSend: function() { this.check = true; }, success: function() { ok( this.check, "check beforeSend was executed" ); } - }); + } ); ajaxTest( "jQuery.ajax() - beforeSend, cancel request manually", 2, { create: function() { - return jQuery.ajax({ - url: url("data/name.html"), + return jQuery.ajax( { + url: url( "data/name.html" ), beforeSend: function( xhr ) { ok( true, "beforeSend got called, canceling" ); xhr.abort(); @@ -582,52 +583,52 @@ module( "ajax", { error: function() { ok( false, "request didn't get canceled" ); } - }); + } ); }, fail: function( _, reason ) { strictEqual( reason, "canceled", "canceled request must fail with 'canceled' status text" ); } - }); + } ); ajaxTest( "jQuery.ajax() - dataType html", 5, { setup: function() { - Globals.register("testFoo"); - Globals.register("testBar"); + Globals.register( "testFoo" ); + Globals.register( "testBar" ); }, dataType: "html", - url: url("data/test.html"), + url: url( "data/test.html" ), success: function( data ) { ok( data.match( /^html text/ ), "Check content for datatype html" ); - jQuery("#ap").html( data ); - strictEqual( window["testFoo"], "foo", "Check if script was evaluated for datatype html" ); - strictEqual( window["testBar"], "bar", "Check if script src was evaluated for datatype html" ); + jQuery( "#ap" ).html( data ); + strictEqual( window[ "testFoo" ], "foo", "Check if script was evaluated for datatype html" ); + strictEqual( window[ "testBar" ], "bar", "Check if script src was evaluated for datatype html" ); } - }); + } ); ajaxTest( "jQuery.ajax() - synchronous request", 1, { - url: url("data/json_obj.js"), + url: url( "data/json_obj.js" ), dataType: "text", async: false, success: true, afterSend: function( xhr ) { ok( /^\{ "data"/.test( xhr.responseText ), "check returned text" ); } - }); + } ); ajaxTest( "jQuery.ajax() - synchronous request with callbacks", 2, { - url: url("data/json_obj.js"), + url: url( "data/json_obj.js" ), async: false, dataType: "text", success: true, afterSend: function( xhr ) { var result; - xhr.done(function( data ) { + xhr.done( function( data ) { ok( true, "success callback executed" ); result = data; - }); + } ); ok( /^\{ "data"/.test( result ), "check returned text" ); } - }); + } ); asyncTest( "jQuery.ajax(), jQuery.get[Script|JSON](), jQuery.post(), pass-through request object", 8, function() { var target = "data/name.html", @@ -640,24 +641,24 @@ module( "ajax", { jQuery( document ).on( "ajaxError.passthru", function( e, xml ) { errorCount++; errorEx += ": " + xml.status; - }); + } ); jQuery( document ).one( "ajaxStop", function() { equal( successCount, 5, "Check all ajax calls successful" ); equal( errorCount, 0, "Check no ajax errors (status" + errorEx + ")" ); - jQuery( document ).off("ajaxError.passthru"); + jQuery( document ).off( "ajaxError.passthru" ); start(); - }); - Globals.register("testBar"); - - ok( jQuery.get( url(target), success ), "get" ); - ok( jQuery.post( url(target), success ), "post" ); - ok( jQuery.getScript( url("data/testbar.php"), success ), "script" ); - ok( jQuery.getJSON( url("data/json_obj.js"), success ), "json" ); - ok( jQuery.ajax({ + } ); + Globals.register( "testBar" ); + + ok( jQuery.get( url( target ), success ), "get" ); + ok( jQuery.post( url( target ), success ), "post" ); + ok( jQuery.getScript( url( "data/testbar.php" ), success ), "script" ); + ok( jQuery.getJSON( url( "data/json_obj.js" ), success ), "json" ); + ok( jQuery.ajax( { url: url( target ), success: success - }), "generic" ); - }); + } ), "generic" ); + } ); ajaxTest( "jQuery.ajax() - cache", 12, function() { @@ -669,7 +670,7 @@ module( "ajax", { cache: false, beforeSend: function() { var parameter, tmp; - while(( tmp = re.exec( this.url ) )) { + while ( ( tmp = re.exec( this.url ) ) ) { strictEqual( parameter, undefined, title + ": only one 'no-cache' parameter" ); parameter = tmp[ 1 ]; notStrictEqual( parameter, "tobereplaced555", title + ": parameter (if it was there) was replaced" ); @@ -706,7 +707,7 @@ module( "ajax", { "2 parameters surrounding _=" ) ]; - }); + } ); jQuery.each( [ " - Same Domain", " - Cross Domain" ], function( crossDomain, label ) { @@ -743,24 +744,24 @@ module( "ajax", { strictEqual( jQuery.type( data ), "array", "JSON results returned (GET, REST-like with param)" ); } } - ]); + ] ); ajaxTest( "jQuery.ajax() - JSONP - Explicit callback param" + label, 10, { setup: function() { - Globals.register("functionToCleanUp"); - Globals.register("XXX"); - Globals.register("jsonpResults"); - window["jsonpResults"] = function( data ) { - ok( data["data"], "JSON results returned (GET, custom callback function)" ); + Globals.register( "functionToCleanUp" ); + Globals.register( "XXX" ); + Globals.register( "jsonpResults" ); + window[ "jsonpResults" ] = function( data ) { + ok( data[ "data" ], "JSON results returned (GET, custom callback function)" ); }; }, - requests: [{ + requests: [ { url: "data/jsonp.php", dataType: "jsonp", crossDomain: crossDomain, jsonp: "callback", success: function( data ) { - ok( data["data"], "JSON results returned (GET, data obj callback)" ); + ok( data[ "data" ], "JSON results returned (GET, data obj callback)" ); } }, { url: "data/jsonp.php", @@ -781,10 +782,10 @@ module( "ajax", { crossDomain: crossDomain, jsonpCallback: "functionToCleanUp", success: function( data ) { - ok( data["data"], "JSON results returned (GET, custom callback name to be cleaned up)" ); - strictEqual( window["functionToCleanUp"], true, "Callback was removed (GET, custom callback name to be cleaned up)" ); + ok( data[ "data" ], "JSON results returned (GET, custom callback name to be cleaned up)" ); + strictEqual( window[ "functionToCleanUp" ], true, "Callback was removed (GET, custom callback name to be cleaned up)" ); var xhr; - jQuery.ajax({ + jQuery.ajax( { url: "data/jsonp.php", dataType: "jsonp", crossDomain: crossDomain, @@ -793,11 +794,11 @@ module( "ajax", { xhr = jqXHR; return false; } - }); - xhr.fail(function() { + } ); + xhr.fail( function() { ok( true, "Ajax error JSON (GET, custom callback name to be cleaned up)" ); - strictEqual( window["functionToCleanUp"], true, "Callback was removed after early abort (GET, custom callback name to be cleaned up)" ); - }); + strictEqual( window[ "functionToCleanUp" ], true, "Callback was removed after early abort (GET, custom callback name to be cleaned up)" ); + } ); } }, { url: "data/jsonp.php?callback=XXX", @@ -809,10 +810,10 @@ module( "ajax", { ok( /^data\/jsonp.php\?callback=XXX&_=\d+$/.test( this.url ), "The URL wasn't messed with (GET, custom callback name with no url manipulation)" ); }, success: function( data ) { - ok( data["data"], "JSON results returned (GET, custom callback name with no url manipulation)" ); + ok( data[ "data" ], "JSON results returned (GET, custom callback name with no url manipulation)" ); } - }] - }); + } ] + } ); ajaxTest( "jQuery.ajax() - JSONP - Callback in data" + label, 2, [ { @@ -833,8 +834,7 @@ module( "ajax", { ok( data.data, "JSON results returned (GET, data context-free callback)" ); } } - ]); - + ] ); ajaxTest( "jQuery.ajax() - JSONP - POST" + label, 3, [ { @@ -843,7 +843,7 @@ module( "ajax", { dataType: "jsonp", crossDomain: crossDomain, success: function( data ) { - ok( data["data"], "JSON results returned (POST, no callback)" ); + ok( data[ "data" ], "JSON results returned (POST, no callback)" ); } }, { @@ -853,7 +853,7 @@ module( "ajax", { dataType: "jsonp", crossDomain: crossDomain, success: function( data ) { - ok( data["data"], "JSON results returned (POST, data callback)" ); + ok( data[ "data" ], "JSON results returned (POST, data callback)" ); } }, { @@ -863,10 +863,10 @@ module( "ajax", { dataType: "jsonp", crossDomain: crossDomain, success: function( data ) { - ok( data["data"], "JSON results returned (POST, data obj callback)" ); + ok( data[ "data" ], "JSON results returned (POST, data obj callback)" ); } } - ]); + ] ); ajaxTest( "jQuery.ajax() - JSONP" + label, 3, [ { @@ -880,14 +880,14 @@ module( "ajax", { { create: function( options ) { var request = jQuery.ajax( options ), - promise = request.then(function( data ) { + promise = request.then( function( data ) { ok( data.data, "first request: JSON results returned (GET, no callback)" ); - request = jQuery.ajax( this ).done(function( data ) { + request = jQuery.ajax( this ).done( function( data ) { ok( data.data, "this re-used: JSON results returned (GET, no callback)" ); - }); + } ); promise.abort = request.abort; return request; - }); + } ); promise.abort = request.abort; return promise; }, @@ -896,44 +896,44 @@ module( "ajax", { crossDomain: crossDomain, success: true } - ]); + ] ); - }); + } ); ajaxTest( "jQuery.ajax() - script, Remote", 2, { setup: function() { - Globals.register("testBar"); + Globals.register( "testBar" ); }, url: window.location.href.replace( /[^\/]*$/, "" ) + "data/testbar.php", dataType: "script", success: function() { - strictEqual( window["testBar"], "bar", "Script results returned (GET, no callback)" ); + strictEqual( window[ "testBar" ], "bar", "Script results returned (GET, no callback)" ); } - }); + } ); ajaxTest( "jQuery.ajax() - script, Remote with POST", 3, { setup: function() { - Globals.register("testBar"); + Globals.register( "testBar" ); }, url: window.location.href.replace( /[^\/]*$/, "" ) + "data/testbar.php", type: "POST", dataType: "script", success: function( data, status ) { - strictEqual( window["testBar"], "bar", "Script results returned (POST, no callback)" ); + strictEqual( window[ "testBar" ], "bar", "Script results returned (POST, no callback)" ); strictEqual( status, "success", "Script results returned (POST, no callback)" ); } - }); + } ); ajaxTest( "jQuery.ajax() - script, Remote with scheme-less URL", 2, { setup: function() { - Globals.register("testBar"); + Globals.register( "testBar" ); }, url: window.location.href.replace( /[^\/]*$/, "" ).replace( /^.*?\/\//, "//" ) + "data/testbar.php", dataType: "script", success: function() { - strictEqual( window["testBar"], "bar", "Script results returned (GET, no callback)" ); + strictEqual( window[ "testBar" ], "bar", "Script results returned (GET, no callback)" ); } - }); + } ); ajaxTest( "jQuery.ajax() - malformed JSON", 2, { url: "data/badjson.js", @@ -942,7 +942,7 @@ module( "ajax", { strictEqual( msg, "parsererror", "A parse error occurred." ); ok( /(invalid|error|exception)/i.test( detailedMsg ), "Detailed parsererror message provided" ); } - }); + } ); ajaxTest( "jQuery.ajax() - script by content-type", 2, [ { @@ -959,7 +959,7 @@ module( "ajax", { }, success: true } - ]); + ] ); ajaxTest( "jQuery.ajax() - JSON by content-type", 5, { url: "data/json.php", @@ -969,15 +969,15 @@ module( "ajax", { }, success: function( json ) { ok( json.length >= 2, "Check length" ); - strictEqual( json[ 0 ]["name"], "John", "Check JSON: first, name" ); - strictEqual( json[ 0 ]["age"], 21, "Check JSON: first, age" ); - strictEqual( json[ 1 ]["name"], "Peter", "Check JSON: second, name" ); - strictEqual( json[ 1 ]["age"], 25, "Check JSON: second, age" ); + strictEqual( json[ 0 ][ "name" ], "John", "Check JSON: first, name" ); + strictEqual( json[ 0 ][ "age" ], 21, "Check JSON: first, age" ); + strictEqual( json[ 1 ][ "name" ], "Peter", "Check JSON: second, name" ); + strictEqual( json[ 1 ][ "age" ], 25, "Check JSON: second, age" ); } - }); + } ); ajaxTest( "jQuery.ajax() - JSON by content-type disabled with options", 6, { - url: url("data/json.php"), + url: url( "data/json.php" ), data: { "header": "json", "json": "array" @@ -988,30 +988,30 @@ module( "ajax", { success: function( text ) { strictEqual( typeof text, "string", "json wasn't auto-determined" ); var json = jQuery.parseJSON( text ); - ok( json.length >= 2, "Check length"); - strictEqual( json[ 0 ]["name"], "John", "Check JSON: first, name" ); - strictEqual( json[ 0 ]["age"], 21, "Check JSON: first, age" ); - strictEqual( json[ 1 ]["name"], "Peter", "Check JSON: second, name" ); - strictEqual( json[ 1 ]["age"], 25, "Check JSON: second, age" ); + ok( json.length >= 2, "Check length" ); + strictEqual( json[ 0 ][ "name" ], "John", "Check JSON: first, name" ); + strictEqual( json[ 0 ][ "age" ], 21, "Check JSON: first, age" ); + strictEqual( json[ 1 ][ "name" ], "Peter", "Check JSON: second, name" ); + strictEqual( json[ 1 ][ "age" ], 25, "Check JSON: second, age" ); } - }); + } ); ajaxTest( "jQuery.ajax() - simple get", 1, { type: "GET", - url: url("data/name.php?name=foo"), + url: url( "data/name.php?name=foo" ), success: function( msg ) { strictEqual( msg, "bar", "Check for GET" ); } - }); + } ); ajaxTest( "jQuery.ajax() - simple post", 1, { type: "POST", - url: url("data/name.php"), + url: url( "data/name.php" ), data: "name=peter", success: function( msg ) { strictEqual( msg, "pan", "Check for POST" ); } - }); + } ); ajaxTest( "jQuery.ajax() - data option - empty bodies for non-GET requests", 1, { url: "data/echoData.php", @@ -1020,7 +1020,7 @@ module( "ajax", { success: function( result ) { strictEqual( result, "" ); } - }); + } ); var ifModifiedNow = new Date(); @@ -1034,14 +1034,14 @@ module( "ajax", { asyncTest( "jQuery.ajax() - If-Modified-Since support" + label, 4, function() { var url = "data/if_modified_since.php?ts=" + ifModifiedNow++; - jQuery.ajax({ + jQuery.ajax( { url: url, ifModified: true, cache: cache, success: function( data, status ) { strictEqual( status, "success" ); - jQuery.ajax({ + jQuery.ajax( { url: url, ifModified: true, cache: cache, @@ -1053,22 +1053,22 @@ module( "ajax", { complete: function() { start(); } - }); + } ); } - }); - }); + } ); + } ); asyncTest( "jQuery.ajax() - Etag support" + label, 3, function() { var url = "data/etag.php?ts=" + ifModifiedNow++; - jQuery.ajax({ + jQuery.ajax( { url: url, ifModified: true, cache: cache, success: function( data, status ) { strictEqual( status, "success" ); - jQuery.ajax({ + jQuery.ajax( { url: url, ifModified: true, cache: cache, @@ -1079,54 +1079,56 @@ module( "ajax", { complete: function() { start(); } - }); + } ); } - }); - }); + } ); + } ); } /* jQuery.each arguments end */ ); ajaxTest( "jQuery.ajax() - failing cross-domain (non-existing)", 1, { + // see RFC 2606 url: "http://example.invalid", error: function( xhr, _, e ) { ok( true, "file not found: " + xhr.status + " => " + e ); } - }); + } ); ajaxTest( "jQuery.ajax() - failing cross-domain", 1, { url: "http://" + externalHost, error: function( xhr, _, e ) { ok( true, "access denied: " + xhr.status + " => " + e ); } - }); + } ); ajaxTest( "jQuery.ajax() - atom+xml", 1, { - url: url("data/atom+xml.php"), + url: url( "data/atom+xml.php" ), success: function() { ok( true, "success" ); } - }); + } ); asyncTest( "jQuery.ajax() - statusText", 3, function() { - jQuery.ajax( url("data/statusText.php?status=200&text=Hello") ).done(function( _, statusText, jqXHR ) { + jQuery.ajax( url( "data/statusText.php?status=200&text=Hello" ) ).done( function( _, statusText, jqXHR ) { strictEqual( statusText, "success", "callback status text ok for success" ); ok( jqXHR.statusText === "Hello" || jqXHR.statusText === "OK", "jqXHR status text ok for success (" + jqXHR.statusText + ")" ); - jQuery.ajax( url("data/statusText.php?status=404&text=World") ).fail(function( jqXHR, statusText ) { + jQuery.ajax( url( "data/statusText.php?status=404&text=World" ) ).fail( function( jqXHR, statusText ) { strictEqual( statusText, "error", "callback status text ok for error" ); + // ok( jqXHR.statusText === "World" || jQuery.browser.safari && jqXHR.statusText === "Not Found", "jqXHR status text ok for error (" + jqXHR.statusText + ")" ); start(); - }); - }); - }); + } ); + } ); + } ); asyncTest( "jQuery.ajax() - statusCode", 20, function() { var count = 12; function countComplete() { - if ( ! --count ) { + if ( !--count ) { start(); } } @@ -1151,45 +1153,45 @@ module( "ajax", { }, function( uri, isSuccess ) { - jQuery.ajax( url(uri), { + jQuery.ajax( url( uri ), { statusCode: createStatusCodes( "in options", isSuccess ), complete: countComplete - }); + } ); - jQuery.ajax( url(uri), { + jQuery.ajax( url( uri ), { complete: countComplete - }).statusCode( createStatusCodes("immediately with method", isSuccess) ); + } ).statusCode( createStatusCodes( "immediately with method", isSuccess ) ); - jQuery.ajax( url(uri), { + jQuery.ajax( url( uri ), { complete: function( jqXHR ) { - jqXHR.statusCode( createStatusCodes("on complete", isSuccess) ); + jqXHR.statusCode( createStatusCodes( "on complete", isSuccess ) ); countComplete(); } - }); + } ); - jQuery.ajax( url(uri), { + jQuery.ajax( url( uri ), { complete: function( jqXHR ) { - setTimeout(function() { - jqXHR.statusCode( createStatusCodes("very late binding", isSuccess) ); + setTimeout( function() { + jqXHR.statusCode( createStatusCodes( "very late binding", isSuccess ) ); countComplete(); }, 100 ); } - }); + } ); - jQuery.ajax( url(uri), { + jQuery.ajax( url( uri ), { statusCode: createStatusCodes( "all (options)", isSuccess ), complete: function( jqXHR ) { - jqXHR.statusCode( createStatusCodes("all (on complete)", isSuccess) ); - setTimeout(function() { - jqXHR.statusCode( createStatusCodes("all (very late binding)", isSuccess) ); + jqXHR.statusCode( createStatusCodes( "all (on complete)", isSuccess ) ); + setTimeout( function() { + jqXHR.statusCode( createStatusCodes( "all (very late binding)", isSuccess ) ); countComplete(); }, 100 ); } - }).statusCode( createStatusCodes("all (immediately with method)", isSuccess) ); + } ).statusCode( createStatusCodes( "all (immediately with method)", isSuccess ) ); var testString = ""; - jQuery.ajax( url(uri), { + jQuery.ajax( url( uri ), { success: function( a, b, jqXHR ) { ok( isSuccess, "success" ); var statusCode = {}; @@ -1216,16 +1218,16 @@ module( "ajax", { ); countComplete(); } - }); + } ); } /* jQuery.each arguments end*/ ); - }); + } ); ajaxTest( "jQuery.ajax() - transitive conversions", 8, [ { - url: url("data/json.php"), + url: url( "data/json.php" ), converters: { "json myJson": function( data ) { ok( true, "converter called" ); @@ -1240,7 +1242,7 @@ module( "ajax", { } }, { - url: url("data/json.php"), + url: url( "data/json.php" ), converters: { "json myJson": function( data ) { ok( true, "converter called (*)" ); @@ -1255,11 +1257,11 @@ module( "ajax", { strictEqual( this.dataTypes[ 1 ], "myjson", "request expected myjson dataType (*)" ); } } - ]); + ] ); ajaxTest( "jQuery.ajax() - overrideMimeType", 2, [ { - url: url("data/json.php"), + url: url( "data/json.php" ), beforeSend: function( xhr ) { xhr.overrideMimeType( "application/json" ); }, @@ -1268,26 +1270,26 @@ module( "ajax", { } }, { - url: url("data/json.php"), + url: url( "data/json.php" ), mimeType: "application/json", success: function( json ) { ok( json.data, "Mimetype overridden using mimeType option" ); } } - ]); + ] ); ajaxTest( "jQuery.ajax() - empty json gets to error callback instead of success callback.", 1, { - url: url("data/echoData.php"), + url: url( "data/echoData.php" ), error: function( _, __, error ) { equal( typeof error === "object", true, "Didn't get back error object for empty json response" ); }, dataType: "json" - }); + } ); ajaxTest( "#2688 - jQuery.ajax() - beforeSend, cancel request", 2, { create: function() { - return jQuery.ajax({ - url: url("data/name.html"), + return jQuery.ajax( { + url: url( "data/name.html" ), beforeSend: function() { ok( true, "beforeSend got called, canceling" ); return false; @@ -1301,12 +1303,12 @@ module( "ajax", { error: function() { ok( false, "request didn't get canceled" ); } - }); + } ); }, fail: function( _, reason ) { strictEqual( reason, "canceled", "canceled request must fail with 'canceled' status text" ); } - }); + } ); ajaxTest( "#2806 - jQuery.ajax() - data option - evaluate function values", 1, { url: "data/echoQuery.php", @@ -1318,24 +1320,24 @@ module( "ajax", { success: function( result ) { strictEqual( result, "key=value" ); } - }); + } ); - test( "#7531 - jQuery.ajax() - Location object as url", function () { + test( "#7531 - jQuery.ajax() - Location object as url", function() { expect( 1 ); var xhr, success = false; try { - xhr = jQuery.ajax({ + xhr = jQuery.ajax( { url: window.location - }); + } ); success = true; xhr.abort(); - } catch (e) { + } catch ( e ) { } ok( success, "document.location did not generate exception" ); - }); + } ); jQuery.each( [ " - Same Domain", " - Cross Domain" ], function( crossDomain, label ) { ajaxTest( "#7578 - jQuery.ajax() - JSONP - default for cache option" + label, 1, { @@ -1347,8 +1349,8 @@ module( "ajax", { return false; }, error: true - }); - }); + } ); + } ); ajaxTest( "#8107 - jQuery.ajax() - multiple method signatures introduced in 1.5", 4, [ { @@ -1361,7 +1363,7 @@ module( "ajax", { }, { create: function() { - return jQuery.ajax("data/name.html"); + return jQuery.ajax( "data/name.html" ); }, done: function() { ok( true, "With only string URL argument" ); @@ -1369,7 +1371,7 @@ module( "ajax", { }, { create: function() { - return jQuery.ajax( "data/name.html", {}); + return jQuery.ajax( "data/name.html", {} ); }, done: function() { ok( true, "With string URL param and map" ); @@ -1384,7 +1386,7 @@ module( "ajax", { ok( true, "With only map" ); } } - ]); + ] ); jQuery.each( [ " - Same Domain", " - Cross Domain" ], function( crossDomain, label ) { ajaxTest( "#8205 - jQuery.ajax() - JSONP - re-use callbacks name" + label, 4, { @@ -1415,7 +1417,7 @@ module( "ajax", { ); } - jQuery.ajax({ + jQuery.ajax( { url: "data/jsonp.php", dataType: "jsonp", crossDomain: crossDomain, @@ -1423,12 +1425,12 @@ module( "ajax", { strictEqual( this.jsonpCallback, previous.callback, "JSONP callback name is re-used" ); return false; } - }); + } ); } - }); - }); + } ); + } ); - test( "#9887 - jQuery.ajax() - Context with circular references (#9887)", function () { + test( "#9887 - jQuery.ajax() - Context with circular references (#9887)", function() { expect( 2 ); var success = false, @@ -1441,13 +1443,13 @@ module( "ajax", { ok( this === context, "context was not deep extended" ); return false; } - }); + } ); success = true; } catch ( e ) { console.log( e ); } ok( success, "context with circular reference did not generate an exception" ); - }); + } ); jQuery.each( [ "as argument", "in settings object" ], function( inSetting, title ) { @@ -1467,12 +1469,12 @@ module( "ajax", { request( false ), request( null ), request( undefined ) - ]); + ] ); - }); + } ); ajaxTest( "#11151 - jQuery.ajax() - parse error body", 2, { - url: url("data/errorWithJSON.php"), + url: url( "data/errorWithJSON.php" ), dataFilter: function( string ) { ok( false, "dataFilter called" ); return string; @@ -1481,16 +1483,17 @@ module( "ajax", { strictEqual( jqXHR.responseText, "{ \"code\": 40, \"message\": \"Bad Request\" }", "Error body properly set" ); deepEqual( jqXHR.responseJSON, { code: 40, message: "Bad Request" }, "Error body properly parsed" ); } - }); + } ); ajaxTest( "#11426 - jQuery.ajax() - loading binary data shouldn't throw an exception in IE", 1, { - url: url("data/1x1.jpg"), + url: url( "data/1x1.jpg" ), success: function( data ) { ok( data === undefined || /JFIF/.test( data ), "success callback reached" ); } - }); + } ); asyncTest( "#11743 - jQuery.ajax() - script, throws exception", 1, function() { + // Support: Android 2.3 only // Android 2.3 doesn't fire the window.onerror handler, just accept the reality there. if ( /android 2\.3/i.test( navigator.userAgent ) ) { @@ -1506,18 +1509,18 @@ module( "ajax", { window.onerror = onerror; start(); }; - jQuery.ajax({ + jQuery.ajax( { url: "data/badjson.js", dataType: "script", "throws": true - }); - }); + } ); + } ); jQuery.each( [ "method", "type" ], function( _, globalOption ) { function request( option ) { var options = { - url: url("data/echoData.php"), + url: url( "data/echoData.php" ), data: "hello", success: function( msg ) { strictEqual( msg, "hello", "Check for POST (no override)" ); @@ -1539,35 +1542,36 @@ module( "ajax", { jQuery.ajaxSetup( options ); }, requests: [ - request("type"), - request("method"), + request( "type" ), + request( "method" ), request() ] - }); + } ); - }); + } ); ajaxTest( "#13276 - jQuery.ajax() - compatibility between XML documents from ajax requests and parsed string", 1, { url: "data/dashboard.xml", dataType: "xml", success: function( ajaxXML ) { - var parsedXML = jQuery( jQuery.parseXML("<tab title=\"Added\">blibli</tab>") ).find("tab"); + var parsedXML = jQuery( jQuery.parseXML( "<tab title=\"Added\">blibli</tab>" ) ).find( "tab" ); ajaxXML = jQuery( ajaxXML ); try { + // Android 2.3 doesn't automatically adopt nodes from foreign documents. // (see the comment in test/manipulation.js) // Support: Android 2.3 if ( /android 2\.3/i.test( navigator.userAgent ) ) { parsedXML = jQuery( ajaxXML[ 0 ].adoptNode( parsedXML[ 0 ] ) ); } - ajaxXML.find("infowindowtab").append( parsedXML ); - } catch( e ) { + ajaxXML.find( "infowindowtab" ).append( parsedXML ); + } catch ( e ) { strictEqual( e, undefined, "error" ); return; } - strictEqual( ajaxXML.find("tab").length, 3, "Parsed node was added properly" ); + strictEqual( ajaxXML.find( "tab" ).length, 3, "Parsed node was added properly" ); } - }); + } ); ajaxTest( "#13292 - jQuery.ajax() - converter is bypassed for 204 requests", 3, { url: "data/nocontent.php", @@ -1587,17 +1591,17 @@ module( "ajax", { strictEqual( status, "parsererror", "Parser Error" ); strictEqual( error, "converter was called", "Converter was called" ); } - }); + } ); ajaxTest( "#13388 - jQuery.ajax() - responseXML", 3, { - url: url("data/with_fries.xml"), + url: url( "data/with_fries.xml" ), dataType: "xml", success: function( resp, _, jqXHR ) { notStrictEqual( resp, undefined, "XML document exists" ); ok( "responseXML" in jqXHR, "jqXHR.responseXML exists" ); strictEqual( resp, jqXHR.responseXML, "jqXHR.responseXML is set correctly" ); } - }); + } ); ajaxTest( "#13922 - jQuery.ajax() - converter is bypassed for HEAD requests", 3, { url: "data/json.php", @@ -1641,19 +1645,20 @@ module( "ajax", { testIframeWithCallback( "#14379 - jQuery.ajax() on unload", "ajax/onunload.html", function( status ) { expect( 1 ); strictEqual( status, "success", "Request completed" ); - }); + } ); //----------- jQuery.ajaxPrefilter() ajaxTest( "jQuery.ajaxPrefilter() - abort", 1, { dataType: "prefix", setup: function() { + // Ensure prefix does not throw an error - jQuery.ajaxPrefilter("+prefix", function( options, _, jqXHR ) { + jQuery.ajaxPrefilter( "+prefix", function( options, _, jqXHR ) { if ( options.abortInPrefilter ) { jqXHR.abort(); } - }); + } ); }, abortInPrefilter: true, error: function() { @@ -1662,27 +1667,27 @@ module( "ajax", { fail: function( _, reason ) { strictEqual( reason, "canceled", "Request aborted by the prefilter must fail with 'canceled' status text" ); } - }); + } ); //----------- jQuery.ajaxSetup() asyncTest( "jQuery.ajaxSetup()", 1, function() { - jQuery.ajaxSetup({ - url: url("data/name.php?name=foo"), + jQuery.ajaxSetup( { + url: url( "data/name.php?name=foo" ), success: function( msg ) { strictEqual( msg, "bar", "Check for GET" ); start(); } - }); + } ); jQuery.ajax(); - }); + } ); asyncTest( "jQuery.ajaxSetup({ timeout: Number }) - with global timeout", 2, function() { var passed = 0, pass = function() { ok( passed++ < 2, "Error callback executed" ); if ( passed === 2 ) { - jQuery( document ).off("ajaxError.setupTest"); + jQuery( document ).off( "ajaxError.setupTest" ); start(); } }, @@ -1693,26 +1698,26 @@ module( "ajax", { jQuery( document ).on( "ajaxError.setupTest", pass ); - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { timeout: 1000 - }); + } ); - jQuery.ajax({ + jQuery.ajax( { type: "GET", - url: url("data/name.php?wait=5"), + url: url( "data/name.php?wait=5" ), error: pass, success: fail - }); - }); + } ); + } ); asyncTest( "jQuery.ajaxSetup({ timeout: Number }) with localtimeout", 1, function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { timeout: 50 - }); - jQuery.ajax({ + } ); + jQuery.ajax( { type: "GET", timeout: 15000, - url: url("data/name.php?wait=1"), + url: url( "data/name.php?wait=1" ), error: function() { ok( false, "Check for local timeout failed" ); start(); @@ -1721,100 +1726,100 @@ module( "ajax", { ok( true, "Check for local timeout" ); start(); } - }); - }); + } ); + } ); //----------- jQuery.domManip() test( "#11264 - jQuery.domManip() - no side effect because of ajaxSetup or global events", function() { expect( 1 ); - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { type: "POST" - }); + } ); jQuery( document ).on( "ajaxStart ajaxStop", function() { ok( false, "Global event triggered" ); - }); + } ); - jQuery("#qunit-fixture").append("<script src='data/ajax/evalScript.php'></script>"); + jQuery( "#qunit-fixture" ).append( "<script src='data/ajax/evalScript.php'></script>" ); - jQuery( document ).off("ajaxStart ajaxStop"); - }); + jQuery( document ).off( "ajaxStart ajaxStop" ); + } ); asyncTest( "jQuery#load() - always use GET method even if it overrided through ajaxSetup (#11264)", 1, function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { type: "POST" - }); + } ); jQuery( "#qunit-fixture" ).load( "data/ajax/method.php", function( method ) { equal( method, "GET" ); start(); - }); - }); + } ); + } ); asyncTest( "#11402 - jQuery.domManip() - script in comments are properly evaluated", 2, function() { - jQuery("#qunit-fixture").load( "data/cleanScript.html", start ); - }); + jQuery( "#qunit-fixture" ).load( "data/cleanScript.html", start ); + } ); //----------- jQuery.get() asyncTest( "jQuery.get( String, Hash, Function ) - parse xml and use text() on nodes", 2, function() { - jQuery.get( url("data/dashboard.xml"), function( xml ) { + jQuery.get( url( "data/dashboard.xml" ), function( xml ) { var content = []; - jQuery( "tab", xml ).each(function() { + jQuery( "tab", xml ).each( function() { content.push( jQuery( this ).text() ); - }); + } ); strictEqual( content[ 0 ], "blabla", "Check first tab" ); strictEqual( content[ 1 ], "blublu", "Check second tab" ); start(); - }); - }); + } ); + } ); asyncTest( "#8277 - jQuery.get( String, Function ) - data in ajaxSettings", 1, function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { data: "helloworld" - }); - jQuery.get( url("data/echoQuery.php"), function( data ) { + } ); + jQuery.get( url( "data/echoQuery.php" ), function( data ) { ok( /helloworld$/.test( data ), "Data from ajaxSettings was used" ); start(); - }); - }); + } ); + } ); //----------- jQuery.getJSON() asyncTest( "jQuery.getJSON( String, Hash, Function ) - JSON array", 5, function() { jQuery.getJSON( - url("data/json.php"), + url( "data/json.php" ), { "json": "array" }, function( json ) { ok( json.length >= 2, "Check length" ); - strictEqual( json[ 0 ]["name"], "John", "Check JSON: first, name" ); - strictEqual( json[ 0 ]["age"], 21, "Check JSON: first, age" ); - strictEqual( json[ 1 ]["name"], "Peter", "Check JSON: second, name" ); - strictEqual( json[ 1 ]["age"], 25, "Check JSON: second, age" ); + strictEqual( json[ 0 ][ "name" ], "John", "Check JSON: first, name" ); + strictEqual( json[ 0 ][ "age" ], 21, "Check JSON: first, age" ); + strictEqual( json[ 1 ][ "name" ], "Peter", "Check JSON: second, name" ); + strictEqual( json[ 1 ][ "age" ], 25, "Check JSON: second, age" ); start(); } ); - }); + } ); asyncTest( "jQuery.getJSON( String, Function ) - JSON object", 2, function() { - jQuery.getJSON( url("data/json.php"), function( json ) { - if ( json && json["data"] ) { - strictEqual( json["data"]["lang"], "en", "Check JSON: lang" ); - strictEqual( json["data"].length, 25, "Check JSON: length" ); + jQuery.getJSON( url( "data/json.php" ), function( json ) { + if ( json && json[ "data" ] ) { + strictEqual( json[ "data" ][ "lang" ], "en", "Check JSON: lang" ); + strictEqual( json[ "data" ].length, 25, "Check JSON: length" ); start(); } - }); - }); + } ); + } ); asyncTest( "jQuery.getJSON() - Using Native JSON", 2, function() { var restore = "JSON" in window, old = window.JSON; if ( !restore ) { - Globals.register("JSON"); + Globals.register( "JSON" ); } window.JSON = { parse: function() { @@ -1823,183 +1828,183 @@ module( "ajax", { return true; } }; - jQuery.getJSON( url("data/json.php"), function( json ) { + jQuery.getJSON( url( "data/json.php" ), function( json ) { strictEqual( json, true, "Verifying return value" ); start(); - }); - }); + } ); + } ); asyncTest( "jQuery.getJSON( String, Function ) - JSON object with absolute url to local content", 2, function() { jQuery.getJSON( url( window.location.href.replace( /[^\/]*$/, "" ) + "data/json.php" ), function( json ) { strictEqual( json.data.lang, "en", "Check JSON: lang" ); strictEqual( json.data.length, 25, "Check JSON: length" ); start(); - }); - }); + } ); + } ); //----------- jQuery.getScript() asyncTest( "jQuery.getScript( String, Function ) - with callback", 2, function() { - Globals.register("testBar"); - jQuery.getScript( url("data/testbar.php"), function() { - strictEqual( window["testBar"], "bar", "Check if script was evaluated" ); + Globals.register( "testBar" ); + jQuery.getScript( url( "data/testbar.php" ), function() { + strictEqual( window[ "testBar" ], "bar", "Check if script was evaluated" ); start(); - }); - }); + } ); + } ); asyncTest( "jQuery.getScript( String, Function ) - no callback", 1, function() { - Globals.register("testBar"); - jQuery.getScript( url("data/testbar.php") ).done( start ); - }); + Globals.register( "testBar" ); + jQuery.getScript( url( "data/testbar.php" ) ).done( start ); + } ); asyncTest( "#8082 - jQuery.getScript( String, Function ) - source as responseText", 2, function() { - Globals.register("testBar"); - jQuery.getScript( url("data/testbar.php"), function( data, _, jqXHR ) { + Globals.register( "testBar" ); + jQuery.getScript( url( "data/testbar.php" ), function( data, _, jqXHR ) { strictEqual( data, jqXHR.responseText, "Same-domain script requests returns the source of the script" ); start(); - }); - }); + } ); + } ); //----------- jQuery.fn.load() // check if load can be called with only url asyncTest( "jQuery.fn.load( String )", 2, function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { beforeSend: function() { strictEqual( this.type, "GET", "no data means GET request" ); } - }); - jQuery("#first").load( "data/name.html", start ); - }); + } ); + jQuery( "#first" ).load( "data/name.html", start ); + } ); asyncTest( "jQuery.fn.load() - 404 error callbacks", 6, function() { - addGlobalEvents("ajaxStart ajaxStop ajaxSend ajaxComplete ajaxError")(); + addGlobalEvents( "ajaxStart ajaxStop ajaxSend ajaxComplete ajaxError" )(); jQuery( document ).ajaxStop( start ); - jQuery("<div/>").load( "data/404.html", function() { + jQuery( "<div/>" ).load( "data/404.html", function() { ok( true, "complete" ); - }); - }); + } ); + } ); // check if load can be called with url and null data asyncTest( "jQuery.fn.load( String, null )", 2, function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { beforeSend: function() { strictEqual( this.type, "GET", "no data means GET request" ); } - }); - jQuery("#first").load( "data/name.html", null, start ); - }); + } ); + jQuery( "#first" ).load( "data/name.html", null, start ); + } ); // check if load can be called with url and undefined data asyncTest( "jQuery.fn.load( String, undefined )", 2, function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { beforeSend: function() { strictEqual( this.type, "GET", "no data means GET request" ); } - }); - jQuery("#first").load( "data/name.html", undefined, start ); - }); + } ); + jQuery( "#first" ).load( "data/name.html", undefined, start ); + } ); // check if load can be called with only url asyncTest( "jQuery.fn.load( URL_SELECTOR )", 1, function() { - jQuery("#first").load( "data/test3.html div.user", function() { - strictEqual( jQuery( this ).children("div").length, 2, "Verify that specific elements were injected" ); + jQuery( "#first" ).load( "data/test3.html div.user", function() { + strictEqual( jQuery( this ).children( "div" ).length, 2, "Verify that specific elements were injected" ); start(); - }); - }); + } ); + } ); // Selector should be trimmed to avoid leading spaces (#14773) asyncTest( "jQuery.fn.load( URL_SELECTOR with spaces )", 1, function() { - jQuery("#first").load( "data/test3.html #superuser ", function() { - strictEqual( jQuery( this ).children("div").length, 1, "Verify that specific elements were injected" ); + jQuery( "#first" ).load( "data/test3.html #superuser ", function() { + strictEqual( jQuery( this ).children( "div" ).length, 1, "Verify that specific elements were injected" ); start(); - }); - }); + } ); + } ); asyncTest( "jQuery.fn.load( String, Function ) - simple: inject text into DOM", 2, function() { - jQuery("#first").load( url("data/name.html"), function() { - ok( /^ERROR/.test(jQuery("#first").text()), "Check if content was injected into the DOM" ); + jQuery( "#first" ).load( url( "data/name.html" ), function() { + ok( /^ERROR/.test( jQuery( "#first" ).text() ), "Check if content was injected into the DOM" ); start(); - }); - }); + } ); + } ); asyncTest( "jQuery.fn.load( String, Function ) - check scripts", 7, function() { var verifyEvaluation = function() { - strictEqual( window["testBar"], "bar", "Check if script src was evaluated after load" ); - strictEqual( jQuery("#ap").html(), "bar", "Check if script evaluation has modified DOM"); + strictEqual( window[ "testBar" ], "bar", "Check if script src was evaluated after load" ); + strictEqual( jQuery( "#ap" ).html(), "bar", "Check if script evaluation has modified DOM" ); start(); }; - Globals.register("testFoo"); - Globals.register("testBar"); + Globals.register( "testFoo" ); + Globals.register( "testBar" ); - jQuery("#first").load( url("data/test.html"), function() { - ok( jQuery("#first").html().match( /^html text/ ), "Check content after loading html" ); - strictEqual( jQuery("#foo").html(), "foo", "Check if script evaluation has modified DOM" ); - strictEqual( window["testFoo"], "foo", "Check if script was evaluated after load" ); + jQuery( "#first" ).load( url( "data/test.html" ), function() { + ok( jQuery( "#first" ).html().match( /^html text/ ), "Check content after loading html" ); + strictEqual( jQuery( "#foo" ).html(), "foo", "Check if script evaluation has modified DOM" ); + strictEqual( window[ "testFoo" ], "foo", "Check if script was evaluated after load" ); setTimeout( verifyEvaluation, 600 ); - }); - }); + } ); + } ); asyncTest( "jQuery.fn.load( String, Function ) - check file with only a script tag", 3, function() { - Globals.register("testFoo"); + Globals.register( "testFoo" ); - jQuery("#first").load( url("data/test2.html"), function() { - strictEqual( jQuery("#foo").html(), "foo", "Check if script evaluation has modified DOM"); - strictEqual( window["testFoo"], "foo", "Check if script was evaluated after load" ); + jQuery( "#first" ).load( url( "data/test2.html" ), function() { + strictEqual( jQuery( "#foo" ).html(), "foo", "Check if script evaluation has modified DOM" ); + strictEqual( window[ "testFoo" ], "foo", "Check if script was evaluated after load" ); start(); - }); - }); + } ); + } ); asyncTest( "jQuery.fn.load( String, Function ) - dataFilter in ajaxSettings", 2, function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { dataFilter: function() { return "Hello World"; } - }); - jQuery("<div/>").load( url("data/name.html"), function( responseText ) { + } ); + jQuery( "<div/>" ).load( url( "data/name.html" ), function( responseText ) { strictEqual( jQuery( this ).html(), "Hello World", "Test div was filled with filtered data" ); strictEqual( responseText, "Hello World", "Test callback receives filtered data" ); start(); - }); - }); + } ); + } ); asyncTest( "jQuery.fn.load( String, Object, Function )", 2, function() { - jQuery("<div />").load( url("data/params_html.php"), { + jQuery( "<div />" ).load( url( "data/params_html.php" ), { "foo": 3, "bar": "ok" }, function() { - var $post = jQuery( this ).find("#post"); - strictEqual( $post.find("#foo").text(), "3", "Check if a hash of data is passed correctly" ); - strictEqual( $post.find("#bar").text(), "ok", "Check if a hash of data is passed correctly" ); + var $post = jQuery( this ).find( "#post" ); + strictEqual( $post.find( "#foo" ).text(), "3", "Check if a hash of data is passed correctly" ); + strictEqual( $post.find( "#bar" ).text(), "ok", "Check if a hash of data is passed correctly" ); start(); - }); - }); + } ); + } ); asyncTest( "jQuery.fn.load( String, String, Function )", 2, function() { - jQuery("<div />").load( url("data/params_html.php"), "foo=3&bar=ok", function() { - var $get = jQuery( this ).find("#get"); - strictEqual( $get.find("#foo").text(), "3", "Check if a string of data is passed correctly" ); - strictEqual( $get.find("#bar").text(), "ok", "Check if a of data is passed correctly" ); + jQuery( "<div />" ).load( url( "data/params_html.php" ), "foo=3&bar=ok", function() { + var $get = jQuery( this ).find( "#get" ); + strictEqual( $get.find( "#foo" ).text(), "3", "Check if a string of data is passed correctly" ); + strictEqual( $get.find( "#bar" ).text(), "ok", "Check if a of data is passed correctly" ); start(); - }); - }); + } ); + } ); asyncTest( "jQuery.fn.load() - callbacks get the correct parameters", 8, function() { var completeArgs = {}; - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { success: function( _, status, jqXHR ) { completeArgs[ this.url ] = [ jqXHR.responseText, status, jqXHR ]; }, error: function( jqXHR, status ) { completeArgs[ this.url ] = [ jqXHR.responseText, status, jqXHR ]; } - }); + } ); jQuery.when.apply( jQuery, - jQuery.map([ + jQuery.map( [ { type: "success", url: "data/echoQuery.php?arg=pop" @@ -2010,67 +2015,67 @@ module( "ajax", { } ], function( options ) { - return jQuery.Deferred(function( defer ) { - jQuery("#foo").load( options.url, function() { + return jQuery.Deferred( function( defer ) { + jQuery( "#foo" ).load( options.url, function() { var args = arguments; strictEqual( completeArgs[ options.url ].length, args.length, "same number of arguments (" + options.type + ")" ); jQuery.each( completeArgs[ options.url ], function( i, value ) { strictEqual( args[ i ], value, "argument #" + i + " is the same (" + options.type + ")" ); - }); + } ); defer.resolve(); - }); - }); - }) + } ); + } ); + } ) ).always( start ); - }); + } ); asyncTest( "#2046 - jQuery.fn.load( String, Function ) with ajaxSetup on dataType json", 1, function() { - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { dataType: "json" - }); - jQuery( document ).ajaxComplete(function( e, xml, s ) { + } ); + jQuery( document ).ajaxComplete( function( e, xml, s ) { strictEqual( s.dataType, "html", "Verify the load() dataType was html" ); - jQuery( document ).off("ajaxComplete"); + jQuery( document ).off( "ajaxComplete" ); start(); - }); - jQuery("#first").load("data/test3.html"); - }); + } ); + jQuery( "#first" ).load( "data/test3.html" ); + } ); asyncTest( "#10524 - jQuery.fn.load() - data specified in ajaxSettings is merged in", 1, function() { var data = { "baz": 1 }; - jQuery.ajaxSetup({ + jQuery.ajaxSetup( { data: { "foo": "bar" } - }); - jQuery("#foo").load( "data/echoQuery.php", data ); - jQuery( document ).ajaxComplete(function( event, jqXHR, options ) { - ok( ~options.data.indexOf("foo=bar"), "Data from ajaxSettings was used" ); + } ); + jQuery( "#foo" ).load( "data/echoQuery.php", data ); + jQuery( document ).ajaxComplete( function( event, jqXHR, options ) { + ok( ~options.data.indexOf( "foo=bar" ), "Data from ajaxSettings was used" ); start(); - }); - }); + } ); + } ); //----------- jQuery.post() asyncTest( "jQuery.post() - data", 3, function() { jQuery.when( jQuery.post( - url("data/name.php"), + url( "data/name.php" ), { xml: "5-2", length: 3 }, function( xml ) { - jQuery( "math", xml ).each(function() { + jQuery( "math", xml ).each( function() { strictEqual( jQuery( "calculation", this ).text(), "5-2", "Check for XML" ); strictEqual( jQuery( "result", this ).text(), "3", "Check for XML" ); - }); + } ); } ), - jQuery.ajax({ - url: url("data/echoData.php"), + jQuery.ajax( { + url: url( "data/echoData.php" ), type: "POST", data: { "test": { @@ -2081,56 +2086,56 @@ module( "ajax", { success: function( data ) { strictEqual( data, "test%5Blength%5D=7&test%5Bfoo%5D=bar", "Check if a sub-object with a length param is serialized correctly" ); } - }) - ).always(function() { + } ) + ).always( function() { start(); - }); - }); + } ); + } ); asyncTest( "jQuery.post( String, Hash, Function ) - simple with xml", 4, function() { jQuery.when( jQuery.post( - url("data/name.php"), + url( "data/name.php" ), { "xml": "5-2" }, function( xml ) { - jQuery( "math", xml ).each(function() { + jQuery( "math", xml ).each( function() { strictEqual( jQuery( "calculation", this ).text(), "5-2", "Check for XML" ); strictEqual( jQuery( "result", this ).text(), "3", "Check for XML" ); - }); + } ); } ), - jQuery.post( url("data/name.php?xml=5-2"), {}, function( xml ) { - jQuery( "math", xml ).each(function() { + jQuery.post( url( "data/name.php?xml=5-2" ), {}, function( xml ) { + jQuery( "math", xml ).each( function() { strictEqual( jQuery( "calculation", this ).text(), "5-2", "Check for XML" ); strictEqual( jQuery( "result", this ).text(), "3", "Check for XML" ); - }); - }) - ).always(function() { + } ); + } ) + ).always( function() { start(); - }); - }); + } ); + } ); asyncTest( "jQuery[get|post]( options ) - simple with xml", 2, function() { jQuery.when.apply( jQuery, - jQuery.map( [ "get", "post" ] , function( method ) { - return jQuery[ method ]({ + jQuery.map( [ "get", "post" ], function( method ) { + return jQuery[ method ]( { url: url( "data/name.php" ), data: { "xml": "5-2" }, success: function( xml ) { - jQuery( "math", xml ).each(function() { + jQuery( "math", xml ).each( function() { strictEqual( jQuery( "result", this ).text(), "3", "Check for XML" ); - }); + } ); } - }); - }) - ).always(function() { + } ); + } ) + ).always( function() { start(); - }); - }); + } ); + } ); //----------- jQuery.active @@ -2138,6 +2143,6 @@ module( "ajax", { expect( 1 ); ok( jQuery.active === 0, "ajax active counter should be zero: " + jQuery.active ); - }); + } ); -})(); +} )(); diff --git a/test/unit/attributes.js b/test/unit/attributes.js index cb0322834..ec55556d1 100644 --- a/test/unit/attributes.js +++ b/test/unit/attributes.js @@ -1,6 +1,6 @@ module( "attributes", { teardown: moduleTeardown -}); +} ); function bareObj( value ) { return value; @@ -47,7 +47,7 @@ test( "jQuery.propFix integrity test", function() { }; deepEqual( props, jQuery.propFix, "jQuery.propFix passes integrity check" ); -}); +} ); test( "attr(String)", function() { expect( 50 ); @@ -56,199 +56,200 @@ test( "attr(String)", function() { select, optgroup, option, $img, styleElem, $button, $form, $a; - equal( jQuery("#text1").attr("type"), "text", "Check for type attribute" ); - equal( jQuery("#radio1").attr("type"), "radio", "Check for type attribute" ); - equal( jQuery("#check1").attr("type"), "checkbox", "Check for type attribute" ); - equal( jQuery("#simon1").attr("rel"), "bookmark", "Check for rel attribute" ); - equal( jQuery("#google").attr("title"), "Google!", "Check for title attribute" ); - equal( jQuery("#mark").attr("hreflang"), "en", "Check for hreflang attribute" ); - equal( jQuery("#en").attr("lang"), "en", "Check for lang attribute" ); - equal( jQuery("#simon").attr("class"), "blog link", "Check for class attribute" ); - equal( jQuery("#name").attr("name"), "name", "Check for name attribute" ); - equal( jQuery("#text1").attr("name"), "action", "Check for name attribute" ); - ok( jQuery("#form").attr("action").indexOf("formaction") >= 0, "Check for action attribute" ); - equal( jQuery("#text1").attr("value", "t").attr("value"), "t", "Check setting the value attribute" ); - equal( jQuery("#text1").attr("value", "").attr("value"), "", "Check setting the value attribute to empty string" ); - equal( jQuery("<div value='t'></div>").attr("value"), "t", "Check setting custom attr named 'value' on a div" ); - equal( jQuery("#form").attr("blah", "blah").attr("blah"), "blah", "Set non-existent attribute on a form" ); - equal( jQuery("#foo").attr("height"), undefined, "Non existent height attribute should return undefined" ); + equal( jQuery( "#text1" ).attr( "type" ), "text", "Check for type attribute" ); + equal( jQuery( "#radio1" ).attr( "type" ), "radio", "Check for type attribute" ); + equal( jQuery( "#check1" ).attr( "type" ), "checkbox", "Check for type attribute" ); + equal( jQuery( "#simon1" ).attr( "rel" ), "bookmark", "Check for rel attribute" ); + equal( jQuery( "#google" ).attr( "title" ), "Google!", "Check for title attribute" ); + equal( jQuery( "#mark" ).attr( "hreflang" ), "en", "Check for hreflang attribute" ); + equal( jQuery( "#en" ).attr( "lang" ), "en", "Check for lang attribute" ); + equal( jQuery( "#simon" ).attr( "class" ), "blog link", "Check for class attribute" ); + equal( jQuery( "#name" ).attr( "name" ), "name", "Check for name attribute" ); + equal( jQuery( "#text1" ).attr( "name" ), "action", "Check for name attribute" ); + ok( jQuery( "#form" ).attr( "action" ).indexOf( "formaction" ) >= 0, "Check for action attribute" ); + equal( jQuery( "#text1" ).attr( "value", "t" ).attr( "value" ), "t", "Check setting the value attribute" ); + equal( jQuery( "#text1" ).attr( "value", "" ).attr( "value" ), "", "Check setting the value attribute to empty string" ); + equal( jQuery( "<div value='t'></div>" ).attr( "value" ), "t", "Check setting custom attr named 'value' on a div" ); + equal( jQuery( "#form" ).attr( "blah", "blah" ).attr( "blah" ), "blah", "Set non-existent attribute on a form" ); + equal( jQuery( "#foo" ).attr( "height" ), undefined, "Non existent height attribute should return undefined" ); // [7472] & [3113] (form contains an input with name="action" or name="id") - extras = jQuery("<input id='id' name='id' /><input id='name' name='name' /><input id='target' name='target' />").appendTo("#testForm"); - equal( jQuery("#form").attr("action","newformaction").attr("action"), "newformaction", "Check that action attribute was changed" ); - equal( jQuery("#testForm").attr("target"), undefined, "Retrieving target does not equal the input with name=target" ); - equal( jQuery("#testForm").attr("target", "newTarget").attr("target"), "newTarget", "Set target successfully on a form" ); - equal( jQuery("#testForm").removeAttr("id").attr("id"), undefined, "Retrieving id does not equal the input with name=id after id is removed [#7472]" ); + extras = jQuery( "<input id='id' name='id' /><input id='name' name='name' /><input id='target' name='target' />" ).appendTo( "#testForm" ); + equal( jQuery( "#form" ).attr( "action", "newformaction" ).attr( "action" ), "newformaction", "Check that action attribute was changed" ); + equal( jQuery( "#testForm" ).attr( "target" ), undefined, "Retrieving target does not equal the input with name=target" ); + equal( jQuery( "#testForm" ).attr( "target", "newTarget" ).attr( "target" ), "newTarget", "Set target successfully on a form" ); + equal( jQuery( "#testForm" ).removeAttr( "id" ).attr( "id" ), undefined, "Retrieving id does not equal the input with name=id after id is removed [#7472]" ); + // Bug #3685 (form contains input with name="name") - equal( jQuery("#testForm").attr("name"), undefined, "Retrieving name does not retrieve input with name=name" ); + equal( jQuery( "#testForm" ).attr( "name" ), undefined, "Retrieving name does not retrieve input with name=name" ); extras.remove(); - equal( jQuery("#text1").attr("maxlength"), "30", "Check for maxlength attribute" ); - equal( jQuery("#text1").attr("maxLength"), "30", "Check for maxLength attribute" ); - equal( jQuery("#area1").attr("maxLength"), "30", "Check for maxLength attribute" ); + equal( jQuery( "#text1" ).attr( "maxlength" ), "30", "Check for maxlength attribute" ); + equal( jQuery( "#text1" ).attr( "maxLength" ), "30", "Check for maxLength attribute" ); + equal( jQuery( "#area1" ).attr( "maxLength" ), "30", "Check for maxLength attribute" ); // using innerHTML in IE causes href attribute to be serialized to the full path - jQuery("<a/>").attr({ + jQuery( "<a/>" ).attr( { "id": "tAnchor5", "href": "#5" - }).appendTo("#qunit-fixture"); - equal( jQuery("#tAnchor5").attr("href"), "#5", "Check for non-absolute href (an anchor)" ); - jQuery("<a id='tAnchor6' href='#5' />").appendTo("#qunit-fixture"); - equal( jQuery("#tAnchor5").prop("href"), jQuery("#tAnchor6").prop("href"), "Check for absolute href prop on an anchor" ); + } ).appendTo( "#qunit-fixture" ); + equal( jQuery( "#tAnchor5" ).attr( "href" ), "#5", "Check for non-absolute href (an anchor)" ); + jQuery( "<a id='tAnchor6' href='#5' />" ).appendTo( "#qunit-fixture" ); + equal( jQuery( "#tAnchor5" ).prop( "href" ), jQuery( "#tAnchor6" ).prop( "href" ), "Check for absolute href prop on an anchor" ); - jQuery("<script type='jquery/test' src='#5' id='scriptSrc'></script>").appendTo("#qunit-fixture"); - equal( jQuery("#tAnchor5").prop("href"), jQuery("#scriptSrc").prop("src"), "Check for absolute src prop on a script" ); + jQuery( "<script type='jquery/test' src='#5' id='scriptSrc'></script>" ).appendTo( "#qunit-fixture" ); + equal( jQuery( "#tAnchor5" ).prop( "href" ), jQuery( "#scriptSrc" ).prop( "src" ), "Check for absolute src prop on a script" ); // list attribute is readonly by default in browsers that support it - jQuery("#list-test").attr( "list", "datalist" ); - equal( jQuery("#list-test").attr("list"), "datalist", "Check setting list attribute" ); + jQuery( "#list-test" ).attr( "list", "datalist" ); + equal( jQuery( "#list-test" ).attr( "list" ), "datalist", "Check setting list attribute" ); // Related to [5574] and [5683] body = document.body; $body = jQuery( body ); - strictEqual( $body.attr("foo"), undefined, "Make sure that a non existent attribute returns undefined" ); + strictEqual( $body.attr( "foo" ), undefined, "Make sure that a non existent attribute returns undefined" ); body.setAttribute( "foo", "baz" ); - equal( $body.attr("foo"), "baz", "Make sure the dom attribute is retrieved when no expando is found" ); + equal( $body.attr( "foo" ), "baz", "Make sure the dom attribute is retrieved when no expando is found" ); - $body.attr( "foo","cool" ); - equal( $body.attr("foo"), "cool", "Make sure that setting works well when both expando and dom attribute are available" ); + $body.attr( "foo", "cool" ); + equal( $body.attr( "foo" ), "cool", "Make sure that setting works well when both expando and dom attribute are available" ); - body.removeAttribute("foo"); // Cleanup + body.removeAttribute( "foo" ); // Cleanup - select = document.createElement("select"); - optgroup = document.createElement("optgroup"); - option = document.createElement("option"); + select = document.createElement( "select" ); + optgroup = document.createElement( "optgroup" ); + option = document.createElement( "option" ); optgroup.appendChild( option ); select.appendChild( optgroup ); - equal( jQuery( option ).prop("selected"), true, "Make sure that a single option is selected, even when in an optgroup." ); + equal( jQuery( option ).prop( "selected" ), true, "Make sure that a single option is selected, even when in an optgroup." ); - $img = jQuery("<img style='display:none' width='215' height='53' src='data/1x1.jpg'/>").appendTo("body"); - equal( $img.attr("width"), "215", "Retrieve width attribute an an element with display:none." ); - equal( $img.attr("height"), "53", "Retrieve height attribute an an element with display:none." ); + $img = jQuery( "<img style='display:none' width='215' height='53' src='data/1x1.jpg'/>" ).appendTo( "body" ); + equal( $img.attr( "width" ), "215", "Retrieve width attribute an an element with display:none." ); + equal( $img.attr( "height" ), "53", "Retrieve height attribute an an element with display:none." ); // Check for style support - styleElem = jQuery("<div/>").appendTo("#qunit-fixture").css({ + styleElem = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ).css( { background: "url(UPPERlower.gif)" - }); - ok( !!~styleElem.attr("style").indexOf("UPPERlower.gif"), "Check style attribute getter" ); - ok( !!~styleElem.attr("style", "position:absolute;").attr("style").indexOf("absolute"), "Check style setter" ); + } ); + ok( !!~styleElem.attr( "style" ).indexOf( "UPPERlower.gif" ), "Check style attribute getter" ); + ok( !!~styleElem.attr( "style", "position:absolute;" ).attr( "style" ).indexOf( "absolute" ), "Check style setter" ); // Check value on button element (#1954) - $button = jQuery("<button>text</button>").insertAfter("#button"); - strictEqual( $button.attr("value"), undefined, "Absence of value attribute on a button" ); - equal( $button.attr( "value", "foobar" ).attr("value"), "foobar", "Value attribute on a button does not return innerHTML" ); - equal( $button.attr("value", "baz").html(), "text", "Setting the value attribute does not change innerHTML" ); + $button = jQuery( "<button>text</button>" ).insertAfter( "#button" ); + strictEqual( $button.attr( "value" ), undefined, "Absence of value attribute on a button" ); + equal( $button.attr( "value", "foobar" ).attr( "value" ), "foobar", "Value attribute on a button does not return innerHTML" ); + equal( $button.attr( "value", "baz" ).html(), "text", "Setting the value attribute does not change innerHTML" ); // Attributes with a colon on a table element (#1591) - equal( jQuery("#table").attr("test:attrib"), undefined, "Retrieving a non-existent attribute on a table with a colon does not throw an error." ); - equal( jQuery("#table").attr( "test:attrib", "foobar" ).attr("test:attrib"), "foobar", "Setting an attribute on a table with a colon does not throw an error." ); + equal( jQuery( "#table" ).attr( "test:attrib" ), undefined, "Retrieving a non-existent attribute on a table with a colon does not throw an error." ); + equal( jQuery( "#table" ).attr( "test:attrib", "foobar" ).attr( "test:attrib" ), "foobar", "Setting an attribute on a table with a colon does not throw an error." ); - $form = jQuery("<form class='something'></form>").appendTo("#qunit-fixture"); - equal( $form.attr("class"), "something", "Retrieve the class attribute on a form." ); + $form = jQuery( "<form class='something'></form>" ).appendTo( "#qunit-fixture" ); + equal( $form.attr( "class" ), "something", "Retrieve the class attribute on a form." ); - $a = jQuery("<a href='#' onclick='something()'>Click</a>").appendTo("#qunit-fixture"); - equal( $a.attr("onclick"), "something()", "Retrieve ^on attribute without anonymous function wrapper." ); + $a = jQuery( "<a href='#' onclick='something()'>Click</a>" ).appendTo( "#qunit-fixture" ); + equal( $a.attr( "onclick" ), "something()", "Retrieve ^on attribute without anonymous function wrapper." ); - ok( jQuery("<div/>").attr("doesntexist") === undefined, "Make sure undefined is returned when no attribute is found." ); - ok( jQuery("<div/>").attr("title") === undefined, "Make sure undefined is returned when no attribute is found." ); - equal( jQuery("<div/>").attr( "title", "something" ).attr("title"), "something", "Set the title attribute." ); - ok( jQuery().attr("doesntexist") === undefined, "Make sure undefined is returned when no element is there." ); - equal( jQuery("<div/>").attr("value"), undefined, "An unset value on a div returns undefined." ); - strictEqual( jQuery("<select><option value='property'></option></select>").attr("value"), undefined, "An unset value on a select returns undefined." ); + ok( jQuery( "<div/>" ).attr( "doesntexist" ) === undefined, "Make sure undefined is returned when no attribute is found." ); + ok( jQuery( "<div/>" ).attr( "title" ) === undefined, "Make sure undefined is returned when no attribute is found." ); + equal( jQuery( "<div/>" ).attr( "title", "something" ).attr( "title" ), "something", "Set the title attribute." ); + ok( jQuery().attr( "doesntexist" ) === undefined, "Make sure undefined is returned when no element is there." ); + equal( jQuery( "<div/>" ).attr( "value" ), undefined, "An unset value on a div returns undefined." ); + strictEqual( jQuery( "<select><option value='property'></option></select>" ).attr( "value" ), undefined, "An unset value on a select returns undefined." ); - $form = jQuery("#form").attr( "enctype", "multipart/form-data" ); - equal( $form.prop("enctype"), "multipart/form-data", "Set the enctype of a form (encoding in IE6/7 #6743)" ); + $form = jQuery( "#form" ).attr( "enctype", "multipart/form-data" ); + equal( $form.prop( "enctype" ), "multipart/form-data", "Set the enctype of a form (encoding in IE6/7 #6743)" ); -}); +} ); test( "attr(String) on cloned elements, #9646", function() { expect( 4 ); var div, - input = jQuery("<input name='tester' />"); + input = jQuery( "<input name='tester' />" ); - input.attr("name"); + input.attr( "name" ); strictEqual( input.clone( true ).attr( "name", "test" )[ 0 ].name, "test", "Name attribute should be changed on cloned element" ); - div = jQuery("<div id='tester' />"); - div.attr("id"); + div = jQuery( "<div id='tester' />" ); + div.attr( "id" ); strictEqual( div.clone( true ).attr( "id", "test" )[ 0 ].id, "test", "Id attribute should be changed on cloned element" ); - input = jQuery("<input value='tester' />"); - input.attr("value"); + input = jQuery( "<input value='tester' />" ); + input.attr( "value" ); strictEqual( input.clone( true ).attr( "value", "test" )[ 0 ].value, "test", "Value attribute should be changed on cloned element" ); strictEqual( input.clone( true ).attr( "value", 42 )[ 0 ].value, "42", "Value attribute should be changed on cloned element" ); -}); +} ); test( "attr(String) in XML Files", function() { expect( 3 ); var xml = createDashboardXML(); - equal( jQuery( "locations", xml ).attr("class"), "foo", "Check class attribute in XML document" ); - equal( jQuery( "location", xml ).attr("for"), "bar", "Check for attribute in XML document" ); - equal( jQuery( "location", xml ).attr("checked"), "different", "Check that hooks are not attached in XML document" ); -}); + equal( jQuery( "locations", xml ).attr( "class" ), "foo", "Check class attribute in XML document" ); + equal( jQuery( "location", xml ).attr( "for" ), "bar", "Check for attribute in XML document" ); + equal( jQuery( "location", xml ).attr( "checked" ), "different", "Check that hooks are not attached in XML document" ); +} ); test( "attr(String, Function)", function() { expect( 2 ); equal( - jQuery("#text1").attr( "value", function() { + jQuery( "#text1" ).attr( "value", function() { return this.id; - }).attr("value"), + } ).attr( "value" ), "text1", "Set value from id" ); equal( - jQuery("#text1").attr( "title", function(i) { + jQuery( "#text1" ).attr( "title", function( i ) { return i; - }).attr("title"), + } ).attr( "title" ), "0", "Set value with an index" ); -}); +} ); test( "attr(Hash)", function() { expect( 3 ); var pass = true; - jQuery("div").attr({ + jQuery( "div" ).attr( { "foo": "baz", "zoo": "ping" - }).each(function() { - if ( this.getAttribute("foo") !== "baz" && this.getAttribute("zoo") !== "ping" ) { + } ).each( function() { + if ( this.getAttribute( "foo" ) !== "baz" && this.getAttribute( "zoo" ) !== "ping" ) { pass = false; } - }); + } ); ok( pass, "Set Multiple Attributes" ); equal( - jQuery("#text1").attr({ + jQuery( "#text1" ).attr( { "value": function() { - return this["id"]; - }}).attr("value"), + return this[ "id" ]; + } } ).attr( "value" ), "text1", "Set attribute to computed value #1" ); equal( - jQuery("#text1").attr({ - "title": function(i) { + jQuery( "#text1" ).attr( { + "title": function( i ) { return i; } - }).attr("title"), + } ).attr( "title" ), "0", "Set attribute to computed value #2" ); -}); +} ); test( "attr(String, Object)", function() { expect( 71 ); @@ -257,12 +258,12 @@ test( "attr(String, Object)", function() { attributeNode, commentNode, textNode, obj, table, td, j, type, check, thrown, button, $radio, $radios, $svg, - div = jQuery("div").attr("foo", "bar"), + div = jQuery( "div" ).attr( "foo", "bar" ), i = 0, fail = false; for ( ; i < div.length; i++ ) { - if ( div[ i ].getAttribute("foo") !== "bar" ) { + if ( div[ i ].getAttribute( "foo" ) !== "bar" ) { fail = i; break; } @@ -271,187 +272,187 @@ test( "attr(String, Object)", function() { equal( fail, false, "Set Attribute, the #" + fail + " element didn't get the attribute 'foo'" ); ok( - jQuery("#foo").attr({ + jQuery( "#foo" ).attr( { "width": null - }), + } ), "Try to set an attribute to nothing" ); - jQuery("#name").attr( "name", "something" ); - equal( jQuery("#name").attr("name"), "something", "Set name attribute" ); - jQuery("#name").attr( "name", null ); - equal( jQuery("#name").attr("name"), undefined, "Remove name attribute" ); + jQuery( "#name" ).attr( "name", "something" ); + equal( jQuery( "#name" ).attr( "name" ), "something", "Set name attribute" ); + jQuery( "#name" ).attr( "name", null ); + equal( jQuery( "#name" ).attr( "name" ), undefined, "Remove name attribute" ); $input = jQuery( "<input>", { name: "something", id: "specified" - }); - equal( $input.attr("name"), "something", "Check element creation gets/sets the name attribute." ); - equal( $input.attr("id"), "specified", "Check element creation gets/sets the id attribute." ); + } ); + equal( $input.attr( "name" ), "something", "Check element creation gets/sets the name attribute." ); + equal( $input.attr( "id" ), "specified", "Check element creation gets/sets the id attribute." ); // As of fixing #11115, we only guarantee boolean property update for checked and selected - $input = jQuery("<input type='checkbox'/>").attr( "checked", true ); - equal( $input.prop("checked"), true, "Setting checked updates property (verified by .prop)" ); - equal( $input[0].checked, true, "Setting checked updates property (verified by native property)" ); - $input = jQuery("<option/>").attr( "selected", true ); - equal( $input.prop("selected"), true, "Setting selected updates property (verified by .prop)" ); - equal( $input[0].selected, true, "Setting selected updates property (verified by native property)" ); - - $input = jQuery("#check2"); + $input = jQuery( "<input type='checkbox'/>" ).attr( "checked", true ); + equal( $input.prop( "checked" ), true, "Setting checked updates property (verified by .prop)" ); + equal( $input[ 0 ].checked, true, "Setting checked updates property (verified by native property)" ); + $input = jQuery( "<option/>" ).attr( "selected", true ); + equal( $input.prop( "selected" ), true, "Setting selected updates property (verified by .prop)" ); + equal( $input[ 0 ].selected, true, "Setting selected updates property (verified by native property)" ); + + $input = jQuery( "#check2" ); $input.prop( "checked", true ).prop( "checked", false ).attr( "checked", true ); - equal( $input.attr("checked"), "checked", "Set checked (verified by .attr)" ); + equal( $input.attr( "checked" ), "checked", "Set checked (verified by .attr)" ); $input.prop( "checked", false ).prop( "checked", true ).attr( "checked", false ); - equal( $input.attr("checked"), undefined, "Remove checked (verified by .attr)" ); + equal( $input.attr( "checked" ), undefined, "Remove checked (verified by .attr)" ); - $input = jQuery("#text1").prop( "readOnly", true ).prop( "readOnly", false ).attr( "readonly", true ); - equal( $input.attr("readonly"), "readonly", "Set readonly (verified by .attr)" ); + $input = jQuery( "#text1" ).prop( "readOnly", true ).prop( "readOnly", false ).attr( "readonly", true ); + equal( $input.attr( "readonly" ), "readonly", "Set readonly (verified by .attr)" ); $input.prop( "readOnly", false ).prop( "readOnly", true ).attr( "readonly", false ); - equal( $input.attr("readonly"), undefined, "Remove readonly (verified by .attr)" ); + equal( $input.attr( "readonly" ), undefined, "Remove readonly (verified by .attr)" ); - $input = jQuery("#check2").attr( "checked", true ).attr( "checked", false ).prop( "checked", true ); - equal( $input[0].checked, true, "Set checked property (verified by native property)" ); - equal( $input.prop("checked"), true, "Set checked property (verified by .prop)" ); - equal( $input.attr("checked"), undefined, "Setting checked property doesn't affect checked attribute" ); + $input = jQuery( "#check2" ).attr( "checked", true ).attr( "checked", false ).prop( "checked", true ); + equal( $input[ 0 ].checked, true, "Set checked property (verified by native property)" ); + equal( $input.prop( "checked" ), true, "Set checked property (verified by .prop)" ); + equal( $input.attr( "checked" ), undefined, "Setting checked property doesn't affect checked attribute" ); $input.attr( "checked", false ).attr( "checked", true ).prop( "checked", false ); - equal( $input[0].checked, false, "Clear checked property (verified by native property)" ); - equal( $input.prop("checked"), false, "Clear checked property (verified by .prop)" ); - equal( $input.attr("checked"), "checked", "Clearing checked property doesn't affect checked attribute" ); + equal( $input[ 0 ].checked, false, "Clear checked property (verified by native property)" ); + equal( $input.prop( "checked" ), false, "Clear checked property (verified by .prop)" ); + equal( $input.attr( "checked" ), "checked", "Clearing checked property doesn't affect checked attribute" ); - $input = jQuery("#check2").attr( "checked", false ).attr( "checked", "checked" ); - equal( $input.attr("checked"), "checked", "Set checked to 'checked' (verified by .attr)" ); + $input = jQuery( "#check2" ).attr( "checked", false ).attr( "checked", "checked" ); + equal( $input.attr( "checked" ), "checked", "Set checked to 'checked' (verified by .attr)" ); - $radios = jQuery("#checkedtest").find("input[type='radio']"); - $radios.eq( 1 ).trigger("click"); - equal( $radios.eq( 1 ).prop("checked"), true, "Second radio was checked when clicked" ); - equal( $radios.eq( 0 ).attr("checked"), "checked", "First radio is still [checked]" ); + $radios = jQuery( "#checkedtest" ).find( "input[type='radio']" ); + $radios.eq( 1 ).trigger( "click" ); + equal( $radios.eq( 1 ).prop( "checked" ), true, "Second radio was checked when clicked" ); + equal( $radios.eq( 0 ).attr( "checked" ), "checked", "First radio is still [checked]" ); - $input = jQuery("#text1").attr( "readonly", false ).prop( "readOnly", true ); - equal( $input[0].readOnly, true, "Set readonly property (verified by native property)" ); - equal( $input.prop("readOnly"), true, "Set readonly property (verified by .prop)" ); + $input = jQuery( "#text1" ).attr( "readonly", false ).prop( "readOnly", true ); + equal( $input[ 0 ].readOnly, true, "Set readonly property (verified by native property)" ); + equal( $input.prop( "readOnly" ), true, "Set readonly property (verified by .prop)" ); $input.attr( "readonly", true ).prop( "readOnly", false ); - equal( $input[0].readOnly, false, "Clear readonly property (verified by native property)" ); - equal( $input.prop("readOnly"), false, "Clear readonly property (verified by .prop)" ); + equal( $input[ 0 ].readOnly, false, "Clear readonly property (verified by native property)" ); + equal( $input.prop( "readOnly" ), false, "Clear readonly property (verified by .prop)" ); - $input = jQuery("#name").attr( "maxlength", "5" ); - equal( $input[0].maxLength, 5, "Set maxlength (verified by native property)" ); + $input = jQuery( "#name" ).attr( "maxlength", "5" ); + equal( $input[ 0 ].maxLength, 5, "Set maxlength (verified by native property)" ); $input.attr( "maxLength", "10" ); - equal( $input[0].maxLength, 10, "Set maxlength (verified by native property)" ); + equal( $input[ 0 ].maxLength, 10, "Set maxlength (verified by native property)" ); // HTML5 boolean attributes - $text = jQuery("#text1").attr({ + $text = jQuery( "#text1" ).attr( { "autofocus": true, "required": true - }); - equal( $text.attr("autofocus"), "autofocus", "Reading autofocus attribute yields 'autofocus'" ); - equal( $text.attr( "autofocus", false ).attr("autofocus"), undefined, "Setting autofocus to false removes it" ); - equal( $text.attr("required"), "required", "Reading required attribute yields 'required'" ); - equal( $text.attr( "required", false ).attr("required"), undefined, "Setting required attribute to false removes it" ); + } ); + equal( $text.attr( "autofocus" ), "autofocus", "Reading autofocus attribute yields 'autofocus'" ); + equal( $text.attr( "autofocus", false ).attr( "autofocus" ), undefined, "Setting autofocus to false removes it" ); + equal( $text.attr( "required" ), "required", "Reading required attribute yields 'required'" ); + equal( $text.attr( "required", false ).attr( "required" ), undefined, "Setting required attribute to false removes it" ); - $details = jQuery("<details open></details>").appendTo("#qunit-fixture"); - equal( $details.attr("open"), "open", "open attribute presence indicates true" ); - equal( $details.attr( "open", false ).attr("open"), undefined, "Setting open attribute to false removes it" ); + $details = jQuery( "<details open></details>" ).appendTo( "#qunit-fixture" ); + equal( $details.attr( "open" ), "open", "open attribute presence indicates true" ); + equal( $details.attr( "open", false ).attr( "open" ), undefined, "Setting open attribute to false removes it" ); $text.attr( "data-something", true ); - equal( $text.attr("data-something"), "true", "Set data attributes"); - equal( $text.data("something"), true, "Setting data attributes are not affected by boolean settings"); + equal( $text.attr( "data-something" ), "true", "Set data attributes" ); + equal( $text.data( "something" ), true, "Setting data attributes are not affected by boolean settings" ); $text.attr( "data-another", false ); - equal( $text.attr("data-another"), "false", "Set data attributes"); - equal( $text.data("another"), false, "Setting data attributes are not affected by boolean settings" ); - equal( $text.attr( "aria-disabled", false ).attr("aria-disabled"), "false", "Setting aria attributes are not affected by boolean settings" ); - $text.removeData("something").removeData("another").removeAttr("aria-disabled"); + equal( $text.attr( "data-another" ), "false", "Set data attributes" ); + equal( $text.data( "another" ), false, "Setting data attributes are not affected by boolean settings" ); + equal( $text.attr( "aria-disabled", false ).attr( "aria-disabled" ), "false", "Setting aria attributes are not affected by boolean settings" ); + $text.removeData( "something" ).removeData( "another" ).removeAttr( "aria-disabled" ); - jQuery("#foo").attr("contenteditable", true); - equal( jQuery("#foo").attr("contenteditable"), "true", "Enumerated attributes are set properly" ); + jQuery( "#foo" ).attr( "contenteditable", true ); + equal( jQuery( "#foo" ).attr( "contenteditable" ), "true", "Enumerated attributes are set properly" ); - attributeNode = document.createAttribute("irrelevant"); - commentNode = document.createComment("some comment"); - textNode = document.createTextNode("some text"); + attributeNode = document.createAttribute( "irrelevant" ); + commentNode = document.createComment( "some comment" ); + textNode = document.createTextNode( "some text" ); obj = {}; jQuery.each( [ commentNode, textNode, attributeNode ], function( i, elem ) { var $elem = jQuery( elem ); $elem.attr( "nonexisting", "foo" ); - strictEqual( $elem.attr("nonexisting"), undefined, "attr(name, value) works correctly on comment and text nodes (bug #7500)." ); - }); + strictEqual( $elem.attr( "nonexisting" ), undefined, "attr(name, value) works correctly on comment and text nodes (bug #7500)." ); + } ); jQuery.each( [ window, document, obj, "#firstp" ], function( i, elem ) { var oldVal = elem.nonexisting, $elem = jQuery( elem ); - strictEqual( $elem.attr("nonexisting"), undefined, "attr works correctly for non existing attributes (bug #7500)." ); - equal( $elem.attr( "nonexisting", "foo" ).attr("nonexisting"), "foo", "attr falls back to prop on unsupported arguments" ); + strictEqual( $elem.attr( "nonexisting" ), undefined, "attr works correctly for non existing attributes (bug #7500)." ); + equal( $elem.attr( "nonexisting", "foo" ).attr( "nonexisting" ), "foo", "attr falls back to prop on unsupported arguments" ); elem.nonexisting = oldVal; - }); + } ); // Register the property on the window for the previous assertion so it will be clean up Globals.register( "nonexisting" ); - table = jQuery("#table").append("<tr><td>cell</td></tr><tr><td>cell</td><td>cell</td></tr><tr><td>cell</td><td>cell</td></tr>"); - td = table.find("td").eq(0); + table = jQuery( "#table" ).append( "<tr><td>cell</td></tr><tr><td>cell</td><td>cell</td></tr><tr><td>cell</td><td>cell</td></tr>" ); + td = table.find( "td" ).eq( 0 ); td.attr( "rowspan", "2" ); - equal( td[ 0 ]["rowSpan"], 2, "Check rowspan is correctly set" ); + equal( td[ 0 ][ "rowSpan" ], 2, "Check rowspan is correctly set" ); td.attr( "colspan", "2" ); - equal( td[ 0 ]["colSpan"], 2, "Check colspan is correctly set" ); - table.attr("cellspacing", "2"); - equal( table[ 0 ]["cellSpacing"], "2", "Check cellspacing is correctly set" ); + equal( td[ 0 ][ "colSpan" ], 2, "Check colspan is correctly set" ); + table.attr( "cellspacing", "2" ); + equal( table[ 0 ][ "cellSpacing" ], "2", "Check cellspacing is correctly set" ); - equal( jQuery("#area1").attr("value"), undefined, "Value attribute is distinct from value property." ); + equal( jQuery( "#area1" ).attr( "value" ), undefined, "Value attribute is distinct from value property." ); // for #1070 - jQuery("#name").attr( "someAttr", "0" ); - equal( jQuery("#name").attr("someAttr"), "0", "Set attribute to a string of '0'" ); - jQuery("#name").attr( "someAttr", 0 ); - equal( jQuery("#name").attr("someAttr"), "0", "Set attribute to the number 0" ); - jQuery("#name").attr( "someAttr", 1 ); - equal( jQuery("#name").attr("someAttr"), "1", "Set attribute to the number 1" ); + jQuery( "#name" ).attr( "someAttr", "0" ); + equal( jQuery( "#name" ).attr( "someAttr" ), "0", "Set attribute to a string of '0'" ); + jQuery( "#name" ).attr( "someAttr", 0 ); + equal( jQuery( "#name" ).attr( "someAttr" ), "0", "Set attribute to the number 0" ); + jQuery( "#name" ).attr( "someAttr", 1 ); + equal( jQuery( "#name" ).attr( "someAttr" ), "1", "Set attribute to the number 1" ); // using contents will get comments regular, text, and comment nodes - j = jQuery("#nonnodes").contents(); + j = jQuery( "#nonnodes" ).contents(); j.attr( "name", "attrvalue" ); - equal( j.attr("name"), "attrvalue", "Check node,textnode,comment for attr" ); - j.removeAttr("name"); + equal( j.attr( "name" ), "attrvalue", "Check node,textnode,comment for attr" ); + j.removeAttr( "name" ); // Type - type = jQuery("#check2").attr("type"); + type = jQuery( "#check2" ).attr( "type" ); try { - jQuery("#check2").attr( "type", "hidden" ); + jQuery( "#check2" ).attr( "type", "hidden" ); ok( true, "No exception thrown on input type change" ); - } catch( e ) { + } catch ( e ) { ok( true, "Exception thrown on input type change: " + e ); } - check = document.createElement("input"); + check = document.createElement( "input" ); thrown = true; try { jQuery( check ).attr( "type", "checkbox" ); - } catch( e ) { + } catch ( e ) { thrown = false; } ok( thrown, "Exception thrown when trying to change type property" ); - equal( "checkbox", jQuery( check ).attr("type"), "Verify that you can change the type of an input element that isn't in the DOM" ); + equal( "checkbox", jQuery( check ).attr( "type" ), "Verify that you can change the type of an input element that isn't in the DOM" ); - check = jQuery("<input />"); + check = jQuery( "<input />" ); thrown = true; try { check.attr( "type", "checkbox" ); - } catch( e ) { + } catch ( e ) { thrown = false; } ok( thrown, "Exception thrown when trying to change type property" ); - equal( "checkbox", check.attr("type"), "Verify that you can change the type of an input element that isn't in the DOM" ); + equal( "checkbox", check.attr( "type" ), "Verify that you can change the type of an input element that isn't in the DOM" ); - button = jQuery("#button"); + button = jQuery( "#button" ); try { button.attr( "type", "submit" ); ok( true, "No exception thrown on button type change" ); - } catch( e ) { + } catch ( e ) { ok( true, "Exception thrown on button type change: " + e ); } $radio = jQuery( "<input>", { "value": "sup", "type": "radio" - }).appendTo("#testForm"); + } ).appendTo( "#testForm" ); equal( $radio.val(), "sup", "Value is not reset when type is set after value on a radio" ); // Setting attributes on svg elements (bug #3116) @@ -459,16 +460,16 @@ test( "attr(String, Object)", function() { "<svg xmlns='http://www.w3.org/2000/svg' xmlns:xlink='http://www.w3.org/1999/xlink' version='1.1' baseProfile='full' width='200' height='200'>" + "<circle cx='200' cy='200' r='150' />" + "</svg>" - ).appendTo("body"); - equal( $svg.attr( "cx", 100 ).attr("cx"), "100", "Set attribute on svg element" ); + ).appendTo( "body" ); + equal( $svg.attr( "cx", 100 ).attr( "cx" ), "100", "Set attribute on svg element" ); $svg.remove(); // undefined values are chainable - jQuery("#name").attr( "maxlength", "5" ).removeAttr("nonexisting"); - equal( typeof jQuery("#name").attr( "maxlength", undefined ), "object", ".attr('attribute', undefined) is chainable (#5571)" ); - equal( jQuery("#name").attr( "maxlength", undefined ).attr("maxlength"), "5", ".attr('attribute', undefined) does not change value (#5571)" ); - equal( jQuery("#name").attr( "nonexisting", undefined ).attr("nonexisting"), undefined, ".attr('attribute', undefined) does not create attribute (#5571)" ); -}); + jQuery( "#name" ).attr( "maxlength", "5" ).removeAttr( "nonexisting" ); + equal( typeof jQuery( "#name" ).attr( "maxlength", undefined ), "object", ".attr('attribute', undefined) is chainable (#5571)" ); + equal( jQuery( "#name" ).attr( "maxlength", undefined ).attr( "maxlength" ), "5", ".attr('attribute', undefined) does not change value (#5571)" ); + equal( jQuery( "#name" ).attr( "nonexisting", undefined ).attr( "nonexisting" ), undefined, ".attr('attribute', undefined) does not create attribute (#5571)" ); +} ); test( "attr - extending the boolean attrHandle", function() { expect( 1 ); @@ -482,18 +483,18 @@ test( "attr - extending the boolean attrHandle", function() { called = false; jQuery( "input" ).attr( "checked" ); ok( called, "The boolean attrHandle does not drop custom attrHandles" ); -}); +} ); test( "attr(String, Object) - Loaded via XML document", function() { expect( 2 ); var xml = createDashboardXML(), titles = []; - jQuery( "tab", xml ).each(function() { - titles.push( jQuery( this ).attr("title") ); - }); + jQuery( "tab", xml ).each( function() { + titles.push( jQuery( this ).attr( "title" ) ); + } ); equal( titles[ 0 ], "Location", "attr() in XML context: Check first title" ); equal( titles[ 1 ], "Users", "attr() in XML context: Check second title" ); -}); +} ); test( "attr(String, Object) - Loaded via XML fragment", function() { expect( 2 ); @@ -501,121 +502,121 @@ test( "attr(String, Object) - Loaded via XML fragment", function() { $frag = jQuery( frag ); $frag.attr( "test", "some value" ); - equal( $frag.attr("test"), "some value", "set attribute" ); + equal( $frag.attr( "test" ), "some value", "set attribute" ); $frag.attr( "test", null ); - equal( $frag.attr("test"), undefined, "remove attribute" ); -}); + equal( $frag.attr( "test" ), undefined, "remove attribute" ); +} ); test( "attr('tabindex')", function() { expect( 8 ); // elements not natively tabbable - equal( jQuery("#listWithTabIndex").attr("tabindex"), "5", "not natively tabbable, with tabindex set to 0" ); - equal( jQuery("#divWithNoTabIndex").attr("tabindex"), undefined, "not natively tabbable, no tabindex set" ); + equal( jQuery( "#listWithTabIndex" ).attr( "tabindex" ), "5", "not natively tabbable, with tabindex set to 0" ); + equal( jQuery( "#divWithNoTabIndex" ).attr( "tabindex" ), undefined, "not natively tabbable, no tabindex set" ); // anchor with href - equal( jQuery("#linkWithNoTabIndex").attr("tabindex"), undefined, "anchor with href, no tabindex set" ); - equal( jQuery("#linkWithTabIndex").attr("tabindex"), "2", "anchor with href, tabindex set to 2" ); - equal( jQuery("#linkWithNegativeTabIndex").attr("tabindex"), "-1", "anchor with href, tabindex set to -1" ); + equal( jQuery( "#linkWithNoTabIndex" ).attr( "tabindex" ), undefined, "anchor with href, no tabindex set" ); + equal( jQuery( "#linkWithTabIndex" ).attr( "tabindex" ), "2", "anchor with href, tabindex set to 2" ); + equal( jQuery( "#linkWithNegativeTabIndex" ).attr( "tabindex" ), "-1", "anchor with href, tabindex set to -1" ); // anchor without href - equal( jQuery("#linkWithNoHrefWithNoTabIndex").attr("tabindex"), undefined, "anchor without href, no tabindex set" ); - equal( jQuery("#linkWithNoHrefWithTabIndex").attr("tabindex"), "1", "anchor without href, tabindex set to 2" ); - equal( jQuery("#linkWithNoHrefWithNegativeTabIndex").attr("tabindex"), "-1", "anchor without href, no tabindex set" ); -}); + equal( jQuery( "#linkWithNoHrefWithNoTabIndex" ).attr( "tabindex" ), undefined, "anchor without href, no tabindex set" ); + equal( jQuery( "#linkWithNoHrefWithTabIndex" ).attr( "tabindex" ), "1", "anchor without href, tabindex set to 2" ); + equal( jQuery( "#linkWithNoHrefWithNegativeTabIndex" ).attr( "tabindex" ), "-1", "anchor without href, no tabindex set" ); +} ); test( "attr('tabindex', value)", function() { expect( 9 ); - var element = jQuery("#divWithNoTabIndex"); - equal( element.attr("tabindex"), undefined, "start with no tabindex" ); + var element = jQuery( "#divWithNoTabIndex" ); + equal( element.attr( "tabindex" ), undefined, "start with no tabindex" ); // set a positive string element.attr( "tabindex", "1" ); - equal( element.attr("tabindex"), "1", "set tabindex to 1 (string)" ); + equal( element.attr( "tabindex" ), "1", "set tabindex to 1 (string)" ); // set a zero string element.attr( "tabindex", "0" ); - equal( element.attr("tabindex"), "0", "set tabindex to 0 (string)" ); + equal( element.attr( "tabindex" ), "0", "set tabindex to 0 (string)" ); // set a negative string element.attr( "tabindex", "-1" ); - equal( element.attr("tabindex"), "-1", "set tabindex to -1 (string)" ); + equal( element.attr( "tabindex" ), "-1", "set tabindex to -1 (string)" ); // set a positive number element.attr( "tabindex", 1 ); - equal( element.attr("tabindex"), "1", "set tabindex to 1 (number)" ); + equal( element.attr( "tabindex" ), "1", "set tabindex to 1 (number)" ); // set a zero number element.attr( "tabindex", 0 ); - equal(element.attr("tabindex"), "0", "set tabindex to 0 (number)"); + equal( element.attr( "tabindex" ), "0", "set tabindex to 0 (number)" ); // set a negative number element.attr( "tabindex", -1 ); - equal( element.attr("tabindex"), "-1", "set tabindex to -1 (number)" ); + equal( element.attr( "tabindex" ), "-1", "set tabindex to -1 (number)" ); - element = jQuery("#linkWithTabIndex"); - equal( element.attr("tabindex"), "2", "start with tabindex 2" ); + element = jQuery( "#linkWithTabIndex" ); + equal( element.attr( "tabindex" ), "2", "start with tabindex 2" ); element.attr( "tabindex", -1 ); - equal( element.attr("tabindex"), "-1", "set negative tabindex" ); -}); + equal( element.attr( "tabindex" ), "-1", "set negative tabindex" ); +} ); test( "removeAttr(String)", function() { expect( 12 ); var $first; - equal( jQuery("#mark").removeAttr("class").attr("class"), undefined, "remove class" ); - equal( jQuery("#form").removeAttr("id").attr("id"), undefined, "Remove id" ); - equal( jQuery("#foo").attr( "style", "position:absolute;" ).removeAttr("style").attr("style"), undefined, "Check removing style attribute" ); - equal( jQuery("#form").attr( "style", "position:absolute;" ).removeAttr("style").attr("style"), undefined, "Check removing style attribute on a form" ); - equal( jQuery("<div style='position: absolute'></div>").appendTo("#foo").removeAttr("style").prop("style").cssText, "", "Check removing style attribute (#9699 Webkit)" ); - equal( jQuery("#fx-test-group").attr( "height", "3px" ).removeAttr("height").get( 0 ).style.height, "1px", "Removing height attribute has no effect on height set with style attribute" ); + equal( jQuery( "#mark" ).removeAttr( "class" ).attr( "class" ), undefined, "remove class" ); + equal( jQuery( "#form" ).removeAttr( "id" ).attr( "id" ), undefined, "Remove id" ); + equal( jQuery( "#foo" ).attr( "style", "position:absolute;" ).removeAttr( "style" ).attr( "style" ), undefined, "Check removing style attribute" ); + equal( jQuery( "#form" ).attr( "style", "position:absolute;" ).removeAttr( "style" ).attr( "style" ), undefined, "Check removing style attribute on a form" ); + equal( jQuery( "<div style='position: absolute'></div>" ).appendTo( "#foo" ).removeAttr( "style" ).prop( "style" ).cssText, "", "Check removing style attribute (#9699 Webkit)" ); + equal( jQuery( "#fx-test-group" ).attr( "height", "3px" ).removeAttr( "height" ).get( 0 ).style.height, "1px", "Removing height attribute has no effect on height set with style attribute" ); - jQuery("#check1").removeAttr("checked").prop( "checked", true ).removeAttr("checked"); - equal( document.getElementById("check1").checked, false, "removeAttr sets boolean properties to false" ); - jQuery("#text1").prop( "readOnly", true ).removeAttr("readonly"); - equal( document.getElementById("text1").readOnly, false, "removeAttr sets boolean properties to false" ); + jQuery( "#check1" ).removeAttr( "checked" ).prop( "checked", true ).removeAttr( "checked" ); + equal( document.getElementById( "check1" ).checked, false, "removeAttr sets boolean properties to false" ); + jQuery( "#text1" ).prop( "readOnly", true ).removeAttr( "readonly" ); + equal( document.getElementById( "text1" ).readOnly, false, "removeAttr sets boolean properties to false" ); - jQuery("#option2c").removeAttr("selected"); - equal( jQuery("#option2d").attr("selected"), "selected", "Removing `selected` from an option that is not selected does not remove selected from the currently selected option (#10870)" ); + jQuery( "#option2c" ).removeAttr( "selected" ); + equal( jQuery( "#option2d" ).attr( "selected" ), "selected", "Removing `selected` from an option that is not selected does not remove selected from the currently selected option (#10870)" ); try { - $first = jQuery("#first").attr( "contenteditable", "true" ).removeAttr("contenteditable"); - equal( $first.attr("contenteditable"), undefined, "Remove the contenteditable attribute" ); - } catch( e ) { + $first = jQuery( "#first" ).attr( "contenteditable", "true" ).removeAttr( "contenteditable" ); + equal( $first.attr( "contenteditable" ), undefined, "Remove the contenteditable attribute" ); + } catch ( e ) { ok( false, "Removing contenteditable threw an error (#10429)" ); } - $first = jQuery("<div Case='mixed'></div>"); - equal( $first.attr("Case"), "mixed", "case of attribute doesn't matter" ); - $first.removeAttr("Case"); - equal( $first.attr("Case"), undefined, "mixed-case attribute was removed" ); -}); + $first = jQuery( "<div Case='mixed'></div>" ); + equal( $first.attr( "Case" ), "mixed", "case of attribute doesn't matter" ); + $first.removeAttr( "Case" ); + equal( $first.attr( "Case" ), undefined, "mixed-case attribute was removed" ); +} ); test( "removeAttr(String) in XML", function() { expect( 7 ); var xml = createDashboardXML(), iwt = jQuery( "infowindowtab", xml ); - equal( iwt.attr("normal"), "ab", "Check initial value" ); - iwt.removeAttr("Normal"); - equal( iwt.attr("normal"), "ab", "Should still be there" ); - iwt.removeAttr("normal"); - equal( iwt.attr("normal"), undefined, "Removed" ); + equal( iwt.attr( "normal" ), "ab", "Check initial value" ); + iwt.removeAttr( "Normal" ); + equal( iwt.attr( "normal" ), "ab", "Should still be there" ); + iwt.removeAttr( "normal" ); + equal( iwt.attr( "normal" ), undefined, "Removed" ); - equal( iwt.attr("mixedCase"), "yes", "Check initial value" ); - equal( iwt.attr("mixedcase"), undefined, "toLowerCase not work good" ); - iwt.removeAttr("mixedcase"); - equal( iwt.attr("mixedCase"), "yes", "Should still be there" ); - iwt.removeAttr("mixedCase"); - equal( iwt.attr("mixedCase"), undefined, "Removed" ); -}); + equal( iwt.attr( "mixedCase" ), "yes", "Check initial value" ); + equal( iwt.attr( "mixedcase" ), undefined, "toLowerCase not work good" ); + iwt.removeAttr( "mixedcase" ); + equal( iwt.attr( "mixedCase" ), "yes", "Should still be there" ); + iwt.removeAttr( "mixedCase" ); + equal( iwt.attr( "mixedCase" ), undefined, "Removed" ); +} ); test( "removeAttr(Multi String, variable space width)", function() { expect( 8 ); - var div = jQuery("<div id='a' alt='b' title='c' rel='d'></div>"), + var div = jQuery( "<div id='a' alt='b' title='c' rel='d'></div>" ), tests = { id: "a", alt: "b", @@ -625,45 +626,45 @@ test( "removeAttr(Multi String, variable space width)", function() { jQuery.each( tests, function( key, val ) { equal( div.attr( key ), val, "Attribute `" + key + "` exists, and has a value of `" + val + "`" ); - }); + } ); div.removeAttr( "id alt title rel " ); jQuery.each( tests, function( key ) { equal( div.attr( key ), undefined, "Attribute `" + key + "` was removed" ); - }); -}); + } ); +} ); test( "prop(String, Object)", function() { expect( 17 ); - equal( jQuery("#text1").prop("value"), "Test", "Check for value attribute" ); - equal( jQuery("#text1").prop( "value", "Test2" ).prop("defaultValue"), "Test", "Check for defaultValue attribute" ); - equal( jQuery("#select2").prop("selectedIndex"), 3, "Check for selectedIndex attribute" ); - equal( jQuery("#foo").prop("nodeName").toUpperCase(), "DIV", "Check for nodeName attribute" ); - equal( jQuery("#foo").prop("tagName").toUpperCase(), "DIV", "Check for tagName attribute" ); - equal( jQuery("<option/>").prop("selected"), false, "Check selected attribute on disconnected element." ); - - equal( jQuery("#listWithTabIndex").prop("tabindex"), 5, "Check retrieving tabindex" ); - jQuery("#text1").prop( "readonly", true ); - equal( document.getElementById("text1").readOnly, true, "Check setting readOnly property with 'readonly'" ); - equal( jQuery("#label-for").prop("for"), "action", "Check retrieving htmlFor" ); - jQuery("#text1").prop("class", "test"); - equal( document.getElementById("text1").className, "test", "Check setting className with 'class'" ); - equal( jQuery("#text1").prop("maxlength"), 30, "Check retrieving maxLength" ); - jQuery("#table").prop( "cellspacing", 1 ); - equal( jQuery("#table").prop("cellSpacing"), "1", "Check setting and retrieving cellSpacing" ); - jQuery("#table").prop( "cellpadding", 1 ); - equal( jQuery("#table").prop("cellPadding"), "1", "Check setting and retrieving cellPadding" ); - jQuery("#table").prop( "rowspan", 1 ); - equal( jQuery("#table").prop("rowSpan"), 1, "Check setting and retrieving rowSpan" ); - jQuery("#table").prop( "colspan", 1 ); - equal( jQuery("#table").prop("colSpan"), 1, "Check setting and retrieving colSpan" ); - jQuery("#table").prop( "usemap", 1 ); - equal( jQuery("#table").prop("useMap"), 1, "Check setting and retrieving useMap" ); - jQuery("#table").prop( "frameborder", 1 ); - equal( jQuery("#table").prop("frameBorder"), 1, "Check setting and retrieving frameBorder" ); -}); + equal( jQuery( "#text1" ).prop( "value" ), "Test", "Check for value attribute" ); + equal( jQuery( "#text1" ).prop( "value", "Test2" ).prop( "defaultValue" ), "Test", "Check for defaultValue attribute" ); + equal( jQuery( "#select2" ).prop( "selectedIndex" ), 3, "Check for selectedIndex attribute" ); + equal( jQuery( "#foo" ).prop( "nodeName" ).toUpperCase(), "DIV", "Check for nodeName attribute" ); + equal( jQuery( "#foo" ).prop( "tagName" ).toUpperCase(), "DIV", "Check for tagName attribute" ); + equal( jQuery( "<option/>" ).prop( "selected" ), false, "Check selected attribute on disconnected element." ); + + equal( jQuery( "#listWithTabIndex" ).prop( "tabindex" ), 5, "Check retrieving tabindex" ); + jQuery( "#text1" ).prop( "readonly", true ); + equal( document.getElementById( "text1" ).readOnly, true, "Check setting readOnly property with 'readonly'" ); + equal( jQuery( "#label-for" ).prop( "for" ), "action", "Check retrieving htmlFor" ); + jQuery( "#text1" ).prop( "class", "test" ); + equal( document.getElementById( "text1" ).className, "test", "Check setting className with 'class'" ); + equal( jQuery( "#text1" ).prop( "maxlength" ), 30, "Check retrieving maxLength" ); + jQuery( "#table" ).prop( "cellspacing", 1 ); + equal( jQuery( "#table" ).prop( "cellSpacing" ), "1", "Check setting and retrieving cellSpacing" ); + jQuery( "#table" ).prop( "cellpadding", 1 ); + equal( jQuery( "#table" ).prop( "cellPadding" ), "1", "Check setting and retrieving cellPadding" ); + jQuery( "#table" ).prop( "rowspan", 1 ); + equal( jQuery( "#table" ).prop( "rowSpan" ), 1, "Check setting and retrieving rowSpan" ); + jQuery( "#table" ).prop( "colspan", 1 ); + equal( jQuery( "#table" ).prop( "colSpan" ), 1, "Check setting and retrieving colSpan" ); + jQuery( "#table" ).prop( "usemap", 1 ); + equal( jQuery( "#table" ).prop( "useMap" ), 1, "Check setting and retrieving useMap" ); + jQuery( "#table" ).prop( "frameborder", 1 ); + equal( jQuery( "#table" ).prop( "frameBorder" ), 1, "Check setting and retrieving frameBorder" ); +} ); test( "prop(String, Object) on null/undefined", function() { @@ -673,242 +674,243 @@ test( "prop(String, Object) on null/undefined", function() { body = document.body, $body = jQuery( body ); - ok( $body.prop("nextSibling") === null, "Make sure a null expando returns null" ); - body["foo"] = "bar"; - equal( $body.prop("foo"), "bar", "Make sure the expando is preferred over the dom attribute" ); - body["foo"] = undefined; - ok( $body.prop("foo") === undefined, "Make sure the expando is preferred over the dom attribute, even if undefined" ); + ok( $body.prop( "nextSibling" ) === null, "Make sure a null expando returns null" ); + body[ "foo" ] = "bar"; + equal( $body.prop( "foo" ), "bar", "Make sure the expando is preferred over the dom attribute" ); + body[ "foo" ] = undefined; + ok( $body.prop( "foo" ) === undefined, "Make sure the expando is preferred over the dom attribute, even if undefined" ); - select = document.createElement("select"); - optgroup = document.createElement("optgroup"); - option = document.createElement("option"); + select = document.createElement( "select" ); + optgroup = document.createElement( "optgroup" ); + option = document.createElement( "option" ); optgroup.appendChild( option ); select.appendChild( optgroup ); - equal( jQuery( option ).prop("selected"), true, "Make sure that a single option is selected, even when in an optgroup." ); - equal( jQuery( document ).prop("nodeName"), "#document", "prop works correctly on document nodes (bug #7451)." ); + equal( jQuery( option ).prop( "selected" ), true, "Make sure that a single option is selected, even when in an optgroup." ); + equal( jQuery( document ).prop( "nodeName" ), "#document", "prop works correctly on document nodes (bug #7451)." ); - attributeNode = document.createAttribute("irrelevant"); - commentNode = document.createComment("some comment"); - textNode = document.createTextNode("some text"); + attributeNode = document.createAttribute( "irrelevant" ); + commentNode = document.createComment( "some comment" ); + textNode = document.createTextNode( "some text" ); obj = {}; jQuery.each( [ document, attributeNode, commentNode, textNode, obj, "#firstp" ], function( i, ele ) { - strictEqual( jQuery( ele ).prop("nonexisting"), undefined, "prop works correctly for non existing attributes (bug #7500)." ); - }); + strictEqual( jQuery( ele ).prop( "nonexisting" ), undefined, "prop works correctly for non existing attributes (bug #7500)." ); + } ); obj = {}; jQuery.each( [ document, obj ], function( i, ele ) { var $ele = jQuery( ele ); $ele.prop( "nonexisting", "foo" ); - equal( $ele.prop("nonexisting"), "foo", "prop(name, value) works correctly for non existing attributes (bug #7500)." ); - }); - jQuery( document ).removeProp("nonexisting"); + equal( $ele.prop( "nonexisting" ), "foo", "prop(name, value) works correctly for non existing attributes (bug #7500)." ); + } ); + jQuery( document ).removeProp( "nonexisting" ); - $form = jQuery("#form").prop( "enctype", "multipart/form-data" ); - equal( $form.prop("enctype"), "multipart/form-data", "Set the enctype of a form (encoding in IE6/7 #6743)" ); -}); + $form = jQuery( "#form" ).prop( "enctype", "multipart/form-data" ); + equal( $form.prop( "enctype" ), "multipart/form-data", "Set the enctype of a form (encoding in IE6/7 #6743)" ); +} ); test( "prop('tabindex')", function() { expect( 11 ); // inputs without tabIndex attribute - equal( jQuery("#inputWithoutTabIndex").prop("tabindex"), 0, "input without tabindex" ); - equal( jQuery("#buttonWithoutTabIndex").prop("tabindex"), 0, "button without tabindex" ); - equal( jQuery("#textareaWithoutTabIndex").prop("tabindex"), 0, "textarea without tabindex" ); + equal( jQuery( "#inputWithoutTabIndex" ).prop( "tabindex" ), 0, "input without tabindex" ); + equal( jQuery( "#buttonWithoutTabIndex" ).prop( "tabindex" ), 0, "button without tabindex" ); + equal( jQuery( "#textareaWithoutTabIndex" ).prop( "tabindex" ), 0, "textarea without tabindex" ); // elements not natively tabbable - equal( jQuery("#listWithTabIndex").prop("tabindex"), 5, "not natively tabbable, with tabindex set to 0" ); - equal( jQuery("#divWithNoTabIndex").prop("tabindex"), -1, "not natively tabbable, no tabindex set" ); + equal( jQuery( "#listWithTabIndex" ).prop( "tabindex" ), 5, "not natively tabbable, with tabindex set to 0" ); + equal( jQuery( "#divWithNoTabIndex" ).prop( "tabindex" ), -1, "not natively tabbable, no tabindex set" ); // anchor with href - equal( jQuery("#linkWithNoTabIndex").prop("tabindex"), 0, "anchor with href, no tabindex set" ); - equal( jQuery("#linkWithTabIndex").prop("tabindex"), 2, "anchor with href, tabindex set to 2" ); - equal( jQuery("#linkWithNegativeTabIndex").prop("tabindex"), -1, "anchor with href, tabindex set to -1" ); + equal( jQuery( "#linkWithNoTabIndex" ).prop( "tabindex" ), 0, "anchor with href, no tabindex set" ); + equal( jQuery( "#linkWithTabIndex" ).prop( "tabindex" ), 2, "anchor with href, tabindex set to 2" ); + equal( jQuery( "#linkWithNegativeTabIndex" ).prop( "tabindex" ), -1, "anchor with href, tabindex set to -1" ); // anchor without href - equal( jQuery("#linkWithNoHrefWithNoTabIndex").prop("tabindex"), -1, "anchor without href, no tabindex set" ); - equal( jQuery("#linkWithNoHrefWithTabIndex").prop("tabindex"), 1, "anchor without href, tabindex set to 2" ); - equal( jQuery("#linkWithNoHrefWithNegativeTabIndex").prop("tabindex"), -1, "anchor without href, no tabindex set" ); -}); + equal( jQuery( "#linkWithNoHrefWithNoTabIndex" ).prop( "tabindex" ), -1, "anchor without href, no tabindex set" ); + equal( jQuery( "#linkWithNoHrefWithTabIndex" ).prop( "tabindex" ), 1, "anchor without href, tabindex set to 2" ); + equal( jQuery( "#linkWithNoHrefWithNegativeTabIndex" ).prop( "tabindex" ), -1, "anchor without href, no tabindex set" ); +} ); test( "prop('tabindex', value)", function() { expect( 10 ); var clone, - element = jQuery("#divWithNoTabIndex"); + element = jQuery( "#divWithNoTabIndex" ); - equal( element.prop("tabindex"), -1, "start with no tabindex" ); + equal( element.prop( "tabindex" ), -1, "start with no tabindex" ); // set a positive string element.prop( "tabindex", "1" ); - equal( element.prop("tabindex"), 1, "set tabindex to 1 (string)" ); + equal( element.prop( "tabindex" ), 1, "set tabindex to 1 (string)" ); // set a zero string element.prop( "tabindex", "0" ); - equal( element.prop("tabindex"), 0, "set tabindex to 0 (string)" ); + equal( element.prop( "tabindex" ), 0, "set tabindex to 0 (string)" ); // set a negative string element.prop( "tabindex", "-1" ); - equal( element.prop("tabindex"), -1, "set tabindex to -1 (string)" ); + equal( element.prop( "tabindex" ), -1, "set tabindex to -1 (string)" ); // set a positive number element.prop( "tabindex", 1 ); - equal( element.prop("tabindex"), 1, "set tabindex to 1 (number)" ); + equal( element.prop( "tabindex" ), 1, "set tabindex to 1 (number)" ); // set a zero number element.prop( "tabindex", 0 ); - equal( element.prop("tabindex"), 0, "set tabindex to 0 (number)" ); + equal( element.prop( "tabindex" ), 0, "set tabindex to 0 (number)" ); // set a negative number element.prop( "tabindex", -1 ); - equal( element.prop("tabindex"), -1, "set tabindex to -1 (number)" ); + equal( element.prop( "tabindex" ), -1, "set tabindex to -1 (number)" ); - element = jQuery("#linkWithTabIndex"); - equal( element.prop("tabindex"), 2, "start with tabindex 2" ); + element = jQuery( "#linkWithTabIndex" ); + equal( element.prop( "tabindex" ), 2, "start with tabindex 2" ); element.prop( "tabindex", -1 ); - equal( element.prop("tabindex"), -1, "set negative tabindex" ); + equal( element.prop( "tabindex" ), -1, "set negative tabindex" ); clone = element.clone(); clone.prop( "tabindex", 1 ); - equal( clone[ 0 ].getAttribute("tabindex"), "1", "set tabindex on cloned element" ); -}); + equal( clone[ 0 ].getAttribute( "tabindex" ), "1", "set tabindex on cloned element" ); +} ); test( "removeProp(String)", function() { expect( 6 ); - var attributeNode = document.createAttribute("irrelevant"), - commentNode = document.createComment("some comment"), - textNode = document.createTextNode("some text"), + var attributeNode = document.createAttribute( "irrelevant" ), + commentNode = document.createComment( "some comment" ), + textNode = document.createTextNode( "some text" ), obj = {}; strictEqual( - jQuery( "#firstp" ).prop( "nonexisting", "foo" ).removeProp( "nonexisting" )[ 0 ]["nonexisting"], + jQuery( "#firstp" ).prop( "nonexisting", "foo" ).removeProp( "nonexisting" )[ 0 ][ "nonexisting" ], undefined, "removeprop works correctly on DOM element nodes" ); jQuery.each( [ document, obj ], function( i, ele ) { var $ele = jQuery( ele ); - $ele.prop( "nonexisting", "foo" ).removeProp("nonexisting"); - strictEqual( ele["nonexisting"], undefined, "removeProp works correctly on non DOM element nodes (bug #7500)." ); - }); + $ele.prop( "nonexisting", "foo" ).removeProp( "nonexisting" ); + strictEqual( ele[ "nonexisting" ], undefined, "removeProp works correctly on non DOM element nodes (bug #7500)." ); + } ); jQuery.each( [ commentNode, textNode, attributeNode ], function( i, ele ) { var $ele = jQuery( ele ); - $ele.prop( "nonexisting", "foo" ).removeProp("nonexisting"); - strictEqual( ele["nonexisting"], undefined, "removeProp works correctly on non DOM element nodes (bug #7500)." ); - }); -}); + $ele.prop( "nonexisting", "foo" ).removeProp( "nonexisting" ); + strictEqual( ele[ "nonexisting" ], undefined, "removeProp works correctly on non DOM element nodes (bug #7500)." ); + } ); +} ); test( "val() after modification", function() { expect( 1 ); - document.getElementById("text1").value = "bla"; - equal( jQuery("#text1").val(), "bla", "Check for modified value of input element" ); + document.getElementById( "text1" ).value = "bla"; + equal( jQuery( "#text1" ).val(), "bla", "Check for modified value of input element" ); -}); +} ); test( "val()", function() { expect( 20 + ( jQuery.fn.serialize ? 6 : 0 ) ); var checks, $button; - equal( jQuery("#text1").val(), "Test", "Check for value of input element" ); + equal( jQuery( "#text1" ).val(), "Test", "Check for value of input element" ); + // ticket #1714 this caused a JS error in IE - equal( jQuery("#first").val(), "", "Check a paragraph element to see if it has a value" ); - ok( jQuery([]).val() === undefined, "Check an empty jQuery object will return undefined from val" ); + equal( jQuery( "#first" ).val(), "", "Check a paragraph element to see if it has a value" ); + ok( jQuery( [] ).val() === undefined, "Check an empty jQuery object will return undefined from val" ); - equal( jQuery("#select2").val(), "3", "Call val() on a single='single' select" ); + equal( jQuery( "#select2" ).val(), "3", "Call val() on a single='single' select" ); - deepEqual( jQuery("#select3").val(), [ "1", "2" ], "Call val() on a multiple='multiple' select" ); + deepEqual( jQuery( "#select3" ).val(), [ "1", "2" ], "Call val() on a multiple='multiple' select" ); - equal( jQuery("#option3c").val(), "2", "Call val() on a option element with value" ); + equal( jQuery( "#option3c" ).val(), "2", "Call val() on a option element with value" ); - equal( jQuery("#option3a").val(), "", "Call val() on a option element with empty value" ); + equal( jQuery( "#option3a" ).val(), "", "Call val() on a option element with empty value" ); - equal( jQuery("#option3e").val(), "no value", "Call val() on a option element with no value attribute" ); + equal( jQuery( "#option3e" ).val(), "no value", "Call val() on a option element with no value attribute" ); - equal( jQuery("#option3a").val(), "", "Call val() on a option element with no value attribute" ); + equal( jQuery( "#option3a" ).val(), "", "Call val() on a option element with no value attribute" ); - jQuery("#select3").val(""); - deepEqual( jQuery("#select3").val(), [""], "Call val() on a multiple='multiple' select" ); + jQuery( "#select3" ).val( "" ); + deepEqual( jQuery( "#select3" ).val(), [ "" ], "Call val() on a multiple='multiple' select" ); - deepEqual( jQuery("#select4").val(), [], "Call val() on multiple='multiple' select with all disabled options" ); + deepEqual( jQuery( "#select4" ).val(), [], "Call val() on multiple='multiple' select with all disabled options" ); - jQuery("#select4 optgroup").add("#select4 > [disabled]").attr( "disabled", false ); - deepEqual( jQuery("#select4").val(), [ "2", "3" ], "Call val() on multiple='multiple' select with some disabled options" ); + jQuery( "#select4 optgroup" ).add( "#select4 > [disabled]" ).attr( "disabled", false ); + deepEqual( jQuery( "#select4" ).val(), [ "2", "3" ], "Call val() on multiple='multiple' select with some disabled options" ); - jQuery("#select4").attr( "disabled", true ); - deepEqual( jQuery("#select4").val(), [ "2", "3" ], "Call val() on disabled multiple='multiple' select" ); + jQuery( "#select4" ).attr( "disabled", true ); + deepEqual( jQuery( "#select4" ).val(), [ "2", "3" ], "Call val() on disabled multiple='multiple' select" ); - equal( jQuery("#select5").val(), "3", "Check value on ambiguous select." ); + equal( jQuery( "#select5" ).val(), "3", "Check value on ambiguous select." ); - jQuery("#select5").val( 1 ); - equal( jQuery("#select5").val(), "1", "Check value on ambiguous select." ); + jQuery( "#select5" ).val( 1 ); + equal( jQuery( "#select5" ).val(), "1", "Check value on ambiguous select." ); - jQuery("#select5").val( 3 ); - equal( jQuery("#select5").val(), "3", "Check value on ambiguous select." ); + jQuery( "#select5" ).val( 3 ); + equal( jQuery( "#select5" ).val(), "3", "Check value on ambiguous select." ); strictEqual( - jQuery("<select name='select12584' id='select12584'><option value='1' disabled='disabled'>1</option></select>").val(), + jQuery( "<select name='select12584' id='select12584'><option value='1' disabled='disabled'>1</option></select>" ).val(), null, "Select-one with only option disabled (#12584)" ); if ( jQuery.fn.serialize ) { - checks = jQuery("<input type='checkbox' name='test' value='1'/><input type='checkbox' name='test' value='2'/><input type='checkbox' name='test' value=''/><input type='checkbox' name='test'/>").appendTo("#form"); + checks = jQuery( "<input type='checkbox' name='test' value='1'/><input type='checkbox' name='test' value='2'/><input type='checkbox' name='test' value=''/><input type='checkbox' name='test'/>" ).appendTo( "#form" ); deepEqual( checks.serialize(), "", "Get unchecked values." ); equal( checks.eq( 3 ).val(), "on", "Make sure a value of 'on' is provided if none is specified." ); - checks.val([ "2" ]); + checks.val( [ "2" ] ); deepEqual( checks.serialize(), "test=2", "Get a single checked value." ); - checks.val([ "1", "" ]); + checks.val( [ "1", "" ] ); deepEqual( checks.serialize(), "test=1&test=", "Get multiple checked values." ); - checks.val([ "", "2" ]); + checks.val( [ "", "2" ] ); deepEqual( checks.serialize(), "test=2&test=", "Get multiple checked values." ); - checks.val([ "1", "on" ]); + checks.val( [ "1", "on" ] ); deepEqual( checks.serialize(), "test=1&test=on", "Get multiple checked values." ); checks.remove(); } - $button = jQuery("<button value='foobar'>text</button>").insertAfter("#button"); + $button = jQuery( "<button value='foobar'>text</button>" ).insertAfter( "#button" ); equal( $button.val(), "foobar", "Value retrieval on a button does not return innerHTML" ); - equal( $button.val("baz").html(), "text", "Setting the value does not change innerHTML" ); + equal( $button.val( "baz" ).html(), "text", "Setting the value does not change innerHTML" ); - equal( jQuery("<option/>").val("test").attr("value"), "test", "Setting value sets the value attribute" ); -}); + equal( jQuery( "<option/>" ).val( "test" ).attr( "value" ), "test", "Setting value sets the value attribute" ); +} ); -test("val() with non-matching values on dropdown list", function() { +test( "val() with non-matching values on dropdown list", function() { expect( 3 ); - jQuery("#select5").val( "" ); - equal( jQuery("#select5").val(), null, "Non-matching set on select-one" ); + jQuery( "#select5" ).val( "" ); + equal( jQuery( "#select5" ).val(), null, "Non-matching set on select-one" ); - var select6 = jQuery("<select multiple id=\"select6\"><option value=\"1\">A</option><option value=\"2\">B</option></select>").appendTo("#form"); - jQuery(select6).val( "nothing" ); - equal( jQuery(select6).val(), null, "Non-matching set (single value) on select-multiple" ); + var select6 = jQuery( "<select multiple id=\"select6\"><option value=\"1\">A</option><option value=\"2\">B</option></select>" ).appendTo( "#form" ); + jQuery( select6 ).val( "nothing" ); + equal( jQuery( select6 ).val(), null, "Non-matching set (single value) on select-multiple" ); - jQuery(select6).val( ["nothing1", "nothing2"] ); - equal( jQuery(select6).val(), null, "Non-matching set (array of values) on select-multiple" ); + jQuery( select6 ).val( [ "nothing1", "nothing2" ] ); + equal( jQuery( select6 ).val(), null, "Non-matching set (array of values) on select-multiple" ); select6.remove(); -}); +} ); -if ( "value" in document.createElement("meter") && - "value" in document.createElement("progress") ) { +if ( "value" in document.createElement( "meter" ) && + "value" in document.createElement( "progress" ) ) { test( "val() respects numbers without exception (Bug #9319)", function() { expect( 4 ); - var $meter = jQuery("<meter min='0' max='10' value='5.6'></meter>"), - $progress = jQuery("<progress max='10' value='1.5'></progress>"); + var $meter = jQuery( "<meter min='0' max='10' value='5.6'></meter>" ), + $progress = jQuery( "<progress max='10' value='1.5'></progress>" ); try { equal( typeof $meter.val(), "number", "meter, returns a number and does not throw exception" ); @@ -917,47 +919,47 @@ if ( "value" in document.createElement("meter") && equal( typeof $progress.val(), "number", "progress, returns a number and does not throw exception" ); equal( $progress.val(), $progress[ 0 ].value, "progress, api matches host and does not throw exception" ); - } catch( e ) {} + } catch ( e ) {} $meter.remove(); $progress.remove(); - }); + } ); } var testVal = function( valueObj ) { expect( 9 ); - jQuery("#text1").val( valueObj("test") ); - equal( document.getElementById("text1").value, "test", "Check for modified (via val(String)) value of input element" ); + jQuery( "#text1" ).val( valueObj( "test" ) ); + equal( document.getElementById( "text1" ).value, "test", "Check for modified (via val(String)) value of input element" ); - jQuery("#text1").val( valueObj( undefined ) ); - equal( document.getElementById("text1").value, "", "Check for modified (via val(undefined)) value of input element" ); + jQuery( "#text1" ).val( valueObj( undefined ) ); + equal( document.getElementById( "text1" ).value, "", "Check for modified (via val(undefined)) value of input element" ); - jQuery("#text1").val( valueObj( 67 ) ); - equal( document.getElementById("text1").value, "67", "Check for modified (via val(Number)) value of input element" ); + jQuery( "#text1" ).val( valueObj( 67 ) ); + equal( document.getElementById( "text1" ).value, "67", "Check for modified (via val(Number)) value of input element" ); - jQuery("#text1").val( valueObj( null ) ); - equal( document.getElementById("text1").value, "", "Check for modified (via val(null)) value of input element" ); + jQuery( "#text1" ).val( valueObj( null ) ); + equal( document.getElementById( "text1" ).value, "", "Check for modified (via val(null)) value of input element" ); var j, $select = jQuery( "<select multiple><option value='1'/><option value='2'/></select>" ), - $select1 = jQuery("#select1"); + $select1 = jQuery( "#select1" ); - $select1.val( valueObj("3") ); + $select1.val( valueObj( "3" ) ); equal( $select1.val(), "3", "Check for modified (via val(String)) value of select element" ); $select1.val( valueObj( 2 ) ); equal( $select1.val(), "2", "Check for modified (via val(Number)) value of select element" ); - $select1.append("<option value='4'>four</option>"); + $select1.append( "<option value='4'>four</option>" ); $select1.val( valueObj( 4 ) ); equal( $select1.val(), "4", "Should be possible to set the val() to a newly created option" ); // using contents will get comments regular, text, and comment nodes - j = jQuery("#nonnodes").contents(); + j = jQuery( "#nonnodes" ).contents(); j.val( valueObj( "asdf" ) ); equal( j.val(), "asdf", "Check node,textnode,comment with val()" ); - j.removeAttr("value"); + j.removeAttr( "value" ); $select.val( valueObj( [ "1", "2" ] ) ); deepEqual( $select.val(), [ "1", "2" ], "Should set array of values" ); @@ -965,408 +967,407 @@ var testVal = function( valueObj ) { test( "val(String/Number)", function() { testVal( bareObj ); -}); +} ); test( "val(Function)", function() { testVal( functionReturningObj ); -}); +} ); test( "val(Array of Numbers) (Bug #7123)", function() { expect( 4 ); - jQuery("#form").append("<input type='checkbox' name='arrayTest' value='1' /><input type='checkbox' name='arrayTest' value='2' /><input type='checkbox' name='arrayTest' value='3' checked='checked' /><input type='checkbox' name='arrayTest' value='4' />"); - var elements = jQuery("input[name=arrayTest]").val([ 1, 2 ]); + jQuery( "#form" ).append( "<input type='checkbox' name='arrayTest' value='1' /><input type='checkbox' name='arrayTest' value='2' /><input type='checkbox' name='arrayTest' value='3' checked='checked' /><input type='checkbox' name='arrayTest' value='4' />" ); + var elements = jQuery( "input[name=arrayTest]" ).val( [ 1, 2 ] ); ok( elements[ 0 ].checked, "First element was checked" ); ok( elements[ 1 ].checked, "Second element was checked" ); ok( !elements[ 2 ].checked, "Third element was unchecked" ); ok( !elements[ 3 ].checked, "Fourth element remained unchecked" ); elements.remove(); -}); +} ); test( "val(Function) with incoming value", function() { expect( 10 ); - var oldVal = jQuery("#text1").val(); + var oldVal = jQuery( "#text1" ).val(); - jQuery("#text1").val(function( i, val ) { + jQuery( "#text1" ).val( function( i, val ) { equal( val, oldVal, "Make sure the incoming value is correct." ); return "test"; - }); + } ); - equal( document.getElementById("text1").value, "test", "Check for modified (via val(String)) value of input element" ); + equal( document.getElementById( "text1" ).value, "test", "Check for modified (via val(String)) value of input element" ); - oldVal = jQuery("#text1").val(); + oldVal = jQuery( "#text1" ).val(); - jQuery("#text1").val(function( i, val ) { + jQuery( "#text1" ).val( function( i, val ) { equal( val, oldVal, "Make sure the incoming value is correct." ); return 67; - }); + } ); - equal( document.getElementById("text1").value, "67", "Check for modified (via val(Number)) value of input element" ); + equal( document.getElementById( "text1" ).value, "67", "Check for modified (via val(Number)) value of input element" ); - oldVal = jQuery("#select1").val(); + oldVal = jQuery( "#select1" ).val(); - jQuery("#select1").val(function( i, val ) { + jQuery( "#select1" ).val( function( i, val ) { equal( val, oldVal, "Make sure the incoming value is correct." ); return "3"; - }); + } ); - equal( jQuery("#select1").val(), "3", "Check for modified (via val(String)) value of select element" ); + equal( jQuery( "#select1" ).val(), "3", "Check for modified (via val(String)) value of select element" ); - oldVal = jQuery("#select1").val(); + oldVal = jQuery( "#select1" ).val(); - jQuery("#select1").val(function( i, val ) { + jQuery( "#select1" ).val( function( i, val ) { equal( val, oldVal, "Make sure the incoming value is correct." ); return 2; - }); + } ); - equal( jQuery("#select1").val(), "2", "Check for modified (via val(Number)) value of select element" ); + equal( jQuery( "#select1" ).val(), "2", "Check for modified (via val(Number)) value of select element" ); - jQuery("#select1").append("<option value='4'>four</option>"); + jQuery( "#select1" ).append( "<option value='4'>four</option>" ); - oldVal = jQuery("#select1").val(); + oldVal = jQuery( "#select1" ).val(); - jQuery("#select1").val(function( i, val ) { + jQuery( "#select1" ).val( function( i, val ) { equal( val, oldVal, "Make sure the incoming value is correct." ); return 4; - }); + } ); - equal( jQuery("#select1").val(), "4", "Should be possible to set the val() to a newly created option" ); -}); + equal( jQuery( "#select1" ).val(), "4", "Should be possible to set the val() to a newly created option" ); +} ); // testing if a form.reset() breaks a subsequent call to a select element's .val() (in IE only) test( "val(select) after form.reset() (Bug #2551)", function() { expect( 3 ); - jQuery("<form id='kk' name='kk'><select id='kkk'><option value='cf'>cf</option><option value='gf'>gf</option></select></form>").appendTo("#qunit-fixture"); + jQuery( "<form id='kk' name='kk'><select id='kkk'><option value='cf'>cf</option><option value='gf'>gf</option></select></form>" ).appendTo( "#qunit-fixture" ); - jQuery("#kkk").val("gf"); + jQuery( "#kkk" ).val( "gf" ); - document["kk"].reset(); + document[ "kk" ].reset(); - equal( jQuery("#kkk")[ 0 ].value, "cf", "Check value of select after form reset." ); - equal( jQuery("#kkk").val(), "cf", "Check value of select after form reset." ); + equal( jQuery( "#kkk" )[ 0 ].value, "cf", "Check value of select after form reset." ); + equal( jQuery( "#kkk" ).val(), "cf", "Check value of select after form reset." ); // re-verify the multi-select is not broken (after form.reset) by our fix for single-select - deepEqual( jQuery("#select3").val(), ["1", "2"], "Call val() on a multiple='multiple' select" ); + deepEqual( jQuery( "#select3" ).val(), [ "1", "2" ], "Call val() on a multiple='multiple' select" ); - jQuery("#kk").remove(); -}); + jQuery( "#kk" ).remove(); +} ); var testAddClass = function( valueObj ) { expect( 9 ); var pass, j, i, - div = jQuery("#qunit-fixture div"); + div = jQuery( "#qunit-fixture div" ); - div.addClass( valueObj("test") ); + div.addClass( valueObj( "test" ) ); pass = true; for ( i = 0; i < div.length; i++ ) { - if ( !~div.get( i ).className.indexOf("test") ) { + if ( !~div.get( i ).className.indexOf( "test" ) ) { pass = false; } } ok( pass, "Add Class" ); // using contents will get regular, text, and comment nodes - j = jQuery("#nonnodes").contents(); - j.addClass( valueObj("asdf") ); - ok( j.hasClass("asdf"), "Check node,textnode,comment for addClass" ); + j = jQuery( "#nonnodes" ).contents(); + j.addClass( valueObj( "asdf" ) ); + ok( j.hasClass( "asdf" ), "Check node,textnode,comment for addClass" ); - div = jQuery("<div/>"); + div = jQuery( "<div/>" ); - div.addClass( valueObj("test") ); - equal( div.attr("class"), "test", "Make sure there's no extra whitespace." ); + div.addClass( valueObj( "test" ) ); + equal( div.attr( "class" ), "test", "Make sure there's no extra whitespace." ); div.attr( "class", " foo" ); - div.addClass( valueObj("test") ); - equal( div.attr("class"), "foo test", "Make sure there's no extra whitespace." ); + div.addClass( valueObj( "test" ) ); + equal( div.attr( "class" ), "foo test", "Make sure there's no extra whitespace." ); div.attr( "class", "foo" ); - div.addClass( valueObj("bar baz") ); - equal( div.attr("class"), "foo bar baz", "Make sure there isn't too much trimming." ); + div.addClass( valueObj( "bar baz" ) ); + equal( div.attr( "class" ), "foo bar baz", "Make sure there isn't too much trimming." ); div.removeClass(); - div.addClass( valueObj("foo") ).addClass( valueObj("foo") ); - equal( div.attr("class"), "foo", "Do not add the same class twice in separate calls." ); + div.addClass( valueObj( "foo" ) ).addClass( valueObj( "foo" ) ); + equal( div.attr( "class" ), "foo", "Do not add the same class twice in separate calls." ); - div.addClass( valueObj("fo") ); - equal( div.attr("class"), "foo fo", "Adding a similar class does not get interrupted." ); - div.removeClass().addClass("wrap2"); - ok( div.addClass("wrap").hasClass("wrap"), "Can add similarly named classes"); + div.addClass( valueObj( "fo" ) ); + equal( div.attr( "class" ), "foo fo", "Adding a similar class does not get interrupted." ); + div.removeClass().addClass( "wrap2" ); + ok( div.addClass( "wrap" ).hasClass( "wrap" ), "Can add similarly named classes" ); div.removeClass(); - div.addClass( valueObj("bar bar") ); - equal( div.attr("class"), "bar", "Do not add the same class twice in the same call." ); + div.addClass( valueObj( "bar bar" ) ); + equal( div.attr( "class" ), "bar", "Do not add the same class twice in the same call." ); }; test( "addClass(String)", function() { testAddClass( bareObj ); -}); +} ); test( "addClass(Function)", function() { testAddClass( functionReturningObj ); -}); +} ); test( "addClass(Function) with incoming value", function() { expect( 52 ); var pass, i, - div = jQuery("#qunit-fixture div"), - old = div.map(function() { - return jQuery(this).attr("class") || ""; - }); + div = jQuery( "#qunit-fixture div" ), + old = div.map( function() { + return jQuery( this ).attr( "class" ) || ""; + } ); - div.addClass(function( i, val ) { + div.addClass( function( i, val ) { if ( this.id !== "_firebugConsole" ) { equal( val, old[ i ], "Make sure the incoming value is correct." ); return "test"; } - }); + } ); pass = true; for ( i = 0; i < div.length; i++ ) { - if ( div.get(i).className.indexOf("test") === -1 ) { + if ( div.get( i ).className.indexOf( "test" ) === -1 ) { pass = false; } } ok( pass, "Add Class" ); -}); +} ); -var testRemoveClass = function(valueObj) { +var testRemoveClass = function( valueObj ) { expect( 8 ); - var $set = jQuery("#qunit-fixture div"), - div = document.createElement("div"); + var $set = jQuery( "#qunit-fixture div" ), + div = document.createElement( "div" ); - $set.addClass("test").removeClass( valueObj("test") ); + $set.addClass( "test" ).removeClass( valueObj( "test" ) ); - ok( !$set.is(".test"), "Remove Class" ); + ok( !$set.is( ".test" ), "Remove Class" ); - $set.addClass("test").addClass("foo").addClass("bar"); - $set.removeClass( valueObj("test") ).removeClass( valueObj("bar") ).removeClass( valueObj("foo") ); + $set.addClass( "test" ).addClass( "foo" ).addClass( "bar" ); + $set.removeClass( valueObj( "test" ) ).removeClass( valueObj( "bar" ) ).removeClass( valueObj( "foo" ) ); - ok( !$set.is(".test,.bar,.foo"), "Remove multiple classes" ); + ok( !$set.is( ".test,.bar,.foo" ), "Remove multiple classes" ); // Make sure that a null value doesn't cause problems - $set.eq( 0 ).addClass("expected").removeClass( valueObj( null ) ); - ok( $set.eq( 0 ).is(".expected"), "Null value passed to removeClass" ); + $set.eq( 0 ).addClass( "expected" ).removeClass( valueObj( null ) ); + ok( $set.eq( 0 ).is( ".expected" ), "Null value passed to removeClass" ); - $set.eq( 0 ).addClass("expected").removeClass( valueObj("") ); - ok( $set.eq( 0 ).is(".expected"), "Empty string passed to removeClass" ); + $set.eq( 0 ).addClass( "expected" ).removeClass( valueObj( "" ) ); + ok( $set.eq( 0 ).is( ".expected" ), "Empty string passed to removeClass" ); // using contents will get regular, text, and comment nodes - $set = jQuery("#nonnodes").contents(); - $set.removeClass( valueObj("asdf") ); - ok( !$set.hasClass("asdf"), "Check node,textnode,comment for removeClass" ); - + $set = jQuery( "#nonnodes" ).contents(); + $set.removeClass( valueObj( "asdf" ) ); + ok( !$set.hasClass( "asdf" ), "Check node,textnode,comment for removeClass" ); - jQuery( div ).removeClass( valueObj("foo") ); - strictEqual( jQuery( div ).attr("class"), undefined, "removeClass doesn't create a class attribute" ); + jQuery( div ).removeClass( valueObj( "foo" ) ); + strictEqual( jQuery( div ).attr( "class" ), undefined, "removeClass doesn't create a class attribute" ); div.className = " test foo "; - jQuery( div ).removeClass( valueObj("foo") ); + jQuery( div ).removeClass( valueObj( "foo" ) ); equal( div.className, "test", "Make sure remaining className is trimmed." ); div.className = " test "; - jQuery( div ).removeClass( valueObj("test") ); + jQuery( div ).removeClass( valueObj( "test" ) ); equal( div.className, "", "Make sure there is nothing left after everything is removed." ); }; test( "removeClass(String) - simple", function() { testRemoveClass( bareObj ); -}); +} ); test( "removeClass(Function) - simple", function() { testRemoveClass( functionReturningObj ); -}); +} ); test( "removeClass(Function) with incoming value", function() { expect( 52 ); - var $divs = jQuery("#qunit-fixture div").addClass("test"), old = $divs.map(function() { - return jQuery( this ).attr("class"); - }); + var $divs = jQuery( "#qunit-fixture div" ).addClass( "test" ), old = $divs.map( function() { + return jQuery( this ).attr( "class" ); + } ); - $divs.removeClass(function( i, val ) { + $divs.removeClass( function( i, val ) { if ( this.id !== "_firebugConsole" ) { equal( val, old[ i ], "Make sure the incoming value is correct." ); return "test"; } - }); + } ); - ok( !$divs.is(".test"), "Remove Class" ); -}); + ok( !$divs.is( ".test" ), "Remove Class" ); +} ); test( "removeClass() removes duplicates", function() { expect( 1 ); - var $div = jQuery( jQuery.parseHTML("<div class='x x x'></div>") ); + var $div = jQuery( jQuery.parseHTML( "<div class='x x x'></div>" ) ); - $div.removeClass("x"); + $div.removeClass( "x" ); - ok( !$div.hasClass("x"), "Element with multiple same classes does not escape the wrath of removeClass()" ); -}); + ok( !$div.hasClass( "x" ), "Element with multiple same classes does not escape the wrath of removeClass()" ); +} ); -test("removeClass(undefined) is a no-op", function() { +test( "removeClass(undefined) is a no-op", function() { expect( 1 ); - var $div = jQuery("<div class='base second'></div>"); + var $div = jQuery( "<div class='base second'></div>" ); $div.removeClass( undefined ); - ok( $div.hasClass("base") && $div.hasClass("second"), "Element still has classes after removeClass(undefined)" ); -}); + ok( $div.hasClass( "base" ) && $div.hasClass( "second" ), "Element still has classes after removeClass(undefined)" ); +} ); -var testToggleClass = function(valueObj) { +var testToggleClass = function( valueObj ) { expect( 17 ); - var e = jQuery("#firstp"); - ok( !e.is(".test"), "Assert class not present" ); - e.toggleClass( valueObj("test") ); - ok( e.is(".test"), "Assert class present" ); - e.toggleClass( valueObj("test") ); - ok( !e.is(".test"), "Assert class not present" ); + var e = jQuery( "#firstp" ); + ok( !e.is( ".test" ), "Assert class not present" ); + e.toggleClass( valueObj( "test" ) ); + ok( e.is( ".test" ), "Assert class present" ); + e.toggleClass( valueObj( "test" ) ); + ok( !e.is( ".test" ), "Assert class not present" ); // class name with a boolean - e.toggleClass( valueObj("test"), false ); - ok( !e.is(".test"), "Assert class not present" ); - e.toggleClass( valueObj("test"), true ); - ok( e.is(".test"), "Assert class present" ); - e.toggleClass( valueObj("test"), false ); - ok( !e.is(".test"), "Assert class not present" ); + e.toggleClass( valueObj( "test" ), false ); + ok( !e.is( ".test" ), "Assert class not present" ); + e.toggleClass( valueObj( "test" ), true ); + ok( e.is( ".test" ), "Assert class present" ); + e.toggleClass( valueObj( "test" ), false ); + ok( !e.is( ".test" ), "Assert class not present" ); // multiple class names - e.addClass("testA testB"); - ok( e.is(".testA.testB"), "Assert 2 different classes present" ); - e.toggleClass( valueObj("testB testC") ); - ok( (e.is(".testA.testC") && !e.is(".testB")), "Assert 1 class added, 1 class removed, and 1 class kept" ); - e.toggleClass( valueObj("testA testC") ); - ok( (!e.is(".testA") && !e.is(".testB") && !e.is(".testC")), "Assert no class present" ); + e.addClass( "testA testB" ); + ok( e.is( ".testA.testB" ), "Assert 2 different classes present" ); + e.toggleClass( valueObj( "testB testC" ) ); + ok( ( e.is( ".testA.testC" ) && !e.is( ".testB" ) ), "Assert 1 class added, 1 class removed, and 1 class kept" ); + e.toggleClass( valueObj( "testA testC" ) ); + ok( ( !e.is( ".testA" ) && !e.is( ".testB" ) && !e.is( ".testC" ) ), "Assert no class present" ); // toggleClass storage e.toggleClass( true ); ok( e[ 0 ].className === "", "Assert class is empty (data was empty)" ); - e.addClass("testD testE"); - ok( e.is(".testD.testE"), "Assert class present" ); + e.addClass( "testD testE" ); + ok( e.is( ".testD.testE" ), "Assert class present" ); e.toggleClass(); - ok( !e.is(".testD.testE"), "Assert class not present" ); - ok( jQuery._data(e[ 0 ], "__className__") === "testD testE", "Assert data was stored" ); + ok( !e.is( ".testD.testE" ), "Assert class not present" ); + ok( jQuery._data( e[ 0 ], "__className__" ) === "testD testE", "Assert data was stored" ); e.toggleClass(); - ok( e.is(".testD.testE"), "Assert class present (restored from data)" ); + ok( e.is( ".testD.testE" ), "Assert class present (restored from data)" ); e.toggleClass( false ); - ok( !e.is(".testD.testE"), "Assert class not present" ); + ok( !e.is( ".testD.testE" ), "Assert class not present" ); e.toggleClass( true ); - ok( e.is(".testD.testE"), "Assert class present (restored from data)" ); + ok( e.is( ".testD.testE" ), "Assert class present (restored from data)" ); e.toggleClass(); e.toggleClass( false ); e.toggleClass(); - ok( e.is(".testD.testE"), "Assert class present (restored from data)" ); + ok( e.is( ".testD.testE" ), "Assert class present (restored from data)" ); // Cleanup - e.removeClass("testD"); + e.removeClass( "testD" ); QUnit.expectJqData( this, e[ 0 ], "__className__" ); }; test( "toggleClass(String|boolean|undefined[, boolean])", function() { testToggleClass( bareObj ); -}); +} ); test( "toggleClass(Function[, boolean])", function() { testToggleClass( functionReturningObj ); -}); +} ); test( "toggleClass(Function[, boolean]) with incoming value", function() { expect( 14 ); - var e = jQuery("#firstp"), - old = e.attr("class") || ""; + var e = jQuery( "#firstp" ), + old = e.attr( "class" ) || ""; - ok( !e.is(".test"), "Assert class not present" ); + ok( !e.is( ".test" ), "Assert class not present" ); - e.toggleClass(function( i, val ) { + e.toggleClass( function( i, val ) { equal( old, val, "Make sure the incoming value is correct." ); return "test"; - }); - ok( e.is(".test"), "Assert class present" ); + } ); + ok( e.is( ".test" ), "Assert class present" ); - old = e.attr("class"); + old = e.attr( "class" ); - e.toggleClass(function( i, val ) { + e.toggleClass( function( i, val ) { equal( old, val, "Make sure the incoming value is correct." ); return "test"; - }); - ok( !e.is(".test"), "Assert class not present" ); + } ); + ok( !e.is( ".test" ), "Assert class not present" ); - old = e.attr("class") || ""; + old = e.attr( "class" ) || ""; // class name with a boolean - e.toggleClass(function( i, val, state ) { + e.toggleClass( function( i, val, state ) { equal( old, val, "Make sure the incoming value is correct." ); equal( state, false, "Make sure that the state is passed in." ); return "test"; }, false ); - ok( !e.is(".test"), "Assert class not present" ); + ok( !e.is( ".test" ), "Assert class not present" ); - old = e.attr("class") || ""; + old = e.attr( "class" ) || ""; - e.toggleClass(function( i, val, state ) { + e.toggleClass( function( i, val, state ) { equal( old, val, "Make sure the incoming value is correct." ); equal( state, true, "Make sure that the state is passed in." ); return "test"; }, true ); - ok( e.is(".test"), "Assert class present" ); + ok( e.is( ".test" ), "Assert class present" ); - old = e.attr("class"); + old = e.attr( "class" ); - e.toggleClass(function( i, val, state ) { + e.toggleClass( function( i, val, state ) { equal( old, val, "Make sure the incoming value is correct." ); equal( state, false, "Make sure that the state is passed in." ); return "test"; }, false ); - ok( !e.is(".test"), "Assert class not present" ); -}); + ok( !e.is( ".test" ), "Assert class not present" ); +} ); test( "addClass, removeClass, hasClass", function() { expect( 17 ); - var jq = jQuery("<p>Hi</p>"), x = jq[ 0 ]; + var jq = jQuery( "<p>Hi</p>" ), x = jq[ 0 ]; - jq.addClass("hi"); + jq.addClass( "hi" ); equal( x.className, "hi", "Check single added class" ); - jq.addClass("foo bar"); + jq.addClass( "foo bar" ); equal( x.className, "hi foo bar", "Check more added classes" ); jq.removeClass(); equal( x.className, "", "Remove all classes" ); - jq.addClass("hi foo bar"); - jq.removeClass("foo"); + jq.addClass( "hi foo bar" ); + jq.removeClass( "foo" ); equal( x.className, "hi bar", "Check removal of one class" ); - ok( jq.hasClass("hi"), "Check has1" ); - ok( jq.hasClass("bar"), "Check has2" ); - - jq = jQuery("<p class='class1\nclass2\tcla.ss3\n\rclass4'></p>"); - - ok( jq.hasClass("class1"), "Check hasClass with line feed" ); - ok( jq.is(".class1"), "Check is with line feed" ); - ok( jq.hasClass("class2"), "Check hasClass with tab" ); - ok( jq.is(".class2"), "Check is with tab" ); - ok( jq.hasClass("cla.ss3"), "Check hasClass with dot" ); - ok( jq.hasClass("class4"), "Check hasClass with carriage return" ); - ok( jq.is(".class4"), "Check is with carriage return" ); - - jq.removeClass("class2"); - ok( jq.hasClass("class2") === false, "Check the class has been properly removed" ); - jq.removeClass("cla"); - ok( jq.hasClass("cla.ss3"), "Check the dotted class has not been removed" ); - jq.removeClass("cla.ss3"); - ok( jq.hasClass("cla.ss3") === false, "Check the dotted class has been removed" ); - jq.removeClass("class4"); - ok( jq.hasClass("class4") === false, "Check the class has been properly removed" ); -}); + ok( jq.hasClass( "hi" ), "Check has1" ); + ok( jq.hasClass( "bar" ), "Check has2" ); + + jq = jQuery( "<p class='class1\nclass2\tcla.ss3\n\rclass4'></p>" ); + + ok( jq.hasClass( "class1" ), "Check hasClass with line feed" ); + ok( jq.is( ".class1" ), "Check is with line feed" ); + ok( jq.hasClass( "class2" ), "Check hasClass with tab" ); + ok( jq.is( ".class2" ), "Check is with tab" ); + ok( jq.hasClass( "cla.ss3" ), "Check hasClass with dot" ); + ok( jq.hasClass( "class4" ), "Check hasClass with carriage return" ); + ok( jq.is( ".class4" ), "Check is with carriage return" ); + + jq.removeClass( "class2" ); + ok( jq.hasClass( "class2" ) === false, "Check the class has been properly removed" ); + jq.removeClass( "cla" ); + ok( jq.hasClass( "cla.ss3" ), "Check the dotted class has not been removed" ); + jq.removeClass( "cla.ss3" ); + ok( jq.hasClass( "cla.ss3" ) === false, "Check the dotted class has been removed" ); + jq.removeClass( "class4" ); + ok( jq.hasClass( "class4" ) === false, "Check the class has been properly removed" ); +} ); test( "addClass, removeClass, hasClass on many elements", function() { expect( 19 ); @@ -1409,17 +1410,17 @@ test( "addClass, removeClass, hasClass on many elements", function() { ok( !jQuery( "<p class='hi0'>p0</p><p class='hi1'>p1</p><p class='hi2'>p2</p>" ).hasClass( "hi" ), "Did not find a class when not present" ); -}); +} ); test( "contents().hasClass() returns correct values", function() { expect( 2 ); - var $div = jQuery("<div><span class='foo'></span><!-- comment -->text</div>"), + var $div = jQuery( "<div><span class='foo'></span><!-- comment -->text</div>" ), $contents = $div.contents(); - ok( $contents.hasClass("foo"), "Found 'foo' in $contents" ); - ok( !$contents.hasClass("undefined"), "Did not find 'undefined' in $contents (correctly)" ); -}); + ok( $contents.hasClass( "foo" ), "Found 'foo' in $contents" ); + ok( !$contents.hasClass( "undefined" ), "Did not find 'undefined' in $contents (correctly)" ); +} ); test( "hasClass correctly interprets non-space separators (#13835)", function() { expect( 4 ); @@ -1433,23 +1434,23 @@ test( "hasClass correctly interprets non-space separators (#13835)", function() }, classes = jQuery.map( map, function( separator, label ) { return " " + separator + label + separator + " "; - }), + } ), $div = jQuery( "<div class='" + classes + "'></div>" ); jQuery.each( map, function( label ) { ok( $div.hasClass( label ), label.replace( "-", " " ) ); - }); -}); + } ); +} ); test( "coords returns correct values in IE6/IE7, see #10828", function() { expect( 1 ); var area, - map = jQuery("<map />"); + map = jQuery( "<map />" ); - area = map.html("<area shape='rect' coords='0,0,0,0' href='#' alt='a' />").find("area"); - equal( area.attr("coords"), "0,0,0,0", "did not retrieve coords correctly" ); -}); + area = map.html( "<area shape='rect' coords='0,0,0,0' href='#' alt='a' />" ).find( "area" ); + equal( area.attr( "coords" ), "0,0,0,0", "did not retrieve coords correctly" ); +} ); test( "should not throw at $(option).val() (#14686)", function() { expect( 1 ); @@ -1460,12 +1461,12 @@ test( "should not throw at $(option).val() (#14686)", function() { } catch ( _ ) { ok( false ); } -}); +} ); test( "option value not trimmed when setting via parent select", function() { expect( 1 ); equal( jQuery( "<select><option> 2</option></select>" ).val( "2" ).val(), "2" ); -}); +} ); test( "Insignificant white space returned for $(option).val() (#14858)", function() { expect ( 3 ); @@ -1478,7 +1479,7 @@ test( "Insignificant white space returned for $(option).val() (#14858)", functio val = jQuery( "<option> test </option>" ).val(); equal( val.length, 4, "insignificant white-space returned for value" ); -}); +} ); test( "SVG class manipulation (gh-2199)", function() { @@ -1499,7 +1500,7 @@ test( "SVG class manipulation (gh-2199)", function() { return document.createElementNS( "http://www.w3.org/2000/svg", nodeName ); } - jQuery.each([ + jQuery.each( [ "svg", "rect", "g" @@ -1517,5 +1518,5 @@ test( "SVG class manipulation (gh-2199)", function() { elem.toggleClass( "awesome" ); ok( !elem.hasClass( "awesome" ), "SVG element (" + this + ") toggles the class off" ); - }); -}); + } ); +} ); diff --git a/test/unit/callbacks.js b/test/unit/callbacks.js index b8dc8ab53..089047f03 100644 --- a/test/unit/callbacks.js +++ b/test/unit/callbacks.js @@ -1,8 +1,8 @@ module( "callbacks", { teardown: moduleTeardown -}); +} ); -(function() { +( function() { var output, addToOutput = function( string ) { @@ -10,9 +10,9 @@ var output, output += string; }; }, - outputA = addToOutput("A"), - outputB = addToOutput("B"), - outputC = addToOutput("C"), + outputA = addToOutput( "A" ), + outputB = addToOutput( "B" ), + outputC = addToOutput( "C" ), tests = { "": "XABC X XABCABCC X XBB X XABA X XX", "once": "XABC X X X X X XABA X XX", @@ -54,11 +54,11 @@ jQuery.each( tests, function( strFlags, resultString ) { if ( this.length ) { objectFlags[ this ] = true; } - }); + } ); jQuery.each( filters, function( filterLabel ) { - jQuery.each({ + jQuery.each( { "string": strFlags, "object": objectFlags }, function( flagsTypes, flags ) { @@ -76,20 +76,20 @@ jQuery.each( tests, function( strFlags, resultString ) { strictEqual( cblist.locked(), false, ".locked() initially false" ); strictEqual( cblist.disabled(), false, ".disabled() initially false" ); strictEqual( cblist.fired(), false, ".fired() initially false" ); - cblist.add(function( str ) { + cblist.add( function( str ) { output += str; - }); + } ); strictEqual( cblist.fired(), false, ".fired() still false after .add" ); cblist.fire( "A" ); strictEqual( output, "XA", "Basic binding and firing" ); strictEqual( cblist.fired(), true, ".fired() detects firing" ); output = "X"; cblist.disable(); - cblist.add(function( str ) { + cblist.add( function( str ) { output += str; - }); + } ); strictEqual( output, "X", "Adding a callback after disabling" ); - cblist.fire("A"); + cblist.fire( "A" ); strictEqual( output, "X", "Firing after disabling" ); strictEqual( cblist.disabled(), true, ".disabled() becomes true" ); strictEqual( cblist.locked(), true, "disabling locks" ); @@ -113,20 +113,20 @@ jQuery.each( tests, function( strFlags, resultString ) { // Basic binding and firing (context, arguments) output = "X"; cblist = jQuery.Callbacks( flags ); - cblist.add(function() { + cblist.add( function() { equal( this, window, "Basic binding and firing (context)" ); output += Array.prototype.join.call( arguments, "" ); - }); + } ); cblist.fireWith( window, [ "A", "B" ] ); strictEqual( output, "XAB", "Basic binding and firing (arguments)" ); // fireWith with no arguments output = ""; cblist = jQuery.Callbacks( flags ); - cblist.add(function() { + cblist.add( function() { equal( this, window, "fireWith with no arguments (context is window)" ); strictEqual( arguments.length, 0, "fireWith with no arguments (no arguments)" ); - }); + } ); cblist.fireWith(); // Basic binding, removing and firing @@ -150,17 +150,17 @@ jQuery.each( tests, function( strFlags, resultString ) { // Locking output = "X"; cblist = jQuery.Callbacks( flags ); - cblist.add(function( str ) { + cblist.add( function( str ) { output += str; - }); + } ); cblist.lock(); - cblist.add(function( str ) { + cblist.add( function( str ) { output += str; - }); - cblist.fire("A"); - cblist.add(function( str ) { + } ); + cblist.fire( "A" ); + cblist.add( function( str ) { output += str; - }); + } ); strictEqual( output, "X", "Lock early" ); strictEqual( cblist.locked(), true, "Locking reflected in accessor" ); @@ -168,16 +168,16 @@ jQuery.each( tests, function( strFlags, resultString ) { output = "X"; cblist = jQuery.Callbacks( flags ); cblist.add( cblist.lock ); - cblist.add(function( str ) { + cblist.add( function( str ) { output += str; - }); + } ); cblist.fire( "A" ); strictEqual( output, "XA", "Locking doesn't abort execution (gh-1990)" ); // Ordering output = "X"; cblist = jQuery.Callbacks( flags ); - cblist.add(function() { + cblist.add( function() { cblist.add( outputC ); outputA(); }, outputB ); @@ -186,7 +186,7 @@ jQuery.each( tests, function( strFlags, resultString ) { // Add and fire again output = "X"; - cblist.add(function() { + cblist.add( function() { cblist.add( outputC ); outputA(); }, outputB ); @@ -199,23 +199,23 @@ jQuery.each( tests, function( strFlags, resultString ) { // Multiple fire output = "X"; cblist = jQuery.Callbacks( flags ); - cblist.add(function( str ) { + cblist.add( function( str ) { output += str; - }); - cblist.fire("A"); + } ); + cblist.fire( "A" ); strictEqual( output, "XA", "Multiple fire (first fire)" ); output = "X"; - cblist.add(function( str ) { + cblist.add( function( str ) { output += str; - }); + } ); strictEqual( output, results.shift(), "Multiple fire (first new callback)" ); output = "X"; - cblist.fire("B"); + cblist.fire( "B" ); strictEqual( output, results.shift(), "Multiple fire (second fire)" ); output = "X"; - cblist.add(function( str ) { + cblist.add( function( str ) { output += str; - }); + } ); strictEqual( output, results.shift(), "Multiple fire (second new callback)" ); // Return false @@ -244,12 +244,12 @@ jQuery.each( tests, function( strFlags, resultString ) { cblist.add( handler ); cblist.fire(); strictEqual( output, results.shift(), "No callback iteration" ); - }); - }); - }); -}); + } ); + } ); + } ); +} ); -})(); +} )(); test( "jQuery.Callbacks( options ) - options are copied", function() { @@ -263,25 +263,25 @@ test( "jQuery.Callbacks( options ) - options are copied", function() { fn = function() { ok( !( count++ ), "called once" ); }; - options["unique"] = false; + options[ "unique" ] = false; cb.add( fn, fn ); cb.fire(); -}); +} ); test( "jQuery.Callbacks.fireWith - arguments are copied", function() { expect( 1 ); - var cb = jQuery.Callbacks("memory"), - args = ["hello"]; + var cb = jQuery.Callbacks( "memory" ), + args = [ "hello" ]; cb.fireWith( null, args ); args[ 0 ] = "world"; - cb.add(function( hello ) { + cb.add( function( hello ) { strictEqual( hello, "hello", "arguments are copied internally" ); - }); -}); + } ); +} ); test( "jQuery.Callbacks.remove - should remove all instances", function() { @@ -295,8 +295,8 @@ test( "jQuery.Callbacks.remove - should remove all instances", function() { cb.add( fn, fn, function() { ok( true, "end of test" ); - }).remove( fn ).fire(); -}); + } ).remove( fn ).fire(); +} ); test( "jQuery.Callbacks.has", function() { @@ -312,36 +312,36 @@ test( "jQuery.Callbacks.has", function() { function getC() { return "C"; } - cb.add(getA, getB, getC); + cb.add( getA, getB, getC ); strictEqual( cb.has(), true, "No arguments to .has() returns whether callback function(s) are attached or not" ); - strictEqual( cb.has(getA), true, "Check if a specific callback function is in the Callbacks list" ); + strictEqual( cb.has( getA ), true, "Check if a specific callback function is in the Callbacks list" ); - cb.remove(getB); - strictEqual( cb.has(getB), false, "Remove a specific callback function and make sure its no longer there" ); - strictEqual( cb.has(getA), true, "Remove a specific callback function and make sure other callback function is still there" ); + cb.remove( getB ); + strictEqual( cb.has( getB ), false, "Remove a specific callback function and make sure its no longer there" ); + strictEqual( cb.has( getA ), true, "Remove a specific callback function and make sure other callback function is still there" ); cb.empty(); strictEqual( cb.has(), false, "Empty list and make sure there are no callback function(s)" ); - strictEqual( cb.has(getA), false, "Check for a specific function in an empty() list" ); + strictEqual( cb.has( getA ), false, "Check for a specific function in an empty() list" ); - cb.add(getA, getB, function(){ + cb.add( getA, getB, function() { strictEqual( cb.has(), true, "Check if list has callback function(s) from within a callback function" ); - strictEqual( cb.has(getA), true, "Check if list has a specific callback from within a callback function" ); - }).fire(); + strictEqual( cb.has( getA ), true, "Check if list has a specific callback from within a callback function" ); + } ).fire(); strictEqual( cb.has(), true, "Callbacks list has callback function(s) after firing" ); cb.disable(); strictEqual( cb.has(), false, "disabled() list has no callback functions (returns false)" ); - strictEqual( cb.has(getA), false, "Check for a specific function in a disabled() list" ); + strictEqual( cb.has( getA ), false, "Check for a specific function in a disabled() list" ); - cb = jQuery.Callbacks("unique"); - cb.add(getA); - cb.add(getA); + cb = jQuery.Callbacks( "unique" ); + cb.add( getA ); + cb.add( getA ); strictEqual( cb.has(), true, "Check if unique list has callback function(s) attached" ); cb.lock(); strictEqual( cb.has(), false, "locked() list is empty and returns false" ); -}); +} ); test( "jQuery.Callbacks() - adding a string doesn't cause a stack overflow", function() { @@ -350,7 +350,7 @@ test( "jQuery.Callbacks() - adding a string doesn't cause a stack overflow", fun jQuery.Callbacks().add( "hello world" ); ok( true, "no stack overflow" ); -}); +} ); test( "jQuery.Callbacks() - disabled callback doesn't fire (gh-1790)", function() { @@ -365,4 +365,4 @@ test( "jQuery.Callbacks() - disabled callback doesn't fire (gh-1790)", function( cb.add( shot ); cb.fire(); ok( !fired, "Disabled callback function didn't fire" ); -}); +} ); diff --git a/test/unit/core.js b/test/unit/core.js index 688fe97a6..bf95ff04b 100644 --- a/test/unit/core.js +++ b/test/unit/core.js @@ -1,7 +1,7 @@ -module("core", { teardown: moduleTeardown }); +module( "core", { teardown: moduleTeardown } ); -test("Basic requirements", function() { - expect(7); +test( "Basic requirements", function() { + expect( 7 ); ok( Array.prototype.push, "Array.push()" ); ok( Function.prototype.apply, "Function.apply()" ); ok( document.getElementById, "getElementById" ); @@ -9,15 +9,15 @@ test("Basic requirements", function() { ok( RegExp, "RegExp" ); ok( jQuery, "jQuery" ); ok( $, "$" ); -}); +} ); -test("jQuery()", function() { +test( "jQuery()", function() { var elem, i, - obj = jQuery("div"), - code = jQuery("<code/>"), - img = jQuery("<img/>"), - div = jQuery("<div/><hr/><code/><b/>"), + obj = jQuery( "div" ), + code = jQuery( "<code/>" ), + img = jQuery( "<img/>" ), + div = jQuery( "<div/><hr/><code/><b/>" ), exec = false, expected = 23, attrObj = { @@ -30,19 +30,19 @@ test("jQuery()", function() { // few here but beware of modular builds where these methods may be excluded. if ( jQuery.fn.click ) { expected++; - attrObj["click"] = function() { ok( exec, "Click executed." ); }; + attrObj[ "click" ] = function() { ok( exec, "Click executed." ); }; } if ( jQuery.fn.width ) { expected++; - attrObj["width"] = 10; + attrObj[ "width" ] = 10; } if ( jQuery.fn.offset ) { expected++; - attrObj["offset"] = { "top": 1, "left": 1 }; + attrObj[ "offset" ] = { "top": 1, "left": 1 }; } if ( jQuery.fn.css ) { expected += 2; - attrObj["css"] = { "paddingLeft": 1, "paddingRight": 1 }; + attrObj[ "css" ] = { "paddingLeft": 1, "paddingRight": 1 }; } if ( jQuery.fn.attr ) { expected++; @@ -53,10 +53,10 @@ test("jQuery()", function() { // Basic constructor's behavior equal( jQuery().length, 0, "jQuery() === jQuery([])" ); - equal( jQuery(undefined).length, 0, "jQuery(undefined) === jQuery([])" ); - equal( jQuery(null).length, 0, "jQuery(null) === jQuery([])" ); - equal( jQuery("").length, 0, "jQuery('') === jQuery([])" ); - deepEqual( jQuery(obj).get(), obj.get(), "jQuery(jQueryObj) == jQueryObj" ); + equal( jQuery( undefined ).length, 0, "jQuery(undefined) === jQuery([])" ); + equal( jQuery( null ).length, 0, "jQuery(null) === jQuery([])" ); + equal( jQuery( "" ).length, 0, "jQuery('') === jQuery([])" ); + deepEqual( jQuery( obj ).get(), obj.get(), "jQuery(jQueryObj) == jQueryObj" ); // Invalid #id goes to Sizzle which will throw an error (gh-1682) try { @@ -66,7 +66,7 @@ test("jQuery()", function() { } // can actually yield more than one, when iframes are included, the window is an array as well - equal( jQuery(window).length, 1, "Correct number of elements generated for jQuery(window)" ); + equal( jQuery( window ).length, 1, "Correct number of elements generated for jQuery(window)" ); /* // disabled since this test was doing nothing. i tried to fix it but i'm not sure @@ -95,76 +95,76 @@ test("jQuery()", function() { equal( div.length, 4, "Correct number of elements generated for div hr code b" ); equal( div.parent().length, 0, "Make sure that the generated HTML has no parent." ); - equal( jQuery([1,2,3]).get(1), 2, "Test passing an array to the factory" ); + equal( jQuery( [ 1,2,3 ] ).get( 1 ), 2, "Test passing an array to the factory" ); - equal( jQuery(document.body).get(0), jQuery("body").get(0), "Test passing an html node to the factory" ); + equal( jQuery( document.body ).get( 0 ), jQuery( "body" ).get( 0 ), "Test passing an html node to the factory" ); - elem = jQuery(" <em>hello</em>")[0]; + elem = jQuery( " <em>hello</em>" )[ 0 ]; equal( elem.nodeName.toLowerCase(), "em", "leading space" ); - elem = jQuery("\n\n<em>world</em>")[0]; + elem = jQuery( "\n\n<em>world</em>" )[ 0 ]; equal( elem.nodeName.toLowerCase(), "em", "leading newlines" ); - elem = jQuery("<div/>", attrObj ); + elem = jQuery( "<div/>", attrObj ); if ( jQuery.fn.width ) { - equal( elem[0].style.width, "10px", "jQuery() quick setter width"); + equal( elem[ 0 ].style.width, "10px", "jQuery() quick setter width" ); } if ( jQuery.fn.offset ) { - equal( elem[0].style.top, "1px", "jQuery() quick setter offset"); + equal( elem[ 0 ].style.top, "1px", "jQuery() quick setter offset" ); } if ( jQuery.fn.css ) { - equal( elem[0].style.paddingLeft, "1px", "jQuery quick setter css"); - equal( elem[0].style.paddingRight, "1px", "jQuery quick setter css"); + equal( elem[ 0 ].style.paddingLeft, "1px", "jQuery quick setter css" ); + equal( elem[ 0 ].style.paddingRight, "1px", "jQuery quick setter css" ); } if ( jQuery.fn.attr ) { - equal( elem[0].getAttribute("desired"), "very", "jQuery quick setter attr"); + equal( elem[ 0 ].getAttribute( "desired" ), "very", "jQuery quick setter attr" ); } - equal( elem[0].childNodes.length, 1, "jQuery quick setter text"); - equal( elem[0].firstChild.nodeValue, "test", "jQuery quick setter text"); - equal( elem[0].className, "test2", "jQuery() quick setter class"); - equal( elem[0].id, "test3", "jQuery() quick setter id"); + equal( elem[ 0 ].childNodes.length, 1, "jQuery quick setter text" ); + equal( elem[ 0 ].firstChild.nodeValue, "test", "jQuery quick setter text" ); + equal( elem[ 0 ].className, "test2", "jQuery() quick setter class" ); + equal( elem[ 0 ].id, "test3", "jQuery() quick setter id" ); exec = true; - elem.trigger("click"); + elem.trigger( "click" ); // manually clean up detached elements elem.remove(); for ( i = 0; i < 3; ++i ) { - elem = jQuery("<input type='text' value='TEST' />"); + elem = jQuery( "<input type='text' value='TEST' />" ); } - equal( elem[0].defaultValue, "TEST", "Ensure cached nodes are cloned properly (Bug #6655)" ); + equal( elem[ 0 ].defaultValue, "TEST", "Ensure cached nodes are cloned properly (Bug #6655)" ); elem = jQuery( "<input type='hidden'>", {} ); strictEqual( elem[ 0 ].ownerDocument, document, "Empty attributes object is not interpreted as a document (trac-8950)" ); -}); +} ); -test("jQuery(selector, context)", function() { - expect(3); - deepEqual( jQuery("div p", "#qunit-fixture").get(), q("sndp", "en", "sap"), "Basic selector with string as context" ); - deepEqual( jQuery("div p", q("qunit-fixture")[0]).get(), q("sndp", "en", "sap"), "Basic selector with element as context" ); - deepEqual( jQuery("div p", jQuery("#qunit-fixture")).get(), q("sndp", "en", "sap"), "Basic selector with jQuery object as context" ); -}); +test( "jQuery(selector, context)", function() { + expect( 3 ); + deepEqual( jQuery( "div p", "#qunit-fixture" ).get(), q( "sndp", "en", "sap" ), "Basic selector with string as context" ); + deepEqual( jQuery( "div p", q( "qunit-fixture" )[ 0 ] ).get(), q( "sndp", "en", "sap" ), "Basic selector with element as context" ); + deepEqual( jQuery( "div p", jQuery( "#qunit-fixture" ) ).get(), q( "sndp", "en", "sap" ), "Basic selector with jQuery object as context" ); +} ); test( "globalEval", function() { expect( 3 ); - Globals.register("globalEvalTest"); + Globals.register( "globalEvalTest" ); - jQuery.globalEval("globalEvalTest = 1;"); + jQuery.globalEval( "globalEvalTest = 1;" ); equal( window.globalEvalTest, 1, "Test variable assignments are global" ); - jQuery.globalEval("var globalEvalTest = 2;"); + jQuery.globalEval( "var globalEvalTest = 2;" ); equal( window.globalEvalTest, 2, "Test variable declarations are global" ); - jQuery.globalEval("this.globalEvalTest = 3;"); + jQuery.globalEval( "this.globalEvalTest = 3;" ); equal( window.globalEvalTest, 3, "Test context (this) is the window object" ); -}); +} ); test( "globalEval execution after script injection (#7862)", function() { expect( 1 ); @@ -177,41 +177,41 @@ test( "globalEval execution after script injection (#7862)", function() { now = jQuery.now(); document.body.appendChild( script ); - jQuery.globalEval( "var strictEvalTest = " + jQuery.now() + ";"); + jQuery.globalEval( "var strictEvalTest = " + jQuery.now() + ";" ); ok( window.strictEvalTest - now < 500, "Code executed synchronously" ); -}); +} ); // This is not run in AMD mode if ( jQuery.noConflict ) { - test("noConflict", function() { - expect(7); + test( "noConflict", function() { + expect( 7 ); var $$ = jQuery; strictEqual( jQuery, jQuery.noConflict(), "noConflict returned the jQuery object" ); - strictEqual( window["jQuery"], $$, "Make sure jQuery wasn't touched." ); - strictEqual( window["$"], original$, "Make sure $ was reverted." ); + strictEqual( window[ "jQuery" ], $$, "Make sure jQuery wasn't touched." ); + strictEqual( window[ "$" ], original$, "Make sure $ was reverted." ); jQuery = $ = $$; - strictEqual( jQuery.noConflict(true), $$, "noConflict returned the jQuery object" ); - strictEqual( window["jQuery"], originaljQuery, "Make sure jQuery was reverted." ); - strictEqual( window["$"], original$, "Make sure $ was reverted." ); - ok( $$().pushStack([]), "Make sure that jQuery still works." ); + strictEqual( jQuery.noConflict( true ), $$, "noConflict returned the jQuery object" ); + strictEqual( window[ "jQuery" ], originaljQuery, "Make sure jQuery was reverted." ); + strictEqual( window[ "$" ], original$, "Make sure $ was reverted." ); + ok( $$().pushStack( [] ), "Make sure that jQuery still works." ); - window["jQuery"] = jQuery = $$; - }); + window[ "jQuery" ] = jQuery = $$; + } ); } -test("trim", function() { - expect(13); +test( "trim", function() { + expect( 13 ); - var nbsp = String.fromCharCode(160); + var nbsp = String.fromCharCode( 160 ); - equal( jQuery.trim("hello "), "hello", "trailing space" ); - equal( jQuery.trim(" hello"), "hello", "leading space" ); - equal( jQuery.trim(" hello "), "hello", "space on both sides" ); - equal( jQuery.trim(" " + nbsp + "hello " + nbsp + " "), "hello", " " ); + equal( jQuery.trim( "hello " ), "hello", "trailing space" ); + equal( jQuery.trim( " hello" ), "hello", "leading space" ); + equal( jQuery.trim( " hello " ), "hello", "space on both sides" ); + equal( jQuery.trim( " " + nbsp + "hello " + nbsp + " " ), "hello", " " ); equal( jQuery.trim(), "", "Nothing in." ); equal( jQuery.trim( undefined ), "", "Undefined" ); @@ -219,85 +219,85 @@ test("trim", function() { equal( jQuery.trim( 5 ), "5", "Number" ); equal( jQuery.trim( false ), "false", "Boolean" ); - equal( jQuery.trim(" "), "", "space should be trimmed" ); - equal( jQuery.trim("ipad\xA0"), "ipad", "nbsp should be trimmed" ); - equal( jQuery.trim("\uFEFF"), "", "zwsp should be trimmed" ); - equal( jQuery.trim("\uFEFF \xA0! | \uFEFF"), "! |", "leading/trailing should be trimmed" ); -}); + equal( jQuery.trim( " " ), "", "space should be trimmed" ); + equal( jQuery.trim( "ipad\xA0" ), "ipad", "nbsp should be trimmed" ); + equal( jQuery.trim( "\uFEFF" ), "", "zwsp should be trimmed" ); + equal( jQuery.trim( "\uFEFF \xA0! | \uFEFF" ), "! |", "leading/trailing should be trimmed" ); +} ); -test("type", function() { +test( "type", function() { expect( 28 ); - equal( jQuery.type(null), "null", "null" ); - equal( jQuery.type(undefined), "undefined", "undefined" ); - equal( jQuery.type(true), "boolean", "Boolean" ); - equal( jQuery.type(false), "boolean", "Boolean" ); - equal( jQuery.type(Boolean(true)), "boolean", "Boolean" ); - equal( jQuery.type(0), "number", "Number" ); - equal( jQuery.type(1), "number", "Number" ); - equal( jQuery.type(Number(1)), "number", "Number" ); - equal( jQuery.type(""), "string", "String" ); - equal( jQuery.type("a"), "string", "String" ); - equal( jQuery.type(String("a")), "string", "String" ); - equal( jQuery.type({}), "object", "Object" ); - equal( jQuery.type(/foo/), "regexp", "RegExp" ); - equal( jQuery.type(new RegExp("asdf")), "regexp", "RegExp" ); - equal( jQuery.type([1]), "array", "Array" ); - equal( jQuery.type(new Date()), "date", "Date" ); - equal( jQuery.type(new Function("return;")), "function", "Function" ); - equal( jQuery.type(function(){}), "function", "Function" ); - equal( jQuery.type(new Error()), "error", "Error" ); - equal( jQuery.type(window), "object", "Window" ); - equal( jQuery.type(document), "object", "Document" ); - equal( jQuery.type(document.body), "object", "Element" ); - equal( jQuery.type(document.createTextNode("foo")), "object", "TextNode" ); - equal( jQuery.type(document.getElementsByTagName("*")), "object", "NodeList" ); + equal( jQuery.type( null ), "null", "null" ); + equal( jQuery.type( undefined ), "undefined", "undefined" ); + equal( jQuery.type( true ), "boolean", "Boolean" ); + equal( jQuery.type( false ), "boolean", "Boolean" ); + equal( jQuery.type( Boolean( true ) ), "boolean", "Boolean" ); + equal( jQuery.type( 0 ), "number", "Number" ); + equal( jQuery.type( 1 ), "number", "Number" ); + equal( jQuery.type( Number( 1 ) ), "number", "Number" ); + equal( jQuery.type( "" ), "string", "String" ); + equal( jQuery.type( "a" ), "string", "String" ); + equal( jQuery.type( String( "a" ) ), "string", "String" ); + equal( jQuery.type( {} ), "object", "Object" ); + equal( jQuery.type( /foo/ ), "regexp", "RegExp" ); + equal( jQuery.type( new RegExp( "asdf" ) ), "regexp", "RegExp" ); + equal( jQuery.type( [ 1 ] ), "array", "Array" ); + equal( jQuery.type( new Date() ), "date", "Date" ); + equal( jQuery.type( new Function( "return;" ) ), "function", "Function" ); + equal( jQuery.type( function() {} ), "function", "Function" ); + equal( jQuery.type( new Error() ), "error", "Error" ); + equal( jQuery.type( window ), "object", "Window" ); + equal( jQuery.type( document ), "object", "Document" ); + equal( jQuery.type( document.body ), "object", "Element" ); + equal( jQuery.type( document.createTextNode( "foo" ) ), "object", "TextNode" ); + equal( jQuery.type( document.getElementsByTagName( "*" ) ), "object", "NodeList" ); // Avoid Lint complaints var MyString = String, MyNumber = Number, MyBoolean = Boolean, MyObject = Object; - equal( jQuery.type(new MyBoolean(true)), "boolean", "Boolean" ); - equal( jQuery.type(new MyNumber(1)), "number", "Number" ); - equal( jQuery.type(new MyString("a")), "string", "String" ); - equal( jQuery.type(new MyObject()), "object", "Object" ); -}); + equal( jQuery.type( new MyBoolean( true ) ), "boolean", "Boolean" ); + equal( jQuery.type( new MyNumber( 1 ) ), "number", "Number" ); + equal( jQuery.type( new MyString( "a" ) ), "string", "String" ); + equal( jQuery.type( new MyObject() ), "object", "Object" ); +} ); -asyncTest("isPlainObject", function() { - expect(16); +asyncTest( "isPlainObject", function() { + expect( 16 ); var pass, iframe, doc, fn = function() {}; // The use case that we want to match - ok( jQuery.isPlainObject({}), "{}" ); + ok( jQuery.isPlainObject( {} ), "{}" ); // Not objects shouldn't be matched - ok( !jQuery.isPlainObject(""), "string" ); - ok( !jQuery.isPlainObject(0) && !jQuery.isPlainObject(1), "number" ); - ok( !jQuery.isPlainObject(true) && !jQuery.isPlainObject(false), "boolean" ); - ok( !jQuery.isPlainObject(null), "null" ); - ok( !jQuery.isPlainObject(undefined), "undefined" ); + ok( !jQuery.isPlainObject( "" ), "string" ); + ok( !jQuery.isPlainObject( 0 ) && !jQuery.isPlainObject( 1 ), "number" ); + ok( !jQuery.isPlainObject( true ) && !jQuery.isPlainObject( false ), "boolean" ); + ok( !jQuery.isPlainObject( null ), "null" ); + ok( !jQuery.isPlainObject( undefined ), "undefined" ); // Arrays shouldn't be matched - ok( !jQuery.isPlainObject([]), "array" ); + ok( !jQuery.isPlainObject( [] ), "array" ); // Instantiated objects shouldn't be matched - ok( !jQuery.isPlainObject(new Date()), "new Date" ); + ok( !jQuery.isPlainObject( new Date() ), "new Date" ); // Functions shouldn't be matched - ok( !jQuery.isPlainObject(fn), "fn" ); + ok( !jQuery.isPlainObject( fn ), "fn" ); // Again, instantiated objects shouldn't be matched - ok( !jQuery.isPlainObject(new fn()), "new fn (no methods)" ); + ok( !jQuery.isPlainObject( new fn() ), "new fn (no methods)" ); // Makes the function a little more realistic // (and harder to detect, incidentally) - fn.prototype["someMethod"] = function(){}; + fn.prototype[ "someMethod" ] = function() {}; // Again, instantiated objects shouldn't be matched - ok( !jQuery.isPlainObject(new fn()), "new fn" ); + ok( !jQuery.isPlainObject( new fn() ), "new fn" ); // Make it even harder to detect in IE < 9 fn = function() { @@ -307,10 +307,10 @@ asyncTest("isPlainObject", function() { b: "b" }; - ok( !jQuery.isPlainObject(new fn()), "fn (inherited and own properties)"); + ok( !jQuery.isPlainObject( new fn() ), "fn (inherited and own properties)" ); // DOM Element - ok( !jQuery.isPlainObject( document.createElement("div") ), "DOM Element" ); + ok( !jQuery.isPlainObject( document.createElement( "div" ) ), "DOM Element" ); // Window ok( !jQuery.isPlainObject( window ), "window" ); @@ -323,27 +323,27 @@ asyncTest("isPlainObject", function() { ok( pass, "Does not throw exceptions on host objects" ); // Objects from other windows should be matched - Globals.register("iframeDone"); + Globals.register( "iframeDone" ); window.iframeDone = function( otherObject, detail ) { window.iframeDone = undefined; iframe.parentNode.removeChild( iframe ); - ok( jQuery.isPlainObject(new otherObject()), "new otherObject" + ( detail ? " - " + detail : "" ) ); + ok( jQuery.isPlainObject( new otherObject() ), "new otherObject" + ( detail ? " - " + detail : "" ) ); start(); }; try { - iframe = jQuery("#qunit-fixture")[0].appendChild( document.createElement("iframe") ); + iframe = jQuery( "#qunit-fixture" )[ 0 ].appendChild( document.createElement( "iframe" ) ); doc = iframe.contentDocument || iframe.contentWindow.document; doc.open(); - doc.write("<body onload='window.parent.iframeDone(Object);'>"); + doc.write( "<body onload='window.parent.iframeDone(Object);'>" ); doc.close(); - } catch(e) { + } catch ( e ) { window.iframeDone( Object, "iframes not supported" ); } -}); +} ); -test("isFunction", function() { - expect(19); +test( "isFunction", function() { + expect( 19 ); var mystr, myarr, myfunction, fn, obj, nodes, first, input, a; @@ -356,31 +356,31 @@ test("isFunction", function() { // Check built-ins // Safari uses "(Internal Function)" - ok( jQuery.isFunction(String), "String Function("+String+")" ); - ok( jQuery.isFunction(Array), "Array Function("+Array+")" ); - ok( jQuery.isFunction(Object), "Object Function("+Object+")" ); - ok( jQuery.isFunction(Function), "Function Function("+Function+")" ); + ok( jQuery.isFunction( String ), "String Function(" + String + ")" ); + ok( jQuery.isFunction( Array ), "Array Function(" + Array + ")" ); + ok( jQuery.isFunction( Object ), "Object Function(" + Object + ")" ); + ok( jQuery.isFunction( Function ), "Function Function(" + Function + ")" ); // When stringified, this could be misinterpreted mystr = "function"; - ok( !jQuery.isFunction(mystr), "Function String" ); + ok( !jQuery.isFunction( mystr ), "Function String" ); // When stringified, this could be misinterpreted myarr = [ "function" ]; - ok( !jQuery.isFunction(myarr), "Function Array" ); + ok( !jQuery.isFunction( myarr ), "Function Array" ); // When stringified, this could be misinterpreted myfunction = { "function": "test" }; - ok( !jQuery.isFunction(myfunction), "Function Object" ); + ok( !jQuery.isFunction( myfunction ), "Function Object" ); // Make sure normal functions still work - fn = function(){}; - ok( jQuery.isFunction(fn), "Normal Function" ); + fn = function() {}; + ok( jQuery.isFunction( fn ), "Normal Function" ); - obj = document.createElement("object"); + obj = document.createElement( "object" ); // Firefox says this is a function - ok( !jQuery.isFunction(obj), "Object Element" ); + ok( !jQuery.isFunction( obj ), "Object Element" ); // IE says this is an object // Since 1.3, this isn't supported (#2968) @@ -389,14 +389,14 @@ test("isFunction", function() { nodes = document.body.childNodes; // Safari says this is a function - ok( !jQuery.isFunction(nodes), "childNodes Property" ); + ok( !jQuery.isFunction( nodes ), "childNodes Property" ); first = document.body.firstChild; // Normal elements are reported ok everywhere - ok( !jQuery.isFunction(first), "A normal DOM Element" ); + ok( !jQuery.isFunction( first ), "A normal DOM Element" ); - input = document.createElement("input"); + input = document.createElement( "input" ); input.type = "text"; document.body.appendChild( input ); @@ -406,30 +406,30 @@ test("isFunction", function() { document.body.removeChild( input ); - a = document.createElement("a"); + a = document.createElement( "a" ); a.href = "some-function"; document.body.appendChild( a ); // This serializes with the word 'function' in it - ok( !jQuery.isFunction(a), "Anchor Element" ); + ok( !jQuery.isFunction( a ), "Anchor Element" ); document.body.removeChild( a ); // Recursive function calls have lengths and array-like properties - function callme(callback){ - function fn(response){ - callback(response); + function callme( callback ) { + function fn( response ) { + callback( response ); } - ok( jQuery.isFunction(fn), "Recursive Function Call" ); + ok( jQuery.isFunction( fn ), "Recursive Function Call" ); - fn({ some: "data" }); + fn( { some: "data" } ); } - callme(function(){ - callme(function(){}); - }); -}); + callme( function() { + callme( function() {} ); + } ); +} ); test( "isNumeric", function() { expect( 38 ); @@ -478,345 +478,349 @@ test( "isNumeric", function() { equal( t( {} ), false, "Empty object" ); equal( t( [] ), false, "Empty array" ); equal( t( [ 42 ] ), false, "Array with one number" ); - equal( t( function(){} ), false, "Instance of a function" ); + equal( t( function() {} ), false, "Instance of a function" ); equal( t( new Date() ), false, "Instance of a Date" ); -}); +} ); -test("isXMLDoc - HTML", function() { - expect(4); +test( "isXMLDoc - HTML", function() { + expect( 4 ); ok( !jQuery.isXMLDoc( document ), "HTML document" ); ok( !jQuery.isXMLDoc( document.documentElement ), "HTML documentElement" ); ok( !jQuery.isXMLDoc( document.body ), "HTML Body Element" ); var body, - iframe = document.createElement("iframe"); + iframe = document.createElement( "iframe" ); document.body.appendChild( iframe ); try { - body = jQuery(iframe).contents()[0]; + body = jQuery( iframe ).contents()[ 0 ]; try { ok( !jQuery.isXMLDoc( body ), "Iframe body element" ); - } catch(e) { + } catch ( e ) { ok( false, "Iframe body element exception" ); } - } catch(e) { + } catch ( e ) { ok( true, "Iframe body element - iframe not working correctly" ); } document.body.removeChild( iframe ); -}); +} ); -test("XSS via location.hash", function() { - expect(1); +test( "XSS via location.hash", function() { + expect( 1 ); stop(); - jQuery["_check9521"] = function(x){ + jQuery[ "_check9521" ] = function( x ) { ok( x, "script called from #id-like selector with inline handler" ); - jQuery("#check9521").remove(); - delete jQuery["_check9521"]; + jQuery( "#check9521" ).remove(); + delete jQuery[ "_check9521" ]; start(); }; try { + // This throws an error because it's processed like an id - jQuery( "#<img id='check9521' src='no-such-.gif' onerror='jQuery._check9521(false)'>" ).appendTo("#qunit-fixture"); - } catch (err) { - jQuery["_check9521"](true); + jQuery( "#<img id='check9521' src='no-such-.gif' onerror='jQuery._check9521(false)'>" ).appendTo( "#qunit-fixture" ); + } catch ( err ) { + jQuery[ "_check9521" ]( true ); } -}); +} ); -test("isXMLDoc - XML", function() { - expect(3); +test( "isXMLDoc - XML", function() { + expect( 3 ); var xml = createDashboardXML(); ok( jQuery.isXMLDoc( xml ), "XML document" ); ok( jQuery.isXMLDoc( xml.documentElement ), "XML documentElement" ); - ok( jQuery.isXMLDoc( jQuery("tab", xml)[0] ), "XML Tab Element" ); -}); + ok( jQuery.isXMLDoc( jQuery( "tab", xml )[ 0 ] ), "XML Tab Element" ); +} ); -test("isWindow", function() { +test( "isWindow", function() { expect( 14 ); - ok( jQuery.isWindow(window), "window" ); - ok( jQuery.isWindow(document.getElementsByTagName("iframe")[0].contentWindow), "iframe.contentWindow" ); + ok( jQuery.isWindow( window ), "window" ); + ok( jQuery.isWindow( document.getElementsByTagName( "iframe" )[ 0 ].contentWindow ), "iframe.contentWindow" ); ok( !jQuery.isWindow(), "empty" ); - ok( !jQuery.isWindow(null), "null" ); - ok( !jQuery.isWindow(undefined), "undefined" ); - ok( !jQuery.isWindow(document), "document" ); - ok( !jQuery.isWindow(document.documentElement), "documentElement" ); - ok( !jQuery.isWindow(""), "string" ); - ok( !jQuery.isWindow(1), "number" ); - ok( !jQuery.isWindow(true), "boolean" ); - ok( !jQuery.isWindow({}), "object" ); - ok( !jQuery.isWindow({ setInterval: function(){} }), "fake window" ); - ok( !jQuery.isWindow(/window/), "regexp" ); - ok( !jQuery.isWindow(function(){}), "function" ); -}); - -test("jQuery('html')", function() { + ok( !jQuery.isWindow( null ), "null" ); + ok( !jQuery.isWindow( undefined ), "undefined" ); + ok( !jQuery.isWindow( document ), "document" ); + ok( !jQuery.isWindow( document.documentElement ), "documentElement" ); + ok( !jQuery.isWindow( "" ), "string" ); + ok( !jQuery.isWindow( 1 ), "number" ); + ok( !jQuery.isWindow( true ), "boolean" ); + ok( !jQuery.isWindow( {} ), "object" ); + ok( !jQuery.isWindow( { setInterval: function() {} } ), "fake window" ); + ok( !jQuery.isWindow( /window/ ), "regexp" ); + ok( !jQuery.isWindow( function() {} ), "function" ); +} ); + +test( "jQuery('html')", function() { expect( 18 ); var s, div, j; - jQuery["foo"] = false; - s = jQuery("<script>jQuery.foo='test';</script>")[0]; + jQuery[ "foo" ] = false; + s = jQuery( "<script>jQuery.foo='test';</script>" )[ 0 ]; ok( s, "Creating a script" ); - ok( !jQuery["foo"], "Make sure the script wasn't executed prematurely" ); - jQuery("body").append("<script>jQuery.foo='test';</script>"); - ok( jQuery["foo"], "Executing a scripts contents in the right context" ); + ok( !jQuery[ "foo" ], "Make sure the script wasn't executed prematurely" ); + jQuery( "body" ).append( "<script>jQuery.foo='test';</script>" ); + ok( jQuery[ "foo" ], "Executing a scripts contents in the right context" ); // Test multi-line HTML - div = jQuery("<div>\r\nsome text\n<p>some p</p>\nmore text\r\n</div>")[0]; + div = jQuery( "<div>\r\nsome text\n<p>some p</p>\nmore text\r\n</div>" )[ 0 ]; equal( div.nodeName.toUpperCase(), "DIV", "Make sure we're getting a div." ); equal( div.firstChild.nodeType, 3, "Text node." ); equal( div.lastChild.nodeType, 3, "Text node." ); - equal( div.childNodes[1].nodeType, 1, "Paragraph." ); - equal( div.childNodes[1].firstChild.nodeType, 3, "Paragraph text." ); + equal( div.childNodes[ 1 ].nodeType, 1, "Paragraph." ); + equal( div.childNodes[ 1 ].firstChild.nodeType, 3, "Paragraph text." ); - ok( jQuery("<link rel='stylesheet'/>")[0], "Creating a link" ); + ok( jQuery( "<link rel='stylesheet'/>" )[ 0 ], "Creating a link" ); - ok( !jQuery("<script/>")[0].parentNode, "Create a script" ); + ok( !jQuery( "<script/>" )[ 0 ].parentNode, "Create a script" ); - ok( jQuery("<input/>").attr("type", "hidden"), "Create an input and set the type." ); + ok( jQuery( "<input/>" ).attr( "type", "hidden" ), "Create an input and set the type." ); - j = jQuery("<span>hi</span> there <!-- mon ami -->"); + j = jQuery( "<span>hi</span> there <!-- mon ami -->" ); ok( j.length >= 2, "Check node,textnode,comment creation (some browsers delete comments)" ); - ok( !jQuery("<option>test</option>")[0].selected, "Make sure that options are auto-selected #2050" ); + ok( !jQuery( "<option>test</option>" )[ 0 ].selected, "Make sure that options are auto-selected #2050" ); - ok( jQuery("<div></div>")[0], "Create a div with closing tag." ); - ok( jQuery("<table></table>")[0], "Create a table with closing tag." ); + ok( jQuery( "<div></div>" )[ 0 ], "Create a div with closing tag." ); + ok( jQuery( "<table></table>" )[ 0 ], "Create a table with closing tag." ); equal( jQuery( "element[attribute='<div></div>']" ).length, 0, "When html is within brackets, do not recognize as html." ); + //equal( jQuery( "element[attribute=<div></div>]" ).length, 0, // "When html is within brackets, do not recognize as html." ); equal( jQuery( "element:not(<div></div>)" ).length, 0, "When html is within parens, do not recognize as html." ); equal( jQuery( "\\<div\\>" ).length, 0, "Ignore escaped html characters" ); -}); +} ); -test("jQuery(tag-hyphenated elements) gh-1987", function() { +test( "jQuery(tag-hyphenated elements) gh-1987", function() { expect( 17 ); - jQuery.each( "thead tbody tfoot colgroup caption tr th td".split(" "), function( i, name ) { - var j = jQuery("<" + name + "-d></" + name + "-d>"); - ok( j[0], "Create a tag-hyphenated elements" ); - ok( jQuery.nodeName(j[0], name.toUpperCase() + "-D"), "Tag-hyphenated element has expected node name" ); - }); + jQuery.each( "thead tbody tfoot colgroup caption tr th td".split( " " ), function( i, name ) { + var j = jQuery( "<" + name + "-d></" + name + "-d>" ); + ok( j[ 0 ], "Create a tag-hyphenated elements" ); + ok( jQuery.nodeName( j[ 0 ], name.toUpperCase() + "-D" ), "Tag-hyphenated element has expected node name" ); + } ); - var j = jQuery("<tr-multiple-hyphens></tr-multiple-hyphens>"); - ok( jQuery.nodeName(j[0], "TR-MULTIPLE-HYPHENS"), "Element with multiple hyphens in its tag has expected node name" ); -}); + var j = jQuery( "<tr-multiple-hyphens></tr-multiple-hyphens>" ); + ok( jQuery.nodeName( j[ 0 ], "TR-MULTIPLE-HYPHENS" ), "Element with multiple hyphens in its tag has expected node name" ); +} ); -test("jQuery('massive html #7990')", function() { +test( "jQuery('massive html #7990')", function() { expect( 3 ); var i, li = "<li>very very very very large html string</li>", - html = ["<ul>"]; + html = [ "<ul>" ]; for ( i = 0; i < 30000; i += 1 ) { - html[html.length] = li; + html[ html.length ] = li; } - html[html.length] = "</ul>"; - html = jQuery(html.join(""))[0]; - equal( html.nodeName.toLowerCase(), "ul"); - equal( html.firstChild.nodeName.toLowerCase(), "li"); + html[ html.length ] = "</ul>"; + html = jQuery( html.join( "" ) )[ 0 ]; + equal( html.nodeName.toLowerCase(), "ul" ); + equal( html.firstChild.nodeName.toLowerCase(), "li" ); equal( html.childNodes.length, 30000 ); -}); +} ); -test("jQuery('html', context)", function() { - expect(1); +test( "jQuery('html', context)", function() { + expect( 1 ); - var $div = jQuery("<div/>")[0], - $span = jQuery("<span/>", $div); - equal($span.length, 1, "verify a span created with a div context works, #1763"); -}); + var $div = jQuery( "<div/>" )[ 0 ], + $span = jQuery( "<span/>", $div ); + equal( $span.length, 1, "verify a span created with a div context works, #1763" ); +} ); -test("jQuery(selector, xml).text(str) - loaded via xml document", function() { - expect(2); +test( "jQuery(selector, xml).text(str) - loaded via xml document", function() { + expect( 2 ); var xml = createDashboardXML(), + // tests for #1419 where ie was a problem - tab = jQuery("tab", xml).eq(0); + tab = jQuery( "tab", xml ).eq( 0 ); equal( tab.text(), "blabla", "verify initial text correct" ); - tab.text("newtext"); + tab.text( "newtext" ); equal( tab.text(), "newtext", "verify new text correct" ); -}); +} ); -test("end()", function() { - expect(3); - equal( "Yahoo", jQuery("#yahoo").parent().end().text(), "check for end" ); - ok( jQuery("#yahoo").end(), "check for end with nothing to end" ); +test( "end()", function() { + expect( 3 ); + equal( "Yahoo", jQuery( "#yahoo" ).parent().end().text(), "check for end" ); + ok( jQuery( "#yahoo" ).end(), "check for end with nothing to end" ); - var x = jQuery("#yahoo"); + var x = jQuery( "#yahoo" ); x.parent(); - equal( "Yahoo", jQuery("#yahoo").text(), "check for non-destructive behaviour" ); -}); - -test("length", function() { - expect(1); - equal( jQuery("#qunit-fixture p").length, 6, "Get Number of Elements Found" ); -}); - -test("get()", function() { - expect(1); - deepEqual( jQuery("#qunit-fixture p").get(), q("firstp","ap","sndp","en","sap","first"), "Get All Elements" ); -}); - -test("toArray()", function() { - expect(1); - deepEqual( jQuery("#qunit-fixture p").toArray(), - q("firstp","ap","sndp","en","sap","first"), + equal( "Yahoo", jQuery( "#yahoo" ).text(), "check for non-destructive behaviour" ); +} ); + +test( "length", function() { + expect( 1 ); + equal( jQuery( "#qunit-fixture p" ).length, 6, "Get Number of Elements Found" ); +} ); + +test( "get()", function() { + expect( 1 ); + deepEqual( jQuery( "#qunit-fixture p" ).get(), q( "firstp", "ap", "sndp", "en", "sap", "first" ), "Get All Elements" ); +} ); + +test( "toArray()", function() { + expect( 1 ); + deepEqual( jQuery( "#qunit-fixture p" ).toArray(), + q( "firstp", "ap", "sndp", "en", "sap", "first" ), "Convert jQuery object to an Array" ); -}); +} ); -test("inArray()", function() { - expect(19); +test( "inArray()", function() { + expect( 19 ); var selections = { - p: q("firstp", "sap", "ap", "first"), - em: q("siblingnext", "siblingfirst"), - div: q("qunit-testrunner-toolbar", "nothiddendiv", "nothiddendivchild", "foo"), - a: q("mark", "groups", "google", "simon1"), + p: q( "firstp", "sap", "ap", "first" ), + em: q( "siblingnext", "siblingfirst" ), + div: q( "qunit-testrunner-toolbar", "nothiddendiv", "nothiddendivchild", "foo" ), + a: q( "mark", "groups", "google", "simon1" ), empty: [] }, tests = { - p: { elem: jQuery("#ap")[0], index: 2 }, - em: { elem: jQuery("#siblingfirst")[0], index: 1 }, - div: { elem: jQuery("#nothiddendiv")[0], index: 1 }, - a: { elem: jQuery("#simon1")[0], index: 3 } + p: { elem: jQuery( "#ap" )[ 0 ], index: 2 }, + em: { elem: jQuery( "#siblingfirst" )[ 0 ], index: 1 }, + div: { elem: jQuery( "#nothiddendiv" )[ 0 ], index: 1 }, + a: { elem: jQuery( "#simon1" )[ 0 ], index: 3 } }, falseTests = { - p: jQuery("#liveSpan1")[0], - em: jQuery("#nothiddendiv")[0], + p: jQuery( "#liveSpan1" )[ 0 ], + em: jQuery( "#nothiddendiv" )[ 0 ], empty: "" }; jQuery.each( tests, function( key, obj ) { equal( jQuery.inArray( obj.elem, selections[ key ] ), obj.index, "elem is in the array of selections of its tag" ); + // Third argument (fromIndex) equal( !!~jQuery.inArray( obj.elem, selections[ key ], 5 ), false, "elem is NOT in the array of selections given a starting index greater than its position" ); equal( !!~jQuery.inArray( obj.elem, selections[ key ], 1 ), true, "elem is in the array of selections given a starting index less than or equal to its position" ); equal( !!~jQuery.inArray( obj.elem, selections[ key ], -3 ), true, "elem is in the array of selections given a negative index" ); - }); + } ); jQuery.each( falseTests, function( key, elem ) { equal( !!~jQuery.inArray( elem, selections[ key ] ), false, "elem is NOT in the array of selections" ); - }); + } ); -}); +} ); -test("get(Number)", function() { - expect(2); - equal( jQuery("#qunit-fixture p").get(0), document.getElementById("firstp"), "Get A Single Element" ); - strictEqual( jQuery("#firstp").get(1), undefined, "Try get with index larger elements count" ); -}); +test( "get(Number)", function() { + expect( 2 ); + equal( jQuery( "#qunit-fixture p" ).get( 0 ), document.getElementById( "firstp" ), "Get A Single Element" ); + strictEqual( jQuery( "#firstp" ).get( 1 ), undefined, "Try get with index larger elements count" ); +} ); -test("get(-Number)",function() { - expect(2); - equal( jQuery("p").get(-1), document.getElementById("first"), "Get a single element with negative index" ); - strictEqual( jQuery("#firstp").get(-2), undefined, "Try get with index negative index larger then elements count" ); -}); +test( "get(-Number)", function() { + expect( 2 ); + equal( jQuery( "p" ).get( -1 ), document.getElementById( "first" ), "Get a single element with negative index" ); + strictEqual( jQuery( "#firstp" ).get( -2 ), undefined, "Try get with index negative index larger then elements count" ); +} ); -test("each(Function)", function() { - expect(1); +test( "each(Function)", function() { + expect( 1 ); var div, pass, i; - div = jQuery("div"); - div.each(function(){this.foo = "zoo";}); + div = jQuery( "div" ); + div.each( function() {this.foo = "zoo";} ); pass = true; for ( i = 0; i < div.length; i++ ) { - if ( div.get(i).foo !== "zoo" ) { + if ( div.get( i ).foo !== "zoo" ) { pass = false; } } ok( pass, "Execute a function, Relative" ); -}); +} ); -test("slice()", function() { - expect(7); +test( "slice()", function() { + expect( 7 ); - var $links = jQuery("#ap a"); + var $links = jQuery( "#ap a" ); - deepEqual( $links.slice(1,2).get(), q("groups"), "slice(1,2)" ); - deepEqual( $links.slice(1).get(), q("groups", "anchor1", "mark"), "slice(1)" ); - deepEqual( $links.slice(0,3).get(), q("google", "groups", "anchor1"), "slice(0,3)" ); - deepEqual( $links.slice(-1).get(), q("mark"), "slice(-1)" ); + deepEqual( $links.slice( 1, 2 ).get(), q( "groups" ), "slice(1,2)" ); + deepEqual( $links.slice( 1 ).get(), q( "groups", "anchor1", "mark" ), "slice(1)" ); + deepEqual( $links.slice( 0, 3 ).get(), q( "google", "groups", "anchor1" ), "slice(0,3)" ); + deepEqual( $links.slice( -1 ).get(), q( "mark" ), "slice(-1)" ); - deepEqual( $links.eq(1).get(), q("groups"), "eq(1)" ); - deepEqual( $links.eq("2").get(), q("anchor1"), "eq('2')" ); - deepEqual( $links.eq(-1).get(), q("mark"), "eq(-1)" ); -}); + deepEqual( $links.eq( 1 ).get(), q( "groups" ), "eq(1)" ); + deepEqual( $links.eq( "2" ).get(), q( "anchor1" ), "eq('2')" ); + deepEqual( $links.eq( -1 ).get(), q( "mark" ), "eq(-1)" ); +} ); -test("first()/last()", function() { - expect(4); +test( "first()/last()", function() { + expect( 4 ); - var $links = jQuery("#ap a"), $none = jQuery("asdf"); + var $links = jQuery( "#ap a" ), $none = jQuery( "asdf" ); - deepEqual( $links.first().get(), q("google"), "first()" ); - deepEqual( $links.last().get(), q("mark"), "last()" ); + deepEqual( $links.first().get(), q( "google" ), "first()" ); + deepEqual( $links.last().get(), q( "mark" ), "last()" ); deepEqual( $none.first().get(), [], "first() none" ); deepEqual( $none.last().get(), [], "last() none" ); -}); +} ); -test("map()", function() { +test( "map()", function() { expect( 2 ); deepEqual( - jQuery("#ap").map(function() { - return jQuery( this ).find("a").get(); - }).get(), + jQuery( "#ap" ).map( function() { + return jQuery( this ).find( "a" ).get(); + } ).get(), q( "google", "groups", "anchor1", "mark" ), "Array Map" ); deepEqual( - jQuery("#ap > a").map(function() { + jQuery( "#ap > a" ).map( function() { return this.parentNode; - }).get(), - q( "ap","ap","ap" ), + } ).get(), + q( "ap", "ap", "ap" ), "Single Map" ); -}); +} ); -test("jQuery.map", function() { +test( "jQuery.map", function() { expect( 25 ); var i, label, result, callback; result = jQuery.map( [ 3, 4, 5 ], function( v, k ) { return k; - }); - equal( result.join(""), "012", "Map the keys from an array" ); + } ); + equal( result.join( "" ), "012", "Map the keys from an array" ); result = jQuery.map( [ 3, 4, 5 ], function( v ) { return v; - }); - equal( result.join(""), "345", "Map the values from an array" ); + } ); + equal( result.join( "" ), "345", "Map the values from an array" ); result = jQuery.map( { a: 1, b: 2 }, function( v, k ) { return k; - }); - equal( result.join(""), "ab", "Map the keys from an object" ); + } ); + equal( result.join( "" ), "ab", "Map the keys from an object" ); result = jQuery.map( { a: 1, b: 2 }, function( v ) { return v; - }); - equal( result.join(""), "12", "Map the values from an object" ); + } ); + equal( result.join( "" ), "12", "Map the values from an object" ); result = jQuery.map( [ "a", undefined, null, "b" ], function( v ) { return v; - }); - equal( result.join(""), "ab", "Array iteration does not include undefined/null results" ); + } ); + equal( result.join( "" ), "ab", "Array iteration does not include undefined/null results" ); result = jQuery.map( { a: "a", b: undefined, c: null, d: "b" }, function( v ) { return v; - }); - equal( result.join(""), "ab", "Object iteration does not include undefined/null results" ); + } ); + equal( result.join( "" ), "ab", "Object iteration does not include undefined/null results" ); result = { Zero: function() {}, @@ -855,7 +859,7 @@ test("jQuery.map", function() { "sparse Array": Array( 4 ), "length: 1 plain object": { length: 1, "0": true }, "length: 2 plain object": { length: 2, "0": true, "1": true }, - NodeList: document.getElementsByTagName("html") + NodeList: document.getElementsByTagName( "html" ) }; callback = function( v, k ) { if ( result[ label ] ) { @@ -871,22 +875,22 @@ test("jQuery.map", function() { result = false; jQuery.map( { length: 0 }, function() { result = true; - }); + } ); ok( !result, "length: 0 plain object treated like array" ); result = false; - jQuery.map( document.getElementsByTagName("asdf"), function() { + jQuery.map( document.getElementsByTagName( "asdf" ), function() { result = true; - }); + } ); ok( !result, "empty NodeList treated like array" ); - result = jQuery.map( Array(4), function( v, k ){ - return k % 2 ? k : [k,k,k]; - }); - equal( result.join(""), "00012223", "Array results flattened (#2616)" ); -}); + result = jQuery.map( Array( 4 ), function( v, k ) { + return k % 2 ? k : [ k,k,k ]; + } ); + equal( result.join( "" ), "00012223", "Array results flattened (#2616)" ); +} ); -test("jQuery.merge()", function() { +test( "jQuery.merge()", function() { expect( 10 ); deepEqual( @@ -920,7 +924,7 @@ test("jQuery.merge()", function() { // Fixed at [5998], #3641 deepEqual( jQuery.merge( [ -2, -1 ], [ 0, 1, 2 ] ), - [ -2, -1 , 0, 1, 2 ], + [ -2, -1, 0, 1, 2 ], "Second array including a zero (falsy)" ); @@ -942,34 +946,34 @@ test("jQuery.merge()", function() { ); deepEqual( - jQuery.merge( [], document.getElementById("lengthtest").getElementsByTagName("input") ), - [ document.getElementById("length"), document.getElementById("idTest") ], + jQuery.merge( [], document.getElementById( "lengthtest" ).getElementsByTagName( "input" ) ), + [ document.getElementById( "length" ), document.getElementById( "idTest" ) ], "Second NodeList" ); -}); +} ); -test("jQuery.grep()", function() { - expect(8); +test( "jQuery.grep()", function() { + expect( 8 ); var searchCriterion = function( value ) { return value % 2 === 0; }; deepEqual( jQuery.grep( [], searchCriterion ), [], "Empty array" ); - deepEqual( jQuery.grep( new Array(4), searchCriterion ), [], "Sparse array" ); + deepEqual( jQuery.grep( new Array( 4 ), searchCriterion ), [], "Sparse array" ); deepEqual( jQuery.grep( [ 1, 2, 3, 4, 5, 6 ], searchCriterion ), [ 2, 4, 6 ], "Satisfying elements present" ); - deepEqual( jQuery.grep( [ 1, 3, 5, 7], searchCriterion ), [], "Satisfying elements absent" ); + deepEqual( jQuery.grep( [ 1, 3, 5, 7 ], searchCriterion ), [], "Satisfying elements absent" ); deepEqual( jQuery.grep( [ 1, 2, 3, 4, 5, 6 ], searchCriterion, true ), [ 1, 3, 5 ], "Satisfying elements present and grep inverted" ); - deepEqual( jQuery.grep( [ 1, 3, 5, 7], searchCriterion, true ), [1, 3, 5, 7], "Satisfying elements absent and grep inverted" ); + deepEqual( jQuery.grep( [ 1, 3, 5, 7 ], searchCriterion, true ), [ 1, 3, 5, 7 ], "Satisfying elements absent and grep inverted" ); deepEqual( jQuery.grep( [ 1, 2, 3, 4, 5, 6 ], searchCriterion, false ), [ 2, 4, 6 ], "Satisfying elements present but grep explicitly uninverted" ); deepEqual( jQuery.grep( [ 1, 3, 5, 7 ], searchCriterion, false ), [], "Satisfying elements absent and grep explicitly uninverted" ); -}); +} ); -test("jQuery.extend(Object, Object)", function() { - expect(28); +test( "jQuery.extend(Object, Object)", function() { + expect( 28 ); var empty, optionsWithLength, optionsWithDate, myKlass, customObject, optionsWithCustomObject, MyNumber, ret, @@ -983,87 +987,87 @@ test("jQuery.extend(Object, Object)", function() { deep2 = { "foo": { "baz": true }, "foo2": document }, deep2copy = { "foo": { "baz": true }, "foo2": document }, deepmerged = { "foo": { "bar": true, "baz": true }, "foo2": document }, - arr = [1, 2, 3], + arr = [ 1, 2, 3 ], nestedarray = { "arr": arr }; - jQuery.extend(settings, options); + jQuery.extend( settings, options ); deepEqual( settings, merged, "Check if extended: settings must be extended" ); deepEqual( options, optionsCopy, "Check if not modified: options must not be modified" ); - jQuery.extend(settings, null, options); + jQuery.extend( settings, null, options ); deepEqual( settings, merged, "Check if extended: settings must be extended" ); deepEqual( options, optionsCopy, "Check if not modified: options must not be modified" ); - jQuery.extend(true, deep1, deep2); - deepEqual( deep1["foo"], deepmerged["foo"], "Check if foo: settings must be extended" ); - deepEqual( deep2["foo"], deep2copy["foo"], "Check if not deep2: options must not be modified" ); - equal( deep1["foo2"], document, "Make sure that a deep clone was not attempted on the document" ); + jQuery.extend( true, deep1, deep2 ); + deepEqual( deep1[ "foo" ], deepmerged[ "foo" ], "Check if foo: settings must be extended" ); + deepEqual( deep2[ "foo" ], deep2copy[ "foo" ], "Check if not deep2: options must not be modified" ); + equal( deep1[ "foo2" ], document, "Make sure that a deep clone was not attempted on the document" ); - ok( jQuery.extend(true, {}, nestedarray)["arr"] !== arr, "Deep extend of object must clone child array" ); + ok( jQuery.extend( true, {}, nestedarray )[ "arr" ] !== arr, "Deep extend of object must clone child array" ); // #5991 - ok( jQuery.isArray( jQuery.extend(true, { "arr": {} }, nestedarray)["arr"] ), "Cloned array have to be an Array" ); - ok( jQuery.isPlainObject( jQuery.extend(true, { "arr": arr }, { "arr": {} })["arr"] ), "Cloned object have to be an plain object" ); + ok( jQuery.isArray( jQuery.extend( true, { "arr": {} }, nestedarray )[ "arr" ] ), "Cloned array have to be an Array" ); + ok( jQuery.isPlainObject( jQuery.extend( true, { "arr": arr }, { "arr": {} } )[ "arr" ] ), "Cloned object have to be an plain object" ); empty = {}; optionsWithLength = { "foo": { "length": -1 } }; - jQuery.extend(true, empty, optionsWithLength); - deepEqual( empty["foo"], optionsWithLength["foo"], "The length property must copy correctly" ); + jQuery.extend( true, empty, optionsWithLength ); + deepEqual( empty[ "foo" ], optionsWithLength[ "foo" ], "The length property must copy correctly" ); empty = {}; optionsWithDate = { "foo": { "date": new Date() } }; - jQuery.extend(true, empty, optionsWithDate); - deepEqual( empty["foo"], optionsWithDate["foo"], "Dates copy correctly" ); + jQuery.extend( true, empty, optionsWithDate ); + deepEqual( empty[ "foo" ], optionsWithDate[ "foo" ], "Dates copy correctly" ); /** @constructor */ myKlass = function() {}; customObject = new myKlass(); optionsWithCustomObject = { "foo": { "date": customObject } }; empty = {}; - jQuery.extend(true, empty, optionsWithCustomObject); - ok( empty["foo"] && empty["foo"]["date"] === customObject, "Custom objects copy correctly (no methods)" ); + jQuery.extend( true, empty, optionsWithCustomObject ); + ok( empty[ "foo" ] && empty[ "foo" ][ "date" ] === customObject, "Custom objects copy correctly (no methods)" ); // Makes the class a little more realistic - myKlass.prototype = { "someMethod": function(){} }; + myKlass.prototype = { "someMethod": function() {} }; empty = {}; - jQuery.extend(true, empty, optionsWithCustomObject); - ok( empty["foo"] && empty["foo"]["date"] === customObject, "Custom objects copy correctly" ); + jQuery.extend( true, empty, optionsWithCustomObject ); + ok( empty[ "foo" ] && empty[ "foo" ][ "date" ] === customObject, "Custom objects copy correctly" ); MyNumber = Number; - ret = jQuery.extend(true, { "foo": 4 }, { "foo": new MyNumber(5) } ); - ok( parseInt(ret.foo, 10) === 5, "Wrapped numbers copy correctly" ); + ret = jQuery.extend( true, { "foo": 4 }, { "foo": new MyNumber( 5 ) } ); + ok( parseInt( ret.foo, 10 ) === 5, "Wrapped numbers copy correctly" ); nullUndef; - nullUndef = jQuery.extend({}, options, { "xnumber2": null }); - ok( nullUndef["xnumber2"] === null, "Check to make sure null values are copied"); + nullUndef = jQuery.extend( {}, options, { "xnumber2": null } ); + ok( nullUndef[ "xnumber2" ] === null, "Check to make sure null values are copied" ); - nullUndef = jQuery.extend({}, options, { "xnumber2": undefined }); - ok( nullUndef["xnumber2"] === options["xnumber2"], "Check to make sure undefined values are not copied"); + nullUndef = jQuery.extend( {}, options, { "xnumber2": undefined } ); + ok( nullUndef[ "xnumber2" ] === options[ "xnumber2" ], "Check to make sure undefined values are not copied" ); - nullUndef = jQuery.extend({}, options, { "xnumber0": null }); - ok( nullUndef["xnumber0"] === null, "Check to make sure null values are inserted"); + nullUndef = jQuery.extend( {}, options, { "xnumber0": null } ); + ok( nullUndef[ "xnumber0" ] === null, "Check to make sure null values are inserted" ); target = {}; recursive = { foo:target, bar:5 }; - jQuery.extend(true, target, recursive); + jQuery.extend( true, target, recursive ); deepEqual( target, { bar:5 }, "Check to make sure a recursive obj doesn't go never-ending loop by not copying it over" ); - ret = jQuery.extend(true, { foo: [] }, { foo: [0] } ); // 1907 + ret = jQuery.extend( true, { foo: [] }, { foo: [ 0 ] } ); // 1907 equal( ret.foo.length, 1, "Check to make sure a value with coercion 'false' copies over when necessary to fix #1907" ); - ret = jQuery.extend(true, { foo: "1,2,3" }, { foo: [1, 2, 3] } ); + ret = jQuery.extend( true, { foo: "1,2,3" }, { foo: [ 1, 2, 3 ] } ); ok( typeof ret.foo !== "string", "Check to make sure values equal with coercion (but not actually equal) overwrite correctly" ); - ret = jQuery.extend(true, { foo:"bar" }, { foo:null } ); + ret = jQuery.extend( true, { foo:"bar" }, { foo:null } ); ok( typeof ret.foo !== "undefined", "Make sure a null value doesn't crash with deep extend, for #1908" ); obj = { foo:null }; - jQuery.extend(true, obj, { foo:"notnull" } ); + jQuery.extend( true, obj, { foo:"notnull" } ); equal( obj.foo, "notnull", "Make sure a null value can be overwritten" ); function func() {} - jQuery.extend(func, { key: "value" } ); + jQuery.extend( func, { key: "value" } ); equal( func.key, "value", "Verify a function can be extended" ); defaults = { xnumber1: 5, xnumber2: 7, xstring1: "peter", xstring2: "pan" }; @@ -1074,14 +1078,14 @@ test("jQuery.extend(Object, Object)", function() { options2Copy = { xstring2: "xx", xxx: "newstringx" }; merged2 = { xnumber1: 5, xnumber2: 1, xstring1: "peter", xstring2: "xx", xxx: "newstringx" }; - settings = jQuery.extend({}, defaults, options1, options2); + settings = jQuery.extend( {}, defaults, options1, options2 ); deepEqual( settings, merged2, "Check if extended: settings must be extended" ); deepEqual( defaults, defaultsCopy, "Check if not modified: options1 must not be modified" ); deepEqual( options1, options1Copy, "Check if not modified: options1 must not be modified" ); deepEqual( options2, options2Copy, "Check if not modified: options2 must not be modified" ); -}); +} ); -test("jQuery.each(Object,Function)", function() { +test( "jQuery.each(Object,Function)", function() { expect( 23 ); var i, label, seen, callback; @@ -1089,13 +1093,13 @@ test("jQuery.each(Object,Function)", function() { seen = {}; jQuery.each( [ 3, 4, 5 ], function( k, v ) { seen[ k ] = v; - }); + } ); deepEqual( seen, { "0": 3, "1": 4, "2": 5 }, "Array iteration" ); seen = {}; jQuery.each( { name: "name", lang: "lang" }, function( k, v ) { seen[ k ] = v; - }); + } ); deepEqual( seen, { name: "name", lang: "lang" }, "Object iteration" ); seen = []; @@ -1104,14 +1108,14 @@ test("jQuery.each(Object,Function)", function() { if ( k === 1 ) { return false; } - }); - deepEqual( seen, [ 1, 2 ] , "Broken array iteration" ); + } ); + deepEqual( seen, [ 1, 2 ], "Broken array iteration" ); seen = []; - jQuery.each( {"a": 1, "b": 2,"c": 3 }, function( k, v ) { + jQuery.each( { "a": 1, "b": 2,"c": 3 }, function( k, v ) { seen.push( v ); return false; - }); + } ); deepEqual( seen, [ 1 ], "Broken object iteration" ); seen = { @@ -1151,7 +1155,7 @@ test("jQuery.each(Object,Function)", function() { "sparse Array": Array( 4 ), "length: 1 plain object": { length: 1, "0": true }, "length: 2 plain object": { length: 2, "0": true, "1": true }, - NodeList: document.getElementsByTagName("html") + NodeList: document.getElementsByTagName( "html" ) }; callback = function( k ) { if ( seen[ label ] ) { @@ -1168,23 +1172,23 @@ test("jQuery.each(Object,Function)", function() { seen = false; jQuery.each( { length: 0 }, function() { seen = true; - }); + } ); ok( !seen, "length: 0 plain object treated like array" ); seen = false; - jQuery.each( document.getElementsByTagName("asdf"), function() { + jQuery.each( document.getElementsByTagName( "asdf" ), function() { seen = true; - }); + } ); ok( !seen, "empty NodeList treated like array" ); i = 0; jQuery.each( document.styleSheets, function() { i++; - }); + } ); equal( i, document.styleSheets.length, "Iteration over document.styleSheets" ); -}); +} ); -test("jQuery.each/map(undefined/null,Function)", function() { +test( "jQuery.each/map(undefined/null,Function)", function() { expect( 1 ); try { @@ -1196,7 +1200,7 @@ test("jQuery.each/map(undefined/null,Function)", function() { } catch ( e ) { ok( false, "each/map must accept null and undefined values" ); } -}); +} ); test( "JIT compilation does not interfere with length retrieval (gh-2145)", function() { expect( 4 ); @@ -1214,74 +1218,74 @@ test( "JIT compilation does not interfere with length retrieval (gh-2145)", func jQuery.each( { 1: "1", 2: "2", 3: "3" }, function( index ) { equal( ++i, index, "Iteration over object with solely " + "numeric indices (gh-2145 JIT iOS 8 bug)" ); - }); + } ); equal( i, 3, "Iteration over object with solely " + "numeric indices (gh-2145 JIT iOS 8 bug)" ); -}); +} ); -test("jQuery.makeArray", function(){ - expect(15); +test( "jQuery.makeArray", function() { + expect( 15 ); - equal( jQuery.makeArray(jQuery("html>*"))[0].nodeName.toUpperCase(), "HEAD", "Pass makeArray a jQuery object" ); + equal( jQuery.makeArray( jQuery( "html>*" ) )[ 0 ].nodeName.toUpperCase(), "HEAD", "Pass makeArray a jQuery object" ); - equal( jQuery.makeArray(document.getElementsByName("PWD")).slice(0,1)[0].name, "PWD", "Pass makeArray a nodelist" ); + equal( jQuery.makeArray( document.getElementsByName( "PWD" ) ).slice( 0, 1 )[ 0 ].name, "PWD", "Pass makeArray a nodelist" ); - equal( (function() { return jQuery.makeArray(arguments); })(1,2).join(""), "12", "Pass makeArray an arguments array" ); + equal( ( function() { return jQuery.makeArray( arguments ); } )( 1, 2 ).join( "" ), "12", "Pass makeArray an arguments array" ); - equal( jQuery.makeArray([1,2,3]).join(""), "123", "Pass makeArray a real array" ); + equal( jQuery.makeArray( [ 1,2,3 ] ).join( "" ), "123", "Pass makeArray a real array" ); equal( jQuery.makeArray().length, 0, "Pass nothing to makeArray and expect an empty array" ); - equal( jQuery.makeArray( 0 )[0], 0 , "Pass makeArray a number" ); + equal( jQuery.makeArray( 0 )[ 0 ], 0, "Pass makeArray a number" ); - equal( jQuery.makeArray( "foo" )[0], "foo", "Pass makeArray a string" ); + equal( jQuery.makeArray( "foo" )[ 0 ], "foo", "Pass makeArray a string" ); - equal( jQuery.makeArray( true )[0].constructor, Boolean, "Pass makeArray a boolean" ); + equal( jQuery.makeArray( true )[ 0 ].constructor, Boolean, "Pass makeArray a boolean" ); - equal( jQuery.makeArray( document.createElement("div") )[0].nodeName.toUpperCase(), "DIV", "Pass makeArray a single node" ); + equal( jQuery.makeArray( document.createElement( "div" ) )[ 0 ].nodeName.toUpperCase(), "DIV", "Pass makeArray a single node" ); - equal( jQuery.makeArray( {length:2, 0:"a", 1:"b"} ).join(""), "ab", "Pass makeArray an array like map (with length)" ); + equal( jQuery.makeArray( { length:2, 0:"a", 1:"b" } ).join( "" ), "ab", "Pass makeArray an array like map (with length)" ); - ok( !!jQuery.makeArray( document.documentElement.childNodes ).slice(0,1)[0].nodeName, "Pass makeArray a childNodes array" ); + ok( !!jQuery.makeArray( document.documentElement.childNodes ).slice( 0, 1 )[ 0 ].nodeName, "Pass makeArray a childNodes array" ); // function, is tricky as it has length - equal( jQuery.makeArray( function(){ return 1;} )[0](), 1, "Pass makeArray a function" ); + equal( jQuery.makeArray( function() { return 1;} )[ 0 ](), 1, "Pass makeArray a function" ); //window, also has length - equal( jQuery.makeArray(window)[0], window, "Pass makeArray the window" ); + equal( jQuery.makeArray( window )[ 0 ], window, "Pass makeArray the window" ); - equal( jQuery.makeArray(/a/)[0].constructor, RegExp, "Pass makeArray a regex" ); + equal( jQuery.makeArray( /a/ )[ 0 ].constructor, RegExp, "Pass makeArray a regex" ); // Some nodes inherit traits of nodelists - ok( jQuery.makeArray(document.getElementById("form")).length >= 13, + ok( jQuery.makeArray( document.getElementById( "form" ) ).length >= 13, "Pass makeArray a form (treat as elements)" ); -}); +} ); -test("jQuery.inArray", function(){ - expect(3); +test( "jQuery.inArray", function() { + expect( 3 ); - equal( jQuery.inArray( 0, false ), -1 , "Search in 'false' as array returns -1 and doesn't throw exception" ); + equal( jQuery.inArray( 0, false ), -1, "Search in 'false' as array returns -1 and doesn't throw exception" ); - equal( jQuery.inArray( 0, null ), -1 , "Search in 'null' as array returns -1 and doesn't throw exception" ); + equal( jQuery.inArray( 0, null ), -1, "Search in 'null' as array returns -1 and doesn't throw exception" ); - equal( jQuery.inArray( 0, undefined ), -1 , "Search in 'undefined' as array returns -1 and doesn't throw exception" ); -}); + equal( jQuery.inArray( 0, undefined ), -1, "Search in 'undefined' as array returns -1 and doesn't throw exception" ); +} ); -test("jQuery.isEmptyObject", function(){ - expect(2); +test( "jQuery.isEmptyObject", function() { + expect( 2 ); - equal(true, jQuery.isEmptyObject({}), "isEmptyObject on empty object literal" ); - equal(false, jQuery.isEmptyObject({a:1}), "isEmptyObject on non-empty object literal" ); + equal( true, jQuery.isEmptyObject( {} ), "isEmptyObject on empty object literal" ); + equal( false, jQuery.isEmptyObject( { a:1 } ), "isEmptyObject on non-empty object literal" ); // What about this ? // equal(true, jQuery.isEmptyObject(null), "isEmptyObject on null" ); -}); +} ); -test("jQuery.proxy", function(){ +test( "jQuery.proxy", function() { expect( 9 ); var test2, test3, test4, fn, cb, - test = function(){ equal( this, thisObject, "Make sure that scope is set properly." ); }, + test = function() { equal( this, thisObject, "Make sure that scope is set properly." ); }, thisObject = { foo: "bar", method: test }; // Make sure normal works @@ -1297,15 +1301,15 @@ test("jQuery.proxy", function(){ equal( jQuery.proxy( null, thisObject ), undefined, "Make sure no function was returned." ); // Partial application - test2 = function( a ){ equal( a, "pre-applied", "Ensure arguments can be pre-applied." ); }; + test2 = function( a ) { equal( a, "pre-applied", "Ensure arguments can be pre-applied." ); }; jQuery.proxy( test2, null, "pre-applied" )(); // Partial application w/ normal arguments - test3 = function( a, b ){ equal( b, "normal", "Ensure arguments can be pre-applied and passed as usual." ); }; + test3 = function( a, b ) { equal( b, "normal", "Ensure arguments can be pre-applied and passed as usual." ); }; jQuery.proxy( test3, null, "pre-applied" )( "normal" ); // Test old syntax - test4 = { "meth": function( a ){ equal( a, "boom", "Ensure old syntax works." ); } }; + test4 = { "meth": function( a ) { equal( a, "boom", "Ensure old syntax works." ); } }; jQuery.proxy( test4, "meth" )( "boom" ); // jQuery 1.9 improved currying with `this` object @@ -1315,9 +1319,9 @@ test("jQuery.proxy", function(){ }; cb = jQuery.proxy( fn, null, "arg1", "arg2" ); cb.call( thisObject, "arg3" ); -}); +} ); -test("jQuery.parseHTML", function() { +test( "jQuery.parseHTML", function() { expect( 22 ); var html, nodes; @@ -1330,88 +1334,88 @@ test("jQuery.parseHTML", function() { deepEqual( jQuery.parseHTML( true ), [], "Boolean true" ); deepEqual( jQuery.parseHTML( 42 ), [], "Positive number" ); deepEqual( jQuery.parseHTML( "" ), [], "Empty string" ); - throws(function() { - jQuery.parseHTML( "<div></div>", document.getElementById("form") ); - }, "Passing an element as the context raises an exception (context should be a document)"); + throws( function() { + jQuery.parseHTML( "<div></div>", document.getElementById( "form" ) ); + }, "Passing an element as the context raises an exception (context should be a document)" ); - nodes = jQuery.parseHTML( jQuery("body")[0].innerHTML ); + nodes = jQuery.parseHTML( jQuery( "body" )[ 0 ].innerHTML ); ok( nodes.length > 4, "Parse a large html string" ); equal( jQuery.type( nodes ), "array", "parseHTML returns an array rather than a nodelist" ); html = "<script>undefined()</script>"; equal( jQuery.parseHTML( html ).length, 0, "Ignore scripts by default" ); - equal( jQuery.parseHTML( html, true )[0].nodeName.toLowerCase(), "script", "Preserve scripts when requested" ); + equal( jQuery.parseHTML( html, true )[ 0 ].nodeName.toLowerCase(), "script", "Preserve scripts when requested" ); html += "<div></div>"; - equal( jQuery.parseHTML( html )[0].nodeName.toLowerCase(), "div", "Preserve non-script nodes" ); - equal( jQuery.parseHTML( html, true )[0].nodeName.toLowerCase(), "script", "Preserve script position"); + equal( jQuery.parseHTML( html )[ 0 ].nodeName.toLowerCase(), "div", "Preserve non-script nodes" ); + equal( jQuery.parseHTML( html, true )[ 0 ].nodeName.toLowerCase(), "script", "Preserve script position" ); - equal( jQuery.parseHTML("text")[0].nodeType, 3, "Parsing text returns a text node" ); - equal( jQuery.parseHTML( "\t<div></div>" )[0].nodeValue, "\t", "Preserve leading whitespace" ); + equal( jQuery.parseHTML( "text" )[ 0 ].nodeType, 3, "Parsing text returns a text node" ); + equal( jQuery.parseHTML( "\t<div></div>" )[ 0 ].nodeValue, "\t", "Preserve leading whitespace" ); - equal( jQuery.parseHTML(" <div/> ")[0].nodeType, 3, "Leading spaces are treated as text nodes (#11290)" ); + equal( jQuery.parseHTML( " <div/> " )[ 0 ].nodeType, 3, "Leading spaces are treated as text nodes (#11290)" ); html = jQuery.parseHTML( "<div>test div</div>" ); equal( html[ 0 ].parentNode.nodeType, 11, "parentNode should be documentFragment" ); equal( html[ 0 ].innerHTML, "test div", "Content should be preserved" ); - equal( jQuery.parseHTML("<span><span>").length, 1, "Incorrect html-strings should not break anything" ); - equal( jQuery.parseHTML("<td><td>")[ 1 ].parentNode.nodeType, 11, "parentNode should be documentFragment" ); -}); + equal( jQuery.parseHTML( "<span><span>" ).length, 1, "Incorrect html-strings should not break anything" ); + equal( jQuery.parseHTML( "<td><td>" )[ 1 ].parentNode.nodeType, 11, "parentNode should be documentFragment" ); +} ); if ( jQuery.support.createHTMLDocument ) { - asyncTest("jQuery.parseHTML", function() { + asyncTest( "jQuery.parseHTML", function() { expect ( 1 ); - Globals.register("parseHTMLError"); + Globals.register( "parseHTMLError" ); - jQuery.globalEval("parseHTMLError = false;"); + jQuery.globalEval( "parseHTMLError = false;" ); jQuery.parseHTML( "<img src=x onerror='parseHTMLError = true'>" ); - window.setTimeout(function() { + window.setTimeout( function() { start(); equal( window.parseHTMLError, false, "onerror eventhandler has not been called." ); - }, 2000); - }); + }, 2000 ); + } ); } -test("jQuery.parseJSON", function() { +test( "jQuery.parseJSON", function() { expect( 20 ); strictEqual( jQuery.parseJSON( null ), null, "primitive null" ); - strictEqual( jQuery.parseJSON("0.88"), 0.88, "Number" ); + strictEqual( jQuery.parseJSON( "0.88" ), 0.88, "Number" ); strictEqual( - jQuery.parseJSON("\" \\\" \\\\ \\/ \\b \\f \\n \\r \\t \\u007E \\u263a \""), + jQuery.parseJSON( "\" \\\" \\\\ \\/ \\b \\f \\n \\r \\t \\u007E \\u263a \"" ), " \" \\ / \b \f \n \r \t ~ \u263A ", "String escapes" ); - deepEqual( jQuery.parseJSON("{}"), {}, "Empty object" ); - deepEqual( jQuery.parseJSON("{\"test\":1}"), { "test": 1 }, "Plain object" ); - deepEqual( jQuery.parseJSON("[0]"), [ 0 ], "Simple array" ); + deepEqual( jQuery.parseJSON( "{}" ), {}, "Empty object" ); + deepEqual( jQuery.parseJSON( "{\"test\":1}" ), { "test": 1 }, "Plain object" ); + deepEqual( jQuery.parseJSON( "[0]" ), [ 0 ], "Simple array" ); deepEqual( - jQuery.parseJSON("[ \"string\", -4.2, 2.7180e0, 3.14E-1, {}, [], true, false, null ]"), + jQuery.parseJSON( "[ \"string\", -4.2, 2.7180e0, 3.14E-1, {}, [], true, false, null ]" ), [ "string", -4.2, 2.718, 0.314, {}, [], true, false, null ], "Array of all data types" ); deepEqual( jQuery.parseJSON( "{ \"string\": \"\", \"number\": 4.2e+1, \"object\": {}," + - "\"array\": [[]], \"boolean\": [ true, false ], \"null\": null }"), - { string: "", number: 42, object: {}, array: [[]], "boolean": [ true, false ], "null": null }, + "\"array\": [[]], \"boolean\": [ true, false ], \"null\": null }" ), + { string: "", number: 42, object: {}, array: [ [] ], "boolean": [ true, false ], "null": null }, "Dictionary of all data types" ); - deepEqual( jQuery.parseJSON("\n{\"test\":1}\t"), { "test": 1 }, + deepEqual( jQuery.parseJSON( "\n{\"test\":1}\t" ), { "test": 1 }, "Leading and trailing whitespace are ignored" ); - throws(function() { + throws( function() { jQuery.parseJSON(); }, null, "Undefined raises an error" ); - throws(function() { + throws( function() { jQuery.parseJSON( "" ); }, null, "Empty string raises an error" ); - throws(function() { - jQuery.parseJSON("''"); + throws( function() { + jQuery.parseJSON( "''" ); }, null, "Single-quoted string raises an error" ); /* @@ -1431,38 +1435,38 @@ test("jQuery.parseJSON", function() { }, null, "Number with no integer component raises an error" ); */ - throws(function() { - var result = jQuery.parseJSON("0101"); + throws( function() { + var result = jQuery.parseJSON( "0101" ); // Support: IE9+ // Ensure base-10 interpretation on browsers that erroneously accept leading-zero numbers if ( result === 101 ) { - throw new Error("close enough"); + throw new Error( "close enough" ); } }, null, "Leading-zero number raises an error or is parsed as decimal" ); - throws(function() { - jQuery.parseJSON("{a:1}"); + throws( function() { + jQuery.parseJSON( "{a:1}" ); }, null, "Unquoted property raises an error" ); - throws(function() { - jQuery.parseJSON("{'a':1}"); + throws( function() { + jQuery.parseJSON( "{'a':1}" ); }, null, "Single-quoted property raises an error" ); - throws(function() { - jQuery.parseJSON("[,]"); + throws( function() { + jQuery.parseJSON( "[,]" ); }, null, "Array element elision raises an error" ); - throws(function() { - jQuery.parseJSON("{},[]"); + throws( function() { + jQuery.parseJSON( "{},[]" ); }, null, "Comma expression raises an error" ); - throws(function() { - jQuery.parseJSON("[]\n,{}"); + throws( function() { + jQuery.parseJSON( "[]\n,{}" ); }, null, "Newline-containing comma expression raises an error" ); - throws(function() { - jQuery.parseJSON("\"\"\n\"\""); + throws( function() { + jQuery.parseJSON( "\"\"\n\"\"" ); }, null, "Automatic semicolon insertion raises an error" ); - strictEqual( jQuery.parseJSON([ 0 ]), 0, "Input cast to string" ); -}); + strictEqual( jQuery.parseJSON( [ 0 ] ), 0, "Input cast to string" ); +} ); -test("jQuery.parseXML", function(){ +test( "jQuery.parseXML", function() { expect( 8 ); var xml, tmp; @@ -1473,13 +1477,13 @@ test("jQuery.parseXML", function(){ tmp = tmp.getElementsByTagName( "b" )[ 0 ]; ok( !!tmp, "<b> present in document" ); strictEqual( tmp.childNodes[ 0 ].nodeValue, "well-formed", "<b> text is as expected" ); - } catch (e) { + } catch ( e ) { strictEqual( e, undefined, "unexpected error" ); } try { xml = jQuery.parseXML( "<p>Not a <<b>well-formed</b> xml string</p>" ); ok( false, "invalid xml not detected" ); - } catch( e ) { + } catch ( e ) { strictEqual( e.message, "Invalid XML: <p>Not a <<b>well-formed</b> xml string</p>", "invalid xml detected" ); } try { @@ -1491,12 +1495,12 @@ test("jQuery.parseXML", function(){ strictEqual( xml, null, "null string => null document" ); xml = jQuery.parseXML( true ); strictEqual( xml, null, "non-string => null document" ); - } catch( e ) { + } catch ( e ) { ok( false, "empty input throws exception" ); } -}); +} ); -test("jQuery.camelCase()", function() { +test( "jQuery.camelCase()", function() { var tests = { "foo-bar": "fooBar", @@ -1508,19 +1512,19 @@ test("jQuery.camelCase()", function() { "-ms-take": "msTake" }; - expect(7); + expect( 7 ); jQuery.each( tests, function( key, val ) { equal( jQuery.camelCase( key ), val, "Converts: " + key + " => " + val ); - }); -}); + } ); +} ); testIframeWithCallback( "Conditional compilation compatibility (#13274)", "core/cc_on.html", function( cc_on, errors, $ ) { expect( 3 ); ok( true, "JScript conditional compilation " + ( cc_on ? "supported" : "not supported" ) ); deepEqual( errors, [], "No errors" ); ok( $(), "jQuery executes" ); -}); +} ); // iOS7 doesn't fire the load event if the long-loading iframe gets its source reset to about:blank. // This makes this test fail but it doesn't seem to cause any real-life problems so blacklisting @@ -1529,7 +1533,7 @@ if ( !/iphone os 7_/i.test( navigator.userAgent ) ) { testIframeWithCallback( "document ready when jQuery loaded asynchronously (#13655)", "core/dynamic_ready.html", function( ready ) { expect( 1 ); equal( true, ready, "document ready correctly fired when jQuery is loaded after DOMContentLoaded" ); - }); + } ); } testIframeWithCallback( "Tolerating alias-masked DOM properties (#14074)", "core/aliased.html", diff --git a/test/unit/css.js b/test/unit/css.js index b4ee1e403..ac569fdff 100644 --- a/test/unit/css.js +++ b/test/unit/css.js @@ -1,88 +1,88 @@ if ( jQuery.css ) { -module("css", { teardown: moduleTeardown }); +module( "css", { teardown: moduleTeardown } ); -test("css(String|Hash)", function() { +test( "css(String|Hash)", function() { expect( 43 ); - equal( jQuery("#qunit-fixture").css("display"), "block", "Check for css property \"display\"" ); + equal( jQuery( "#qunit-fixture" ).css( "display" ), "block", "Check for css property \"display\"" ); var $child, div, div2, width, height, child, prctval, checkval, old; - $child = jQuery("#nothiddendivchild").css({ "width": "20%", "height": "20%" }); - notEqual( $child.css("width"), "20px", "Retrieving a width percentage on the child of a hidden div returns percentage" ); - notEqual( $child.css("height"), "20px", "Retrieving a height percentage on the child of a hidden div returns percentage" ); + $child = jQuery( "#nothiddendivchild" ).css( { "width": "20%", "height": "20%" } ); + notEqual( $child.css( "width" ), "20px", "Retrieving a width percentage on the child of a hidden div returns percentage" ); + notEqual( $child.css( "height" ), "20px", "Retrieving a height percentage on the child of a hidden div returns percentage" ); div = jQuery( "<div/>" ); // These should be "auto" (or some better value) // temporarily provide "0px" for backwards compat - equal( div.css("width"), "0px", "Width on disconnected node." ); - equal( div.css("height"), "0px", "Height on disconnected node." ); + equal( div.css( "width" ), "0px", "Width on disconnected node." ); + equal( div.css( "height" ), "0px", "Height on disconnected node." ); - div.css({ "width": 4, "height": 4 }); + div.css( { "width": 4, "height": 4 } ); - equal( div.css("width"), "4px", "Width on disconnected node." ); - equal( div.css("height"), "4px", "Height on disconnected node." ); + equal( div.css( "width" ), "4px", "Width on disconnected node." ); + equal( div.css( "height" ), "4px", "Height on disconnected node." ); - div2 = jQuery( "<div style='display:none;'><input type='text' style='height:20px;'/><textarea style='height:20px;'/><div style='height:20px;'></div></div>").appendTo("body"); + div2 = jQuery( "<div style='display:none;'><input type='text' style='height:20px;'/><textarea style='height:20px;'/><div style='height:20px;'></div></div>" ).appendTo( "body" ); - equal( div2.find("input").css("height"), "20px", "Height on hidden input." ); - equal( div2.find("textarea").css("height"), "20px", "Height on hidden textarea." ); - equal( div2.find("div").css("height"), "20px", "Height on hidden div." ); + equal( div2.find( "input" ).css( "height" ), "20px", "Height on hidden input." ); + equal( div2.find( "textarea" ).css( "height" ), "20px", "Height on hidden textarea." ); + equal( div2.find( "div" ).css( "height" ), "20px", "Height on hidden div." ); div2.remove(); // handle negative numbers by setting to zero #11604 - jQuery("#nothiddendiv").css( {"width": 1, "height": 1} ); - - width = parseFloat(jQuery("#nothiddendiv").css("width")); - height = parseFloat(jQuery("#nothiddendiv").css("height")); - jQuery("#nothiddendiv").css({ "overflow":"hidden", "width": -1, "height": -1 }); - equal( parseFloat(jQuery("#nothiddendiv").css("width")), 0, "Test negative width set to 0"); - equal( parseFloat(jQuery("#nothiddendiv").css("height")), 0, "Test negative height set to 0"); - - equal( jQuery("<div style='display: none;'/>").css("display"), "none", "Styles on disconnected nodes"); - - jQuery("#floatTest").css({"float": "right"}); - equal( jQuery("#floatTest").css("float"), "right", "Modified CSS float using \"float\": Assert float is right"); - jQuery("#floatTest").css({"font-size": "30px"}); - equal( jQuery("#floatTest").css("font-size"), "30px", "Modified CSS font-size: Assert font-size is 30px"); - jQuery.each("0,0.25,0.5,0.75,1".split(","), function(i, n) { - jQuery("#foo").css({"opacity": n}); - - equal( jQuery("#foo").css("opacity"), parseFloat(n), "Assert opacity is " + parseFloat(n) + " as a String" ); - jQuery("#foo").css({"opacity": parseFloat(n)}); - equal( jQuery("#foo").css("opacity"), parseFloat(n), "Assert opacity is " + parseFloat(n) + " as a Number" ); - }); - jQuery("#foo").css({"opacity": ""}); - equal( jQuery("#foo").css("opacity"), "1", "Assert opacity is 1 when set to an empty String" ); - - equal( jQuery("#empty").css("opacity"), "0", "Assert opacity is accessible via filter property set in stylesheet in IE" ); - jQuery("#empty").css({ "opacity": "1" }); - equal( jQuery("#empty").css("opacity"), "1", "Assert opacity is taken from style attribute when set vs stylesheet in IE with filters" ); + jQuery( "#nothiddendiv" ).css( { "width": 1, "height": 1 } ); + + width = parseFloat( jQuery( "#nothiddendiv" ).css( "width" ) ); + height = parseFloat( jQuery( "#nothiddendiv" ).css( "height" ) ); + jQuery( "#nothiddendiv" ).css( { "overflow":"hidden", "width": -1, "height": -1 } ); + equal( parseFloat( jQuery( "#nothiddendiv" ).css( "width" ) ), 0, "Test negative width set to 0" ); + equal( parseFloat( jQuery( "#nothiddendiv" ).css( "height" ) ), 0, "Test negative height set to 0" ); + + equal( jQuery( "<div style='display: none;'/>" ).css( "display" ), "none", "Styles on disconnected nodes" ); + + jQuery( "#floatTest" ).css( { "float": "right" } ); + equal( jQuery( "#floatTest" ).css( "float" ), "right", "Modified CSS float using \"float\": Assert float is right" ); + jQuery( "#floatTest" ).css( { "font-size": "30px" } ); + equal( jQuery( "#floatTest" ).css( "font-size" ), "30px", "Modified CSS font-size: Assert font-size is 30px" ); + jQuery.each( "0,0.25,0.5,0.75,1".split( "," ), function( i, n ) { + jQuery( "#foo" ).css( { "opacity": n } ); + + equal( jQuery( "#foo" ).css( "opacity" ), parseFloat( n ), "Assert opacity is " + parseFloat( n ) + " as a String" ); + jQuery( "#foo" ).css( { "opacity": parseFloat( n ) } ); + equal( jQuery( "#foo" ).css( "opacity" ), parseFloat( n ), "Assert opacity is " + parseFloat( n ) + " as a Number" ); + } ); + jQuery( "#foo" ).css( { "opacity": "" } ); + equal( jQuery( "#foo" ).css( "opacity" ), "1", "Assert opacity is 1 when set to an empty String" ); + + equal( jQuery( "#empty" ).css( "opacity" ), "0", "Assert opacity is accessible via filter property set in stylesheet in IE" ); + jQuery( "#empty" ).css( { "opacity": "1" } ); + equal( jQuery( "#empty" ).css( "opacity" ), "1", "Assert opacity is taken from style attribute when set vs stylesheet in IE with filters" ); jQuery.support.opacity ? - ok(true, "Requires the same number of tests"): - ok( ~jQuery("#empty")[0].currentStyle.filter.indexOf("gradient"), "Assert setting opacity doesn't overwrite other filters of the stylesheet in IE" ); + ok( true, "Requires the same number of tests" ) : + ok( ~jQuery( "#empty" )[ 0 ].currentStyle.filter.indexOf( "gradient" ), "Assert setting opacity doesn't overwrite other filters of the stylesheet in IE" ); - div = jQuery("#nothiddendiv"); - child = jQuery("#nothiddendivchild"); + div = jQuery( "#nothiddendiv" ); + child = jQuery( "#nothiddendivchild" ); - equal( parseInt(div.css("fontSize"), 10), 16, "Verify fontSize px set." ); - equal( parseInt(div.css("font-size"), 10), 16, "Verify fontSize px set." ); - equal( parseInt(child.css("fontSize"), 10), 16, "Verify fontSize px set." ); - equal( parseInt(child.css("font-size"), 10), 16, "Verify fontSize px set." ); + equal( parseInt( div.css( "fontSize" ), 10 ), 16, "Verify fontSize px set." ); + equal( parseInt( div.css( "font-size" ), 10 ), 16, "Verify fontSize px set." ); + equal( parseInt( child.css( "fontSize" ), 10 ), 16, "Verify fontSize px set." ); + equal( parseInt( child.css( "font-size" ), 10 ), 16, "Verify fontSize px set." ); - child.css("height", "100%"); - equal( child[0].style.height, "100%", "Make sure the height is being set correctly." ); + child.css( "height", "100%" ); + equal( child[ 0 ].style.height, "100%", "Make sure the height is being set correctly." ); - child.attr("class", "em"); - equal( parseInt(child.css("fontSize"), 10), 32, "Verify fontSize em set." ); + child.attr( "class", "em" ); + equal( parseInt( child.css( "fontSize" ), 10 ), 32, "Verify fontSize em set." ); // Have to verify this as the result depends upon the browser's CSS // support for font-size percentages - child.attr("class", "prct"); - prctval = parseInt(child.css("fontSize"), 10); + child.attr( "class", "prct" ); + prctval = parseInt( child.css( "fontSize" ), 10 ); checkval = 0; if ( prctval === 16 || prctval === 24 ) { checkval = prctval; @@ -90,34 +90,34 @@ test("css(String|Hash)", function() { equal( prctval, checkval, "Verify fontSize % set." ); - equal( typeof child.css("width"), "string", "Make sure that a string width is returned from css('width')." ); + equal( typeof child.css( "width" ), "string", "Make sure that a string width is returned from css('width')." ); - old = child[0].style.height; + old = child[ 0 ].style.height; // Test NaN - child.css("height", parseFloat("zoo")); - equal( child[0].style.height, old, "Make sure height isn't changed on NaN." ); + child.css( "height", parseFloat( "zoo" ) ); + equal( child[ 0 ].style.height, old, "Make sure height isn't changed on NaN." ); // Test null - child.css("height", null); - equal( child[0].style.height, old, "Make sure height isn't changed on null." ); + child.css( "height", null ); + equal( child[ 0 ].style.height, old, "Make sure height isn't changed on null." ); - old = child[0].style.fontSize; + old = child[ 0 ].style.fontSize; // Test NaN - child.css("font-size", parseFloat("zoo")); - equal( child[0].style.fontSize, old, "Make sure font-size isn't changed on NaN." ); + child.css( "font-size", parseFloat( "zoo" ) ); + equal( child[ 0 ].style.fontSize, old, "Make sure font-size isn't changed on NaN." ); // Test null - child.css("font-size", null); - equal( child[0].style.fontSize, old, "Make sure font-size isn't changed on null." ); + child.css( "font-size", null ); + equal( child[ 0 ].style.fontSize, old, "Make sure font-size isn't changed on null." ); strictEqual( child.css( "x-fake" ), undefined, "Make sure undefined is returned from css(nonexistent)." ); - div = jQuery( "<div/>" ).css({ position: "absolute", "z-index": 1000 }).appendTo( "#qunit-fixture" ); + div = jQuery( "<div/>" ).css( { position: "absolute", "z-index": 1000 } ).appendTo( "#qunit-fixture" ); strictEqual( div.css( "z-index" ), "1000", "Make sure that a string z-index is returned from css('z-index') (#14432)." ); -}); +} ); test( "css(String) computed values", function() { expect( 3 ); @@ -129,97 +129,96 @@ test( "css(String) computed values", function() { strictEqual( div.css( "padding-left" ), "500px", "should get computed value for padding-left property" ); strictEqual( div.css( "width" ), "200px", "should get computed value for width property" ); strictEqual( div.css( "font-size" ), "32px", "should get computed value for font-size property" ); -}); - +} ); test( "css() explicit and relative values", function() { expect( 29 ); - var $elem = jQuery("#nothiddendiv"); + var $elem = jQuery( "#nothiddendiv" ); - $elem.css({ "width": 1, "height": 1, "paddingLeft": "1px", "opacity": 1 }); - equal( $elem.css("width"), "1px", "Initial css set or width/height works (hash)" ); - equal( $elem.css("paddingLeft"), "1px", "Initial css set of paddingLeft works (hash)" ); - equal( $elem.css("opacity"), "1", "Initial css set of opacity works (hash)" ); + $elem.css( { "width": 1, "height": 1, "paddingLeft": "1px", "opacity": 1 } ); + equal( $elem.css( "width" ), "1px", "Initial css set or width/height works (hash)" ); + equal( $elem.css( "paddingLeft" ), "1px", "Initial css set of paddingLeft works (hash)" ); + equal( $elem.css( "opacity" ), "1", "Initial css set of opacity works (hash)" ); - $elem.css({ width: "+=9" }); - equal( $elem.css("width"), "10px", "'+=9' on width (hash)" ); + $elem.css( { width: "+=9" } ); + equal( $elem.css( "width" ), "10px", "'+=9' on width (hash)" ); - $elem.css({ "width": "-=9" }); - equal( $elem.css("width"), "1px", "'-=9' on width (hash)" ); + $elem.css( { "width": "-=9" } ); + equal( $elem.css( "width" ), "1px", "'-=9' on width (hash)" ); - $elem.css({ "width": "+=9px" }); - equal( $elem.css("width"), "10px", "'+=9px' on width (hash)" ); + $elem.css( { "width": "+=9px" } ); + equal( $elem.css( "width" ), "10px", "'+=9px' on width (hash)" ); - $elem.css({ "width": "-=9px" }); - equal( $elem.css("width"), "1px", "'-=9px' on width (hash)" ); + $elem.css( { "width": "-=9px" } ); + equal( $elem.css( "width" ), "1px", "'-=9px' on width (hash)" ); $elem.css( "width", "+=9" ); - equal( $elem.css("width"), "10px", "'+=9' on width (params)" ); + equal( $elem.css( "width" ), "10px", "'+=9' on width (params)" ); $elem.css( "width", "-=9" ) ; - equal( $elem.css("width"), "1px", "'-=9' on width (params)" ); + equal( $elem.css( "width" ), "1px", "'-=9' on width (params)" ); $elem.css( "width", "+=9px" ); - equal( $elem.css("width"), "10px", "'+=9px' on width (params)" ); + equal( $elem.css( "width" ), "10px", "'+=9px' on width (params)" ); $elem.css( "width", "-=9px" ); - equal( $elem.css("width"), "1px", "'-=9px' on width (params)" ); + equal( $elem.css( "width" ), "1px", "'-=9px' on width (params)" ); $elem.css( "width", "-=-9px" ); - equal( $elem.css("width"), "10px", "'-=-9px' on width (params)" ); + equal( $elem.css( "width" ), "10px", "'-=-9px' on width (params)" ); $elem.css( "width", "+=-9px" ); - equal( $elem.css("width"), "1px", "'+=-9px' on width (params)" ); + equal( $elem.css( "width" ), "1px", "'+=-9px' on width (params)" ); - $elem.css({ "paddingLeft": "+=4" }); - equal( $elem.css("paddingLeft"), "5px", "'+=4' on paddingLeft (hash)" ); + $elem.css( { "paddingLeft": "+=4" } ); + equal( $elem.css( "paddingLeft" ), "5px", "'+=4' on paddingLeft (hash)" ); - $elem.css({ "paddingLeft": "-=4" }); - equal( $elem.css("paddingLeft"), "1px", "'-=4' on paddingLeft (hash)" ); + $elem.css( { "paddingLeft": "-=4" } ); + equal( $elem.css( "paddingLeft" ), "1px", "'-=4' on paddingLeft (hash)" ); - $elem.css({ "paddingLeft": "+=4px" }); - equal( $elem.css("paddingLeft"), "5px", "'+=4px' on paddingLeft (hash)" ); + $elem.css( { "paddingLeft": "+=4px" } ); + equal( $elem.css( "paddingLeft" ), "5px", "'+=4px' on paddingLeft (hash)" ); - $elem.css({ "paddingLeft": "-=4px" }); - equal( $elem.css("paddingLeft"), "1px", "'-=4px' on paddingLeft (hash)" ); + $elem.css( { "paddingLeft": "-=4px" } ); + equal( $elem.css( "paddingLeft" ), "1px", "'-=4px' on paddingLeft (hash)" ); - $elem.css({ "padding-left": "+=4" }); - equal( $elem.css("paddingLeft"), "5px", "'+=4' on padding-left (hash)" ); + $elem.css( { "padding-left": "+=4" } ); + equal( $elem.css( "paddingLeft" ), "5px", "'+=4' on padding-left (hash)" ); - $elem.css({ "padding-left": "-=4" }); - equal( $elem.css("paddingLeft"), "1px", "'-=4' on padding-left (hash)" ); + $elem.css( { "padding-left": "-=4" } ); + equal( $elem.css( "paddingLeft" ), "1px", "'-=4' on padding-left (hash)" ); - $elem.css({ "padding-left": "+=4px" }); - equal( $elem.css("paddingLeft"), "5px", "'+=4px' on padding-left (hash)" ); + $elem.css( { "padding-left": "+=4px" } ); + equal( $elem.css( "paddingLeft" ), "5px", "'+=4px' on padding-left (hash)" ); - $elem.css({ "padding-left": "-=4px" }); - equal( $elem.css("paddingLeft"), "1px", "'-=4px' on padding-left (hash)" ); + $elem.css( { "padding-left": "-=4px" } ); + equal( $elem.css( "paddingLeft" ), "1px", "'-=4px' on padding-left (hash)" ); $elem.css( "paddingLeft", "+=4" ); - equal( $elem.css("paddingLeft"), "5px", "'+=4' on paddingLeft (params)" ); + equal( $elem.css( "paddingLeft" ), "5px", "'+=4' on paddingLeft (params)" ); $elem.css( "paddingLeft", "-=4" ); - equal( $elem.css("paddingLeft"), "1px", "'-=4' on paddingLeft (params)" ); + equal( $elem.css( "paddingLeft" ), "1px", "'-=4' on paddingLeft (params)" ); $elem.css( "padding-left", "+=4px" ); - equal( $elem.css("paddingLeft"), "5px", "'+=4px' on padding-left (params)" ); + equal( $elem.css( "paddingLeft" ), "5px", "'+=4px' on padding-left (params)" ); $elem.css( "padding-left", "-=4px" ); - equal( $elem.css("paddingLeft"), "1px", "'-=4px' on padding-left (params)" ); + equal( $elem.css( "paddingLeft" ), "1px", "'-=4px' on padding-left (params)" ); - $elem.css({ "opacity": "-=0.5" }); - equal( $elem.css("opacity"), "0.5", "'-=0.5' on opacity (hash)" ); + $elem.css( { "opacity": "-=0.5" } ); + equal( $elem.css( "opacity" ), "0.5", "'-=0.5' on opacity (hash)" ); - $elem.css({ "opacity": "+=0.5" }); - equal( $elem.css("opacity"), "1", "'+=0.5' on opacity (hash)" ); + $elem.css( { "opacity": "+=0.5" } ); + equal( $elem.css( "opacity" ), "1", "'+=0.5' on opacity (hash)" ); $elem.css( "opacity", "-=0.5" ); - equal( $elem.css("opacity"), "0.5", "'-=0.5' on opacity (params)" ); + equal( $elem.css( "opacity" ), "0.5", "'-=0.5' on opacity (params)" ); $elem.css( "opacity", "+=0.5" ); - equal( $elem.css("opacity"), "1", "'+=0.5' on opacity (params)" ); -}); + equal( $elem.css( "opacity" ), "1", "'+=0.5' on opacity (params)" ); +} ); test( "css() non-px relative values (gh-1711)", function() { expect( 17 ); @@ -256,12 +255,12 @@ test( "css() non-px relative values (gh-1711)", function() { "pc": parseFloat( $child.css( prop, "100pc" ).css( prop ) ) / 100, "cm": parseFloat( $child.css( prop, "100cm" ).css( prop ) ) / 100, "mm": parseFloat( $child.css( prop, "100mm" ).css( prop ) ) / 100, - "%" : parseFloat( $child.css( prop, "100%" ).css( prop ) ) / 100 + "%": parseFloat( $child.css( prop, "100%" ).css( prop ) ) / 100 }; }; - jQuery( "#nothiddendiv" ).css({ height: 1, padding: 0, width: 400 }); - $child.css({ height: 1, padding: 0 }); + jQuery( "#nothiddendiv" ).css( { height: 1, padding: 0, width: 400 } ); + $child.css( { height: 1, padding: 0 } ); getUnits( "width" ); cssCurrent = parseFloat( $child.css( "width", "50%" ).css( "width" ) ); @@ -285,44 +284,44 @@ test( "css() non-px relative values (gh-1711)", function() { add( "lineHeight", 1, "cm" ); add( "lineHeight", -20, "mm" ); add( "lineHeight", 50, "%" ); -}); +} ); -test("css(String, Object)", function() { +test( "css(String, Object)", function() { expect( 19 ); var j, div, display, ret, success; - jQuery("#floatTest").css("float", "left"); - equal( jQuery("#floatTest").css("float"), "left", "Modified CSS float using \"float\": Assert float is left"); - jQuery("#floatTest").css("font-size", "20px"); - equal( jQuery("#floatTest").css("font-size"), "20px", "Modified CSS font-size: Assert font-size is 20px"); + jQuery( "#floatTest" ).css( "float", "left" ); + equal( jQuery( "#floatTest" ).css( "float" ), "left", "Modified CSS float using \"float\": Assert float is left" ); + jQuery( "#floatTest" ).css( "font-size", "20px" ); + equal( jQuery( "#floatTest" ).css( "font-size" ), "20px", "Modified CSS font-size: Assert font-size is 20px" ); - jQuery.each("0,0.25,0.5,0.75,1".split(","), function(i, n) { - jQuery("#foo").css("opacity", n); - equal( jQuery("#foo").css("opacity"), parseFloat(n), "Assert opacity is " + parseFloat(n) + " as a String" ); - jQuery("#foo").css("opacity", parseFloat(n)); - equal( jQuery("#foo").css("opacity"), parseFloat(n), "Assert opacity is " + parseFloat(n) + " as a Number" ); - }); - jQuery("#foo").css("opacity", ""); - equal( jQuery("#foo").css("opacity"), "1", "Assert opacity is 1 when set to an empty String" ); + jQuery.each( "0,0.25,0.5,0.75,1".split( "," ), function( i, n ) { + jQuery( "#foo" ).css( "opacity", n ); + equal( jQuery( "#foo" ).css( "opacity" ), parseFloat( n ), "Assert opacity is " + parseFloat( n ) + " as a String" ); + jQuery( "#foo" ).css( "opacity", parseFloat( n ) ); + equal( jQuery( "#foo" ).css( "opacity" ), parseFloat( n ), "Assert opacity is " + parseFloat( n ) + " as a Number" ); + } ); + jQuery( "#foo" ).css( "opacity", "" ); + equal( jQuery( "#foo" ).css( "opacity" ), "1", "Assert opacity is 1 when set to an empty String" ); // using contents will get comments regular, text, and comment nodes - j = jQuery("#nonnodes").contents(); - j.css("overflow", "visible"); - equal( j.css("overflow"), "visible", "Check node,textnode,comment css works" ); - equal( jQuery("#t2037 .hidden").css("display"), "none", "Make sure browser thinks it is hidden" ); + j = jQuery( "#nonnodes" ).contents(); + j.css( "overflow", "visible" ); + equal( j.css( "overflow" ), "visible", "Check node,textnode,comment css works" ); + equal( jQuery( "#t2037 .hidden" ).css( "display" ), "none", "Make sure browser thinks it is hidden" ); - div = jQuery("#nothiddendiv"); - display = div.css("display"); - ret = div.css("display", undefined); + div = jQuery( "#nothiddendiv" ); + display = div.css( "display" ); + ret = div.css( "display", undefined ); equal( ret, div, "Make sure setting undefined returns the original set." ); - equal( div.css("display"), display, "Make sure that the display wasn't changed." ); + equal( div.css( "display" ), display, "Make sure that the display wasn't changed." ); success = true; try { jQuery( "#foo" ).css( "backgroundColor", "rgba(0, 0, 0, 0.1)" ); } - catch (e) { + catch ( e ) { success = false; } ok( success, "Setting RGBA values does not throw Error (#5509)" ); @@ -330,7 +329,7 @@ test("css(String, Object)", function() { jQuery( "#foo" ).css( "font", "7px/21px sans-serif" ); strictEqual( jQuery( "#foo" ).css( "line-height" ), "21px", "Set font shorthand property (#14759)" ); -}); +} ); test( "css(String, Object) with negative values", function() { expect( 4 ); @@ -345,7 +344,7 @@ test( "css(String, Object) with negative values", function() { jQuery( "#nothiddendiv" ).css( "left", "-20px" ); equal( jQuery( "#nothiddendiv" ).css( "top" ), "-20px", "Ensure negative top values work." ); equal( jQuery( "#nothiddendiv" ).css( "left" ), "-20px", "Ensure negative left values work." ); -}); +} ); test( "css(Array)", function() { expect( 2 ); @@ -357,30 +356,31 @@ test( "css(Array)", function() { expectedSingle = { "width": "16px" }, - elem = jQuery("<div></div>").appendTo("#qunit-fixture"); + elem = jQuery( "<div></div>" ).appendTo( "#qunit-fixture" ); - deepEqual( elem.css( expectedMany ).css([ "overflow", "width" ]), expectedMany, "Getting multiple element array" ); - deepEqual( elem.css( expectedSingle ).css([ "width" ]), expectedSingle, "Getting single element array" ); -}); + deepEqual( elem.css( expectedMany ).css( [ "overflow", "width" ] ), expectedMany, "Getting multiple element array" ); + deepEqual( elem.css( expectedSingle ).css( [ "width" ] ), expectedSingle, "Getting single element array" ); +} ); if ( !jQuery.support.opacity ) { - test("css(String, Object) for MSIE", function() { + test( "css(String, Object) for MSIE", function() { expect( 5 ); + // for #1438, IE throws JS error when filter exists but doesn't have opacity in it - jQuery("#foo").css("filter", "progid:DXImageTransform.Microsoft.Chroma(color='red');"); - equal( jQuery("#foo").css("opacity"), "1", "Assert opacity is 1 when a different filter is set in IE, #1438" ); + jQuery( "#foo" ).css( "filter", "progid:DXImageTransform.Microsoft.Chroma(color='red');" ); + equal( jQuery( "#foo" ).css( "opacity" ), "1", "Assert opacity is 1 when a different filter is set in IE, #1438" ); var filterVal = "progid:DXImageTransform.Microsoft.Alpha(opacity=30) progid:DXImageTransform.Microsoft.Blur(pixelradius=5)", filterVal2 = "progid:DXImageTransform.Microsoft.alpha(opacity=100) progid:DXImageTransform.Microsoft.Blur(pixelradius=5)", filterVal3 = "progid:DXImageTransform.Microsoft.Blur(pixelradius=5)"; - jQuery("#foo").css("filter", filterVal); - equal( jQuery("#foo").css("filter"), filterVal, "css('filter', val) works" ); - jQuery("#foo").css("opacity", 1); - equal( jQuery("#foo").css("filter"), filterVal2, "Setting opacity in IE doesn't duplicate opacity filter" ); - equal( jQuery("#foo").css("opacity"), 1, "Setting opacity in IE with other filters works" ); - jQuery("#foo").css("filter", filterVal3).css("opacity", 1); - ok( jQuery("#foo").css("filter").indexOf(filterVal3) !== -1, "Setting opacity in IE doesn't clobber other filters" ); - }); + jQuery( "#foo" ).css( "filter", filterVal ); + equal( jQuery( "#foo" ).css( "filter" ), filterVal, "css('filter', val) works" ); + jQuery( "#foo" ).css( "opacity", 1 ); + equal( jQuery( "#foo" ).css( "filter" ), filterVal2, "Setting opacity in IE doesn't duplicate opacity filter" ); + equal( jQuery( "#foo" ).css( "opacity" ), 1, "Setting opacity in IE with other filters works" ); + jQuery( "#foo" ).css( "filter", filterVal3 ).css( "opacity", 1 ); + ok( jQuery( "#foo" ).css( "filter" ).indexOf( filterVal3 ) !== -1, "Setting opacity in IE doesn't clobber other filters" ); + } ); test( "Setting opacity to 1 properly removes filter: style (#6652)", function() { var rfilter = /filter:[^;]*/i, @@ -388,180 +388,180 @@ if ( !jQuery.support.opacity ) { test2 = test.find( "div" ).css( "opacity", 1 ); function hasFilter( elem ) { - return !!rfilter.exec( elem[0].style.cssText ); + return !!rfilter.exec( elem[ 0 ].style.cssText ); } expect( 2 ); ok( !hasFilter( test ), "Removed filter attribute on element without filter in stylesheet" ); ok( hasFilter( test2 ), "Filter attribute remains on element that had filter in stylesheet" ); - }); + } ); } -test("css(String, Function)", function() { - expect(3); +test( "css(String, Function)", function() { + expect( 3 ); var index, - sizes = ["10px", "20px", "30px"]; + sizes = [ "10px", "20px", "30px" ]; - jQuery("<div id='cssFunctionTest'><div class='cssFunction'></div>" + + jQuery( "<div id='cssFunctionTest'><div class='cssFunction'></div>" + "<div class='cssFunction'></div>" + - "<div class='cssFunction'></div></div>") - .appendTo("body"); + "<div class='cssFunction'></div></div>" ) + .appendTo( "body" ); index = 0; - jQuery("#cssFunctionTest div").css("font-size", function() { - var size = sizes[index]; + jQuery( "#cssFunctionTest div" ).css( "font-size", function() { + var size = sizes[ index ]; index++; return size; - }); + } ); index = 0; - jQuery("#cssFunctionTest div").each(function() { - var computedSize = jQuery(this).css("font-size"), - expectedSize = sizes[index]; + jQuery( "#cssFunctionTest div" ).each( function() { + var computedSize = jQuery( this ).css( "font-size" ), + expectedSize = sizes[ index ]; equal( computedSize, expectedSize, "Div #" + index + " should be " + expectedSize ); index++; - }); + } ); - jQuery("#cssFunctionTest").remove(); -}); + jQuery( "#cssFunctionTest" ).remove(); +} ); -test("css(String, Function) with incoming value", function() { - expect(3); +test( "css(String, Function) with incoming value", function() { + expect( 3 ); var index, - sizes = ["10px", "20px", "30px"]; + sizes = [ "10px", "20px", "30px" ]; - jQuery("<div id='cssFunctionTest'><div class='cssFunction'></div>" + + jQuery( "<div id='cssFunctionTest'><div class='cssFunction'></div>" + "<div class='cssFunction'></div>" + - "<div class='cssFunction'></div></div>") - .appendTo("body"); + "<div class='cssFunction'></div></div>" ) + .appendTo( "body" ); index = 0; - jQuery("#cssFunctionTest div").css("font-size", function() { - var size = sizes[index]; + jQuery( "#cssFunctionTest div" ).css( "font-size", function() { + var size = sizes[ index ]; index++; return size; - }); + } ); index = 0; - jQuery("#cssFunctionTest div").css("font-size", function(i, computedSize) { - var expectedSize = sizes[index]; + jQuery( "#cssFunctionTest div" ).css( "font-size", function( i, computedSize ) { + var expectedSize = sizes[ index ]; equal( computedSize, expectedSize, "Div #" + index + " should be " + expectedSize ); index++; return computedSize; - }); + } ); - jQuery("#cssFunctionTest").remove(); -}); + jQuery( "#cssFunctionTest" ).remove(); +} ); -test("css(Object) where values are Functions", function() { - expect(3); +test( "css(Object) where values are Functions", function() { + expect( 3 ); var index, - sizes = ["10px", "20px", "30px"]; + sizes = [ "10px", "20px", "30px" ]; - jQuery("<div id='cssFunctionTest'><div class='cssFunction'></div>" + + jQuery( "<div id='cssFunctionTest'><div class='cssFunction'></div>" + "<div class='cssFunction'></div>" + - "<div class='cssFunction'></div></div>") - .appendTo("body"); + "<div class='cssFunction'></div></div>" ) + .appendTo( "body" ); index = 0; - jQuery("#cssFunctionTest div").css({"fontSize": function() { - var size = sizes[index]; + jQuery( "#cssFunctionTest div" ).css( { "fontSize": function() { + var size = sizes[ index ]; index++; return size; - }}); + } } ); index = 0; - jQuery("#cssFunctionTest div").each(function() { - var computedSize = jQuery(this).css("font-size"), - expectedSize = sizes[index]; + jQuery( "#cssFunctionTest div" ).each( function() { + var computedSize = jQuery( this ).css( "font-size" ), + expectedSize = sizes[ index ]; equal( computedSize, expectedSize, "Div #" + index + " should be " + expectedSize ); index++; - }); + } ); - jQuery("#cssFunctionTest").remove(); -}); + jQuery( "#cssFunctionTest" ).remove(); +} ); -test("css(Object) where values are Functions with incoming values", function() { - expect(3); +test( "css(Object) where values are Functions with incoming values", function() { + expect( 3 ); var index, - sizes = ["10px", "20px", "30px"]; + sizes = [ "10px", "20px", "30px" ]; - jQuery("<div id='cssFunctionTest'><div class='cssFunction'></div>" + + jQuery( "<div id='cssFunctionTest'><div class='cssFunction'></div>" + "<div class='cssFunction'></div>" + - "<div class='cssFunction'></div></div>") - .appendTo("body"); + "<div class='cssFunction'></div></div>" ) + .appendTo( "body" ); index = 0; - jQuery("#cssFunctionTest div").css({"fontSize": function() { - var size = sizes[index]; + jQuery( "#cssFunctionTest div" ).css( { "fontSize": function() { + var size = sizes[ index ]; index++; return size; - }}); + } } ); index = 0; - jQuery("#cssFunctionTest div").css({"font-size": function(i, computedSize) { - var expectedSize = sizes[index]; + jQuery( "#cssFunctionTest div" ).css( { "font-size": function( i, computedSize ) { + var expectedSize = sizes[ index ]; equal( computedSize, expectedSize, "Div #" + index + " should be " + expectedSize ); index++; return computedSize; - }}); + } } ); - jQuery("#cssFunctionTest").remove(); -}); + jQuery( "#cssFunctionTest" ).remove(); +} ); -test("show(); hide()", function() { +test( "show(); hide()", function() { expect( 4 ); var hiddendiv, div; - hiddendiv = jQuery("div.hidden"); + hiddendiv = jQuery( "div.hidden" ); hiddendiv.hide(); - equal( hiddendiv.css("display"), "none", "Cascade-hidden div after hide()" ); + equal( hiddendiv.css( "display" ), "none", "Cascade-hidden div after hide()" ); hiddendiv.show(); - equal( hiddendiv.css("display"), "none", "Show does not trump CSS cascade" ); + equal( hiddendiv.css( "display" ), "none", "Show does not trump CSS cascade" ); - div = jQuery("<div>").hide(); - equal( div.css("display"), "none", "Detached div hidden" ); - div.appendTo("#qunit-fixture").show(); - equal( div.css("display"), "block", "Initially-detached div after show()" ); + div = jQuery( "<div>" ).hide(); + equal( div.css( "display" ), "none", "Detached div hidden" ); + div.appendTo( "#qunit-fixture" ).show(); + equal( div.css( "display" ), "block", "Initially-detached div after show()" ); -}); +} ); -test("show();", function() { +test( "show();", function() { expect( 18 ); var hiddendiv, div, pass, test; - hiddendiv = jQuery("div.hidden"); + hiddendiv = jQuery( "div.hidden" ); - equal(jQuery.css( hiddendiv[0], "display"), "none", "hiddendiv is display: none"); + equal( jQuery.css( hiddendiv[ 0 ], "display" ), "none", "hiddendiv is display: none" ); - hiddendiv.css("display", "block"); - equal(jQuery.css( hiddendiv[0], "display"), "block", "hiddendiv is display: block"); + hiddendiv.css( "display", "block" ); + equal( jQuery.css( hiddendiv[ 0 ], "display" ), "block", "hiddendiv is display: block" ); hiddendiv.show(); - equal(jQuery.css( hiddendiv[0], "display"), "block", "hiddendiv is display: block"); + equal( jQuery.css( hiddendiv[ 0 ], "display" ), "block", "hiddendiv is display: block" ); - hiddendiv.css("display",""); + hiddendiv.css( "display", "" ); pass = true; - div = jQuery("#qunit-fixture div"); - div.show().each(function(){ + div = jQuery( "#qunit-fixture div" ); + div.show().each( function() { if ( this.style.display === "none" ) { pass = false; } - }); + } ); ok( pass, "Show" ); jQuery( @@ -572,137 +572,137 @@ test("show();", function() { "<table id='test-table'></table>" ).appendTo( "#qunit-fixture" ).find( "*" ).css( "display", "none" ); - jQuery("#test-table").remove(); + jQuery( "#test-table" ).remove(); test = { - "div" : "block", - "p" : "block", - "a" : "inline", - "code" : "inline", - "pre" : "block", - "span" : "inline", - "table" : "table", - "thead" : "table-header-group", - "tbody" : "table-row-group", - "tr" : "table-row", - "th" : "table-cell", - "td" : "table-cell", - "ul" : "block", - "li" : "list-item" + "div": "block", + "p": "block", + "a": "inline", + "code": "inline", + "pre": "block", + "span": "inline", + "table": "table", + "thead": "table-header-group", + "tbody": "table-row-group", + "tr": "table-row", + "th": "table-cell", + "td": "table-cell", + "ul": "block", + "li": "list-item" }; - jQuery.each(test, function(selector, expected) { - var elem = jQuery(selector, "#show-tests").show(); - equal( elem.css("display"), expected, "Show using correct display type for " + selector ); - }); + jQuery.each( test, function( selector, expected ) { + var elem = jQuery( selector, "#show-tests" ).show(); + equal( elem.css( "display" ), expected, "Show using correct display type for " + selector ); + } ); // Make sure that showing or hiding a text node doesn't cause an error - jQuery("<div>test</div> text <span>test</span>").show().remove(); - jQuery("<div>test</div> text <span>test</span>").hide().remove(); -}); + jQuery( "<div>test</div> text <span>test</span>" ).show().remove(); + jQuery( "<div>test</div> text <span>test</span>" ).hide().remove(); +} ); -test( "show() resolves correct default display for detached nodes", function(){ +test( "show() resolves correct default display for detached nodes", function() { expect( 16 ); var div, span, tr; - div = jQuery("<div class='hidden'>"); - div.show().appendTo("#qunit-fixture"); - equal( div.css("display"), "none", + div = jQuery( "<div class='hidden'>" ); + div.show().appendTo( "#qunit-fixture" ); + equal( div.css( "display" ), "none", "A shown-while-detached div can be hidden by the CSS cascade" ); - div = jQuery("<div><div class='hidden'></div></div>").children("div"); - div.show().appendTo("#qunit-fixture"); - equal( div.css("display"), "none", + div = jQuery( "<div><div class='hidden'></div></div>" ).children( "div" ); + div.show().appendTo( "#qunit-fixture" ); + equal( div.css( "display" ), "none", "A shown-while-detached div inside a visible div can be hidden by the CSS cascade" ); - span = jQuery("<span class='hidden'/>"); - span.show().appendTo("#qunit-fixture"); - equal( span.css("display"), "none", + span = jQuery( "<span class='hidden'/>" ); + span.show().appendTo( "#qunit-fixture" ); + equal( span.css( "display" ), "none", "A shown-while-detached span can be hidden by the CSS cascade" ); - div = jQuery("div.hidden"); + div = jQuery( "div.hidden" ); div.detach().show(); ok( !div[ 0 ].style.display, "show() does not update inline style of a cascade-hidden-before-detach div" ); - div.appendTo("#qunit-fixture"); - equal( div.css("display"), "none", + div.appendTo( "#qunit-fixture" ); + equal( div.css( "display" ), "none", "A shown-while-detached cascade-hidden div is hidden after attachment" ); div.remove(); - span = jQuery("<span class='hidden'/>"); - span.appendTo("#qunit-fixture").detach().show().appendTo("#qunit-fixture"); - equal( span.css("display"), "none", + span = jQuery( "<span class='hidden'/>" ); + span.appendTo( "#qunit-fixture" ).detach().show().appendTo( "#qunit-fixture" ); + equal( span.css( "display" ), "none", "A shown-while-detached cascade-hidden span is hidden after attachment" ); span.remove(); - div = jQuery( document.createElement("div") ); - div.show().appendTo("#qunit-fixture"); + div = jQuery( document.createElement( "div" ) ); + div.show().appendTo( "#qunit-fixture" ); ok( !div[ 0 ].style.display, "A shown-while-detached div has no inline style" ); - equal( div.css("display"), "block", + equal( div.css( "display" ), "block", "A shown-while-detached div has default display after attachment" ); div.remove(); - div = jQuery("<div style='display: none'>"); + div = jQuery( "<div style='display: none'>" ); div.show(); equal( div[ 0 ].style.display, "", "show() updates inline style of a detached inline-hidden div" ); - div.appendTo("#qunit-fixture"); - equal( div.css("display"), "block", + div.appendTo( "#qunit-fixture" ); + equal( div.css( "display" ), "block", "A shown-while-detached inline-hidden div has default display after attachment" ); - div = jQuery("<div><div style='display: none'></div></div>").children("div"); - div.show().appendTo("#qunit-fixture"); - equal( div.css("display"), "block", + div = jQuery( "<div><div style='display: none'></div></div>" ).children( "div" ); + div.show().appendTo( "#qunit-fixture" ); + equal( div.css( "display" ), "block", "A shown-while-detached inline-hidden div inside a visible div has default display " + "after attachment" ); - span = jQuery("<span style='display: none'/>"); + span = jQuery( "<span style='display: none'/>" ); span.show(); equal( span[ 0 ].style.display, "", "show() updates inline style of a detached inline-hidden span" ); - span.appendTo("#qunit-fixture"); - equal( span.css("display"), "inline", + span.appendTo( "#qunit-fixture" ); + equal( span.css( "display" ), "inline", "A shown-while-detached inline-hidden span has default display after attachment" ); - div = jQuery("<div style='display: inline'/>"); - div.show().appendTo("#qunit-fixture"); - equal( div.css("display"), "inline", + div = jQuery( "<div style='display: inline'/>" ); + div.show().appendTo( "#qunit-fixture" ); + equal( div.css( "display" ), "inline", "show() does not update inline style of a detached inline-visible div" ); div.remove(); - tr = jQuery("<tr/>"); - jQuery("#table").append( tr ); + tr = jQuery( "<tr/>" ); + jQuery( "#table" ).append( tr ); tr.detach().hide().show(); ok( !tr[ 0 ].style.display, "Not-hidden detached tr elements have no inline style" ); tr.remove(); - span = jQuery("<span/>").hide().show(); + span = jQuery( "<span/>" ).hide().show(); ok( !span[ 0 ].style.display, "Not-hidden detached span elements have no inline style" ); span.remove(); -}); +} ); -test("toggle()", function() { - expect(9); +test( "toggle()", function() { + expect( 9 ); var div, oldHide, - x = jQuery("#foo"); + x = jQuery( "#foo" ); - ok( x.is(":visible"), "is visible" ); + ok( x.is( ":visible" ), "is visible" ); x.toggle(); - ok( x.is(":hidden"), "is hidden" ); + ok( x.is( ":hidden" ), "is hidden" ); x.toggle(); - ok( x.is(":visible"), "is visible again" ); + ok( x.is( ":visible" ), "is visible again" ); - x.toggle(true); - ok( x.is(":visible"), "is visible" ); - x.toggle(false); - ok( x.is(":hidden"), "is hidden" ); - x.toggle(true); - ok( x.is(":visible"), "is visible again" ); + x.toggle( true ); + ok( x.is( ":visible" ), "is visible" ); + x.toggle( false ); + ok( x.is( ":hidden" ), "is hidden" ); + x.toggle( true ); + ok( x.is( ":visible" ), "is visible again" ); - div = jQuery("<div style='display:none'><div></div></div>").appendTo("#qunit-fixture"); - x = div.find("div"); + div = jQuery( "<div style='display:none'><div></div></div>" ).appendTo( "#qunit-fixture" ); + x = div.find( "div" ); strictEqual( x.toggle().css( "display" ), "none", "is hidden" ); strictEqual( x.toggle().css( "display" ), "block", "is visible" ); @@ -714,110 +714,110 @@ test("toggle()", function() { }; x.toggle( name === "show" ); jQuery.fn.hide = oldHide; -}); +} ); -test("hide hidden elements (bug #7141)", function() { - expect(3); +test( "hide hidden elements (bug #7141)", function() { + expect( 3 ); - var div = jQuery("<div style='display:none'></div>").appendTo("#qunit-fixture"); - equal( div.css("display"), "none", "Element is hidden by default" ); + var div = jQuery( "<div style='display:none'></div>" ).appendTo( "#qunit-fixture" ); + equal( div.css( "display" ), "none", "Element is hidden by default" ); div.hide(); - ok( !jQuery._data(div, "display"), "display data is undefined after hiding an already-hidden element" ); + ok( !jQuery._data( div, "display" ), "display data is undefined after hiding an already-hidden element" ); div.show(); - equal( div.css("display"), "block", "Show a double-hidden element" ); + equal( div.css( "display" ), "block", "Show a double-hidden element" ); div.remove(); -}); +} ); -test("jQuery.css(elem, 'height') doesn't clear radio buttons (bug #1095)", function () { - expect(4); +test( "jQuery.css(elem, 'height') doesn't clear radio buttons (bug #1095)", function() { + expect( 4 ); - var $checkedtest = jQuery("#checkedtest"); - jQuery.css($checkedtest[0], "height"); + var $checkedtest = jQuery( "#checkedtest" ); + jQuery.css( $checkedtest[ 0 ], "height" ); - ok( jQuery("input[type='radio']", $checkedtest).first().attr("checked"), "Check first radio still checked." ); - ok( !jQuery("input[type='radio']", $checkedtest).last().attr("checked"), "Check last radio still NOT checked." ); - ok( jQuery("input[type='checkbox']", $checkedtest).first().attr("checked"), "Check first checkbox still checked." ); - ok( !jQuery("input[type='checkbox']", $checkedtest).last().attr("checked"), "Check last checkbox still NOT checked." ); -}); + ok( jQuery( "input[type='radio']", $checkedtest ).first().attr( "checked" ), "Check first radio still checked." ); + ok( !jQuery( "input[type='radio']", $checkedtest ).last().attr( "checked" ), "Check last radio still NOT checked." ); + ok( jQuery( "input[type='checkbox']", $checkedtest ).first().attr( "checked" ), "Check first checkbox still checked." ); + ok( !jQuery( "input[type='checkbox']", $checkedtest ).last().attr( "checked" ), "Check last checkbox still NOT checked." ); +} ); -test("internal ref to elem.runtimeStyle (bug #7608)", function () { - expect(1); +test( "internal ref to elem.runtimeStyle (bug #7608)", function() { + expect( 1 ); var result = true; try { - jQuery("#foo").css( { "width": "0%" } ).css("width"); - } catch (e) { + jQuery( "#foo" ).css( { "width": "0%" } ).css( "width" ); + } catch ( e ) { result = false; } ok( result, "elem.runtimeStyle does not throw exception" ); -}); +} ); -test("marginRight computed style (bug #3333)", function() { - expect(1); +test( "marginRight computed style (bug #3333)", function() { + expect( 1 ); - var $div = jQuery("#foo"); - $div.css({ + var $div = jQuery( "#foo" ); + $div.css( { "width": "1px", "marginRight": 0 - }); + } ); - equal($div.css("marginRight"), "0px", "marginRight correctly calculated with a width and display block"); -}); + equal( $div.css( "marginRight" ), "0px", "marginRight correctly calculated with a width and display block" ); +} ); -test("box model properties incorrectly returning % instead of px, see #10639 and #12088", function() { +test( "box model properties incorrectly returning % instead of px, see #10639 and #12088", function() { expect( 2 ); - var container = jQuery("<div/>").width( 400 ).appendTo("#qunit-fixture"), - el = jQuery("<div/>").css({ "width": "50%", "marginRight": "50%" }).appendTo( container ), - el2 = jQuery("<div/>").css({ "width": "50%", "minWidth": "300px", "marginLeft": "25%" }).appendTo( container ); + var container = jQuery( "<div/>" ).width( 400 ).appendTo( "#qunit-fixture" ), + el = jQuery( "<div/>" ).css( { "width": "50%", "marginRight": "50%" } ).appendTo( container ), + el2 = jQuery( "<div/>" ).css( { "width": "50%", "minWidth": "300px", "marginLeft": "25%" } ).appendTo( container ); - equal( el.css("marginRight"), "200px", "css('marginRight') returning % instead of px, see #10639" ); - equal( el2.css("marginLeft"), "100px", "css('marginLeft') returning incorrect pixel value, see #12088" ); -}); + equal( el.css( "marginRight" ), "200px", "css('marginRight') returning % instead of px, see #10639" ); + equal( el2.css( "marginLeft" ), "100px", "css('marginLeft') returning incorrect pixel value, see #12088" ); +} ); -test("jQuery.cssProps behavior, (bug #8402)", function() { +test( "jQuery.cssProps behavior, (bug #8402)", function() { expect( 2 ); - var div = jQuery( "<div>" ).appendTo(document.body).css({ + var div = jQuery( "<div>" ).appendTo( document.body ).css( { "position": "absolute", "top": 0, "left": 10 - }); + } ); jQuery.cssProps.top = "left"; - equal( div.css("top"), "10px", "the fixed property is used when accessing the computed style"); - div.css("top", "100px"); - equal( div[0].style.left, "100px", "the fixed property is used when setting the style"); + equal( div.css( "top" ), "10px", "the fixed property is used when accessing the computed style" ); + div.css( "top", "100px" ); + equal( div[ 0 ].style.left, "100px", "the fixed property is used when setting the style" ); + // cleanup jQuery.cssProps jQuery.cssProps.top = undefined; -}); +} ); -test("widows & orphans #8936", function () { +test( "widows & orphans #8936", function() { - var $p = jQuery("<p>").appendTo("#qunit-fixture"); + var $p = jQuery( "<p>" ).appendTo( "#qunit-fixture" ); - if ( "widows" in $p[0].style ) { - expect(2); + if ( "widows" in $p[ 0 ].style ) { + expect( 2 ); - $p.css({ + $p.css( { "widows": 3, "orphans": 3 - }); + } ); - equal( $p.css("widows") || jQuery.style( $p[0], "widows" ), 3, "widows correctly set to 3"); - equal( $p.css("orphans") || jQuery.style( $p[0], "orphans" ), 3, "orphans correctly set to 3"); + equal( $p.css( "widows" ) || jQuery.style( $p[ 0 ], "widows" ), 3, "widows correctly set to 3" ); + equal( $p.css( "orphans" ) || jQuery.style( $p[ 0 ], "orphans" ), 3, "orphans correctly set to 3" ); } else { - expect(1); - ok( true, "jQuery does not attempt to test for style props that definitely don't exist in older versions of IE"); + expect( 1 ); + ok( true, "jQuery does not attempt to test for style props that definitely don't exist in older versions of IE" ); } - $p.remove(); -}); +} ); -test("can't get css for disconnected in IE<9, see #10254 and #8388", function() { +test( "can't get css for disconnected in IE<9, see #10254 and #8388", function() { expect( 2 ); var span, div; @@ -826,9 +826,9 @@ test("can't get css for disconnected in IE<9, see #10254 and #8388", function() div = jQuery( "<div/>" ).css( "top", 10 ); equal( div.css( "top" ), "10px", "can't get top in IE<9, see #8388" ); -}); +} ); -test("can't get background-position in IE<9, see #10796", function() { +test( "can't get background-position in IE<9, see #10796", function() { var div = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ), units = [ "0 0", @@ -845,62 +845,63 @@ test("can't get background-position in IE<9, see #10796", function() { expect( l ); - for( ; i < l; i++ ) { + for ( ; i < l; i++ ) { div.css( "background-position", units [ i ] ); ok( div.css( "background-position" ), "can't get background-position in IE<9, see #10796" ); } -}); +} ); -test("percentage properties for bottom and right in IE<9 should not be incorrectly transformed to pixels, see #11311", function() { +test( "percentage properties for bottom and right in IE<9 should not be incorrectly transformed to pixels, see #11311", function() { expect( 1 ); - var div = jQuery("<div style='position: absolute; width: 1px; height: 20px; bottom:50%;'></div>").appendTo( "#qunit-fixture" ); + var div = jQuery( "<div style='position: absolute; width: 1px; height: 20px; bottom:50%;'></div>" ).appendTo( "#qunit-fixture" ); ok( window.getComputedStyle || div.css( "bottom" ) === "50%", "position properties get incorrectly transformed in IE<8, see #11311" ); -}); +} ); if ( jQuery.fn.offset ) { - test("percentage properties for left and top should be transformed to pixels, see #9505", function() { + test( "percentage properties for left and top should be transformed to pixels, see #9505", function() { expect( 2 ); - var parent = jQuery("<div style='position:relative;width:200px;height:200px;margin:0;padding:0;border-width:0'></div>").appendTo( "#qunit-fixture" ), - div = jQuery("<div style='position: absolute; width: 20px; height: 20px; top:50%; left:50%'></div>").appendTo( parent ); + var parent = jQuery( "<div style='position:relative;width:200px;height:200px;margin:0;padding:0;border-width:0'></div>" ).appendTo( "#qunit-fixture" ), + div = jQuery( "<div style='position: absolute; width: 20px; height: 20px; top:50%; left:50%'></div>" ).appendTo( parent ); - equal( div.css("top"), "100px", "position properties not transformed to pixels, see #9505" ); - equal( div.css("left"), "100px", "position properties not transformed to pixels, see #9505" ); - }); + equal( div.css( "top" ), "100px", "position properties not transformed to pixels, see #9505" ); + equal( div.css( "left" ), "100px", "position properties not transformed to pixels, see #9505" ); + } ); } -test("Do not append px (#9548, #12990)", function() { +test( "Do not append px (#9548, #12990)", function() { expect( 2 ); - var $div = jQuery("<div>").appendTo("#qunit-fixture"); + var $div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ); $div.css( "fill-opacity", 1 ); + // Support: Android 2.3 (no support for fill-opacity) if ( $div.css( "fill-opacity" ) ) { - equal( $div.css("fill-opacity"), 1, "Do not append px to 'fill-opacity'" ); + equal( $div.css( "fill-opacity" ), 1, "Do not append px to 'fill-opacity'" ); } else { ok( true, "No support for fill-opacity CSS property" ); } $div.css( "column-count", 1 ); - if ( $div.css("column-count") ) { - equal( $div.css("column-count"), 1, "Do not append px to 'column-count'" ); + if ( $div.css( "column-count" ) ) { + equal( $div.css( "column-count" ), 1, "Do not append px to 'column-count'" ); } else { ok( true, "No support for column-count CSS property" ); } -}); +} ); -test("css('width') and css('height') should respect box-sizing, see #11004", function() { +test( "css('width') and css('height') should respect box-sizing, see #11004", function() { expect( 4 ); // Support: Android 2.3 (-webkit-box-sizing). - var el_dis = jQuery("<div style='width:300px;height:300px;margin:2px;padding:2px;-webkit-box-sizing:border-box;box-sizing:border-box;'>test</div>"), - el = el_dis.clone().appendTo("#qunit-fixture"); + var el_dis = jQuery( "<div style='width:300px;height:300px;margin:2px;padding:2px;-webkit-box-sizing:border-box;box-sizing:border-box;'>test</div>" ), + el = el_dis.clone().appendTo( "#qunit-fixture" ); - equal( el.css("width"), el.css("width", el.css("width")).css("width"), "css('width') is not respecting box-sizing, see #11004"); - equal( el_dis.css("width"), el_dis.css("width", el_dis.css("width")).css("width"), "css('width') is not respecting box-sizing for disconnected element, see #11004"); - equal( el.css("height"), el.css("height", el.css("height")).css("height"), "css('height') is not respecting box-sizing, see #11004"); - equal( el_dis.css("height"), el_dis.css("height", el_dis.css("height")).css("height"), "css('height') is not respecting box-sizing for disconnected element, see #11004"); -}); + equal( el.css( "width" ), el.css( "width", el.css( "width" ) ).css( "width" ), "css('width') is not respecting box-sizing, see #11004" ); + equal( el_dis.css( "width" ), el_dis.css( "width", el_dis.css( "width" ) ).css( "width" ), "css('width') is not respecting box-sizing for disconnected element, see #11004" ); + equal( el.css( "height" ), el.css( "height", el.css( "height" ) ).css( "height" ), "css('height') is not respecting box-sizing, see #11004" ); + equal( el_dis.css( "height" ), el_dis.css( "height", el_dis.css( "height" ) ).css( "height" ), "css('height') is not respecting box-sizing for disconnected element, see #11004" ); +} ); testIframeWithCallback( "css('width') should work correctly before document ready (#14084)", "css/cssWidthBeforeDocReady.html", @@ -917,7 +918,7 @@ testIframeWithCallback( "css('width') should work correctly before document read div.style.width = "3.3px"; qunitFixture.appendChild( div ); supportsFractionalGBCR = jQuery.support.gBCRDimensions() && - div.getBoundingClientRect().width.toFixed(1) === "3.3"; + div.getBoundingClientRect().width.toFixed( 1 ) === "3.3"; qunitFixture.removeChild( div ); test( "css('width') and css('height') should return fractional values for nodes in the document", function() { @@ -956,23 +957,23 @@ testIframeWithCallback( "css('width') should work correctly before document read } ); } )(); -test("certain css values of 'normal' should be convertable to a number, see #8627", function() { +test( "certain css values of 'normal' should be convertable to a number, see #8627", function() { expect ( 3 ); - var el = jQuery("<div style='letter-spacing:normal;font-weight:normal;'>test</div>").appendTo("#qunit-fixture"); + var el = jQuery( "<div style='letter-spacing:normal;font-weight:normal;'>test</div>" ).appendTo( "#qunit-fixture" ); - ok( jQuery.isNumeric( parseFloat( el.css("letterSpacing") ) ), "css('letterSpacing') not convertable to number, see #8627" ); - ok( jQuery.isNumeric( parseFloat( el.css("fontWeight") ) ), "css('fontWeight') not convertable to number, see #8627" ); + ok( jQuery.isNumeric( parseFloat( el.css( "letterSpacing" ) ) ), "css('letterSpacing') not convertable to number, see #8627" ); + ok( jQuery.isNumeric( parseFloat( el.css( "fontWeight" ) ) ), "css('fontWeight') not convertable to number, see #8627" ); equal( typeof el.css( "fontWeight" ), "string", ".css() returns a string" ); -}); +} ); // only run this test in IE9 if ( document.documentMode === 9 ) { test( ".css('filter') returns a string in IE9, see #12537", function() { expect( 1 ); - equal( jQuery("<div style='-ms-filter:\"progid:DXImageTransform.Microsoft.gradient(startColorstr=#FFFFFF, endColorstr=#ECECEC)\";'></div>").css("filter"), "progid:DXImageTransform.Microsoft.gradient(startColorstr=#FFFFFF, endColorstr=#ECECEC)", "IE9 returns the correct value from css('filter')." ); - }); + equal( jQuery( "<div style='-ms-filter:\"progid:DXImageTransform.Microsoft.gradient(startColorstr=#FFFFFF, endColorstr=#ECECEC)\";'></div>" ).css( "filter" ), "progid:DXImageTransform.Microsoft.gradient(startColorstr=#FFFFFF, endColorstr=#ECECEC)", "IE9 returns the correct value from css('filter')." ); + } ); } test( "cssHooks - expand", function() { @@ -980,7 +981,7 @@ test( "cssHooks - expand", function() { var result, properties = { margin: [ "marginTop", "marginRight", "marginBottom", "marginLeft" ], - borderWidth: [ "borderTopWidth", "borderRightWidth", "borderBottomWidth", "borderLeftWidth"], + borderWidth: [ "borderTopWidth", "borderRightWidth", "borderBottomWidth", "borderLeftWidth" ], padding: [ "paddingTop", "paddingRight", "paddingBottom", "paddingLeft" ] }; @@ -989,70 +990,70 @@ test( "cssHooks - expand", function() { expected = {}; jQuery.each( keys, function( _, key ) { expected[ key ] = 10; - }); + } ); result = hook.expand( 10 ); deepEqual( result, expected, property + " expands properly with a number" ); jQuery.each( keys, function( _, key ) { expected[ key ] = "10px"; - }); + } ); result = hook.expand( "10px" ); deepEqual( result, expected, property + " expands properly with '10px'" ); - expected[ keys[1] ] = expected[ keys[3] ] = "20px"; + expected[ keys[ 1 ] ] = expected[ keys[ 3 ] ] = "20px"; result = hook.expand( "10px 20px" ); deepEqual( result, expected, property + " expands properly with '10px 20px'" ); - expected[ keys[2] ] = "30px"; + expected[ keys[ 2 ] ] = "30px"; result = hook.expand( "10px 20px 30px" ); deepEqual( result, expected, property + " expands properly with '10px 20px 30px'" ); - expected[ keys[3] ] = "40px"; + expected[ keys[ 3 ] ] = "40px"; result = hook.expand( "10px 20px 30px 40px" ); deepEqual( result, expected, property + " expands properly with '10px 20px 30px 40px'" ); - }); + } ); -}); +} ); test( "css opacity consistency across browsers (#12685)", function() { expect( 4 ); var el, - fixture = jQuery("#qunit-fixture"); + fixture = jQuery( "#qunit-fixture" ); // Append style element - jQuery("<style>.opacityWithSpaces_t12685 { opacity: 0.1; -ms-filter: 'alpha(opacity = 10)'; } .opacityNoSpaces_t12685 { opacity: 0.2; -ms-filter: 'alpha(opacity=20)'; }</style>").appendTo( fixture ); + jQuery( "<style>.opacityWithSpaces_t12685 { opacity: 0.1; -ms-filter: 'alpha(opacity = 10)'; } .opacityNoSpaces_t12685 { opacity: 0.2; -ms-filter: 'alpha(opacity=20)'; }</style>" ).appendTo( fixture ); - el = jQuery("<div class='opacityWithSpaces_t12685'></div>").appendTo(fixture); + el = jQuery( "<div class='opacityWithSpaces_t12685'></div>" ).appendTo( fixture ); - equal( Math.round( el.css("opacity") * 100 ), 10, "opacity from style sheet (-ms-filter:alpha with spaces)" ); - el.removeClass("opacityWithSpaces_t12685").addClass("opacityNoSpaces_t12685"); - equal( Math.round( el.css("opacity") * 100 ), 20, "opacity from style sheet (-ms-filter:alpha without spaces)" ); + equal( Math.round( el.css( "opacity" ) * 100 ), 10, "opacity from style sheet (-ms-filter:alpha with spaces)" ); + el.removeClass( "opacityWithSpaces_t12685" ).addClass( "opacityNoSpaces_t12685" ); + equal( Math.round( el.css( "opacity" ) * 100 ), 20, "opacity from style sheet (-ms-filter:alpha without spaces)" ); el.css( "opacity", 0.3 ); - equal( Math.round( el.css("opacity") * 100 ), 30, "override opacity" ); + equal( Math.round( el.css( "opacity" ) * 100 ), 30, "override opacity" ); el.css( "opacity", "" ); - equal( Math.round( el.css("opacity") * 100 ), 20, "remove opacity override" ); -}); + equal( Math.round( el.css( "opacity" ) * 100 ), 20, "remove opacity override" ); +} ); test( ":visible/:hidden selectors", function() { expect( 17 ); var $div, $table, $a; - ok( jQuery("#nothiddendiv").is(":visible"), "Modifying CSS display: Assert element is visible" ); - jQuery("#nothiddendiv").css({ display: "none" }); - ok( !jQuery("#nothiddendiv").is(":visible"), "Modified CSS display: Assert element is hidden" ); - jQuery("#nothiddendiv").css({ "display": "block" }); - ok( jQuery("#nothiddendiv").is(":visible"), "Modified CSS display: Assert element is visible"); - ok( !jQuery(window).is(":visible"), "Calling is(':visible') on window does not throw an exception (#10267)."); - ok( !jQuery(document).is(":visible"), "Calling is(':visible') on document does not throw an exception (#10267)."); + ok( jQuery( "#nothiddendiv" ).is( ":visible" ), "Modifying CSS display: Assert element is visible" ); + jQuery( "#nothiddendiv" ).css( { display: "none" } ); + ok( !jQuery( "#nothiddendiv" ).is( ":visible" ), "Modified CSS display: Assert element is hidden" ); + jQuery( "#nothiddendiv" ).css( { "display": "block" } ); + ok( jQuery( "#nothiddendiv" ).is( ":visible" ), "Modified CSS display: Assert element is visible" ); + ok( !jQuery( window ).is( ":visible" ), "Calling is(':visible') on window does not throw an exception (#10267)." ); + ok( !jQuery( document ).is( ":visible" ), "Calling is(':visible') on document does not throw an exception (#10267)." ); - ok( jQuery("#nothiddendiv").is(":visible"), "Modifying CSS display: Assert element is visible"); - jQuery("#nothiddendiv").css("display", "none"); - ok( !jQuery("#nothiddendiv").is(":visible"), "Modified CSS display: Assert element is hidden"); - jQuery("#nothiddendiv").css("display", "block"); - ok( jQuery("#nothiddendiv").is(":visible"), "Modified CSS display: Assert element is visible"); + ok( jQuery( "#nothiddendiv" ).is( ":visible" ), "Modifying CSS display: Assert element is visible" ); + jQuery( "#nothiddendiv" ).css( "display", "none" ); + ok( !jQuery( "#nothiddendiv" ).is( ":visible" ), "Modified CSS display: Assert element is hidden" ); + jQuery( "#nothiddendiv" ).css( "display", "block" ); + ok( jQuery( "#nothiddendiv" ).is( ":visible" ), "Modified CSS display: Assert element is visible" ); ok( jQuery( "#siblingspan" ).is( ":visible" ), "Span with no content is visible" ); $div = jQuery( "<div><span></span></div>" ).appendTo( "#qunit-fixture" ); @@ -1065,19 +1066,19 @@ test( ":visible/:hidden selectors", function() { // $br = jQuery( "<br/>" ).appendTo( "#qunit-fixture" ); // ok( $br.is( ":visible" ), "br element is visible" ); - $table = jQuery("#table"); - $table.html("<tr><td style='display:none'>cell</td><td>cell</td></tr>"); - equal(jQuery("#table td:visible").length, 1, "hidden cell is not perceived as visible (#4512). Works on table elements"); - $table.css("display", "none").html("<tr><td>cell</td><td>cell</td></tr>"); - equal(jQuery("#table td:visible").length, 0, "hidden cell children not perceived as visible (#4512)"); + $table = jQuery( "#table" ); + $table.html( "<tr><td style='display:none'>cell</td><td>cell</td></tr>" ); + equal( jQuery( "#table td:visible" ).length, 1, "hidden cell is not perceived as visible (#4512). Works on table elements" ); + $table.css( "display", "none" ).html( "<tr><td>cell</td><td>cell</td></tr>" ); + equal( jQuery( "#table td:visible" ).length, 0, "hidden cell children not perceived as visible (#4512)" ); - t( "Is Visible", "#qunit-fixture div:visible:lt(2)", ["foo", "nothiddendiv"] ); + t( "Is Visible", "#qunit-fixture div:visible:lt(2)", [ "foo", "nothiddendiv" ] ); t( "Is Not Hidden", "#qunit-fixture:hidden", [] ); - t( "Is Hidden", "#form input:hidden", ["hidden1","hidden2"] ); + t( "Is Hidden", "#form input:hidden", [ "hidden1","hidden2" ] ); $a = jQuery( "<a href='#'><h1>Header</h1></a>" ).appendTo( "#qunit-fixture" ); ok( $a.is( ":visible" ), "Anchor tag with flow content is visible (gh-2227)" ); -}); +} ); test( "Keep the last style if the new one isn't recognized by the browser (#14836)", function() { expect( 2 ); @@ -1087,56 +1088,59 @@ test( "Keep the last style if the new one isn't recognized by the browser (#1483 equal( el.css( "position" ), "absolute", "The old style is kept when setting an unrecognized value" ); el = jQuery( "<div></div>" ).css( "position", "absolute" ).css( "position", " " ); equal( el.css( "position" ), "absolute", "The old style is kept when setting to a space" ); -}); +} ); test( "Reset the style if set to an empty string", function() { expect( 1 ); var el = jQuery( "<div></div>" ).css( "position", "absolute" ).css( "position", "" ); + // Some browsers return an empty string; others "static". Both those cases mean the style // was reset successfully so accept them both. equal( el.css( "position" ) || "static", "static", "The style can be reset by setting to an empty string" ); -}); +} ); asyncTest( "Clearing a Cloned Element's Style Shouldn't Clear the Original Element's Style (#8908)", 24, function() { var baseUrl = document.location.href.replace( /([^\/]*)$/, "" ), - styles = [{ + styles = [ { name: "backgroundAttachment", - value: ["fixed"], + value: [ "fixed" ], expected: [ "scroll" ] },{ name: "backgroundColor", value: [ "rgb(255, 0, 0)", "rgb(255,0,0)", "#ff0000" ], - expected: ["transparent"] + expected: [ "transparent" ] }, { + // Firefox returns auto's value name: "backgroundImage", value: [ "url('test.png')", "url(" + baseUrl + "test.png)", "url(\"" + baseUrl + "test.png\")" ], expected: [ "none", "url(\"http://static.jquery.com/files/rocker/images/logo_jquery_215x53.gif\")" ] }, { name: "backgroundPosition", - value: ["5% 5%"], + value: [ "5% 5%" ], expected: [ "0% 0%", "-1000px 0px", "-1000px 0%" ] }, { + // Firefox returns no-repeat name: "backgroundRepeat", - value: ["repeat-y"], + value: [ "repeat-y" ], expected: [ "repeat", "no-repeat" ] }, { name: "backgroundClip", - value: ["padding-box"], - expected: ["border-box"] + value: [ "padding-box" ], + expected: [ "border-box" ] }, { name: "backgroundOrigin", - value: ["content-box"], - expected: ["padding-box"] + value: [ "content-box" ], + expected: [ "padding-box" ] }, { name: "backgroundSize", - value: ["80px 60px"], + value: [ "80px 60px" ], expected: [ "auto auto" ] - }]; + } ]; - jQuery.each(styles, function( index, style ) { + jQuery.each( styles, function( index, style ) { var $clone, $clonedChildren, $source = jQuery( "#firstp" ), source = $source[ 0 ], @@ -1160,7 +1164,7 @@ asyncTest( "Clearing a Cloned Element's Style Shouldn't Clear the Original Eleme $clone.css( style.name, "" ); $clonedChildren.css( style.name, "" ); - window.setTimeout(function() { + window.setTimeout( function() { notEqual( $clone.css( style.name ), style.value[ 0 ], "Cloned css was changed" ); ok( jQuery.inArray( $source.css( style.name ) !== -1, style.value ), @@ -1173,10 +1177,10 @@ asyncTest( "Clearing a Cloned Element's Style Shouldn't Clear the Original Eleme "; result: " + $children.css( style.name ) + "; expected: " + style.value.join( "," ) ); }, 100 ); - }); + } ); window.setTimeout( start, 1000 ); -}); +} ); test( "show() after hide() should always set display to initial value (#14750)", function() { expect( 1 ); @@ -1188,13 +1192,13 @@ test( "show() after hide() should always set display to initial value (#14750)", div.css( "display", "inline" ).hide().show().css( "display", "list-item" ).hide().show(); equal( div.css( "display" ), "list-item", "should get last set display value" ); -}); +} ); // Support: IE < 11 // We have to jump through the hoops here in order to test work with "order" CSS property, // that some browsers do not support. This test is not, strictly speaking, correct, // but it's the best that we can do. -(function() { +( function() { var style = document.createElement( "div" ).style, exist = "order" in style || "WebkitOrder" in style; @@ -1206,9 +1210,9 @@ test( "show() after hide() should always set display to initial value (#14750)", $elem.css( "order", 2 ); equal( $elem.css( "order" ), "2", "2 on order" ); - }); + } ); } -})(); +} )(); test( "Do not throw on frame elements from css method (#15098)", function() { expect( 1 ); @@ -1233,7 +1237,7 @@ test( "Do not throw on frame elements from css method (#15098)", function() { } catch ( _ ) { ok( false, "It did throw" ); } -}); +} ); test( "get upper case alpha opacity in IE8", function() { expect( 1 ); @@ -1247,8 +1251,7 @@ test( "get upper case alpha opacity in IE8", function() { equal( jQuery( div ).css( "opacity" ), "0.5", "get upper case alpha opacity in IE8 ok" ); fixture.removeChild( div ); -}); - +} ); ( function() { var vendorPrefixes = [ "Webkit", "Moz", "ms" ]; @@ -1261,6 +1264,7 @@ test( "get upper case alpha opacity in IE8", function() { } test( "Don't default to a cached previously used wrong prefixed name (gh-2015)", function() { + // Note: this test needs a property we know is only supported in a prefixed version // by at least one of our main supported browsers. This may get out of date so let's // use -(webkit|moz)-appearance as well as those two are not on a standards track. diff --git a/test/unit/data.js b/test/unit/data.js index 1b4affb32..cf98a816c 100644 --- a/test/unit/data.js +++ b/test/unit/data.js @@ -1,47 +1,47 @@ -module("data", { teardown: moduleTeardown }); +module( "data", { teardown: moduleTeardown } ); -test("expando", function(){ - expect(1); +test( "expando", function() { + expect( 1 ); - equal(jQuery.expando !== undefined, true, "jQuery is exposing the expando"); -}); + equal( jQuery.expando !== undefined, true, "jQuery is exposing the expando" ); +} ); function dataTests( elem ) { var dataObj, internalDataObj; - equal( jQuery.data(elem, "foo"), undefined, "No data exists initially" ); - strictEqual( jQuery.hasData(elem), false, "jQuery.hasData agrees no data exists initially" ); + equal( jQuery.data( elem, "foo" ), undefined, "No data exists initially" ); + strictEqual( jQuery.hasData( elem ), false, "jQuery.hasData agrees no data exists initially" ); - dataObj = jQuery.data(elem); + dataObj = jQuery.data( elem ); equal( typeof dataObj, "object", "Calling data with no args gives us a data object reference" ); - strictEqual( jQuery.data(elem), dataObj, "Calling jQuery.data returns the same data object when called multiple times" ); + strictEqual( jQuery.data( elem ), dataObj, "Calling jQuery.data returns the same data object when called multiple times" ); - strictEqual( jQuery.hasData(elem), false, "jQuery.hasData agrees no data exists even when an empty data obj exists" ); + strictEqual( jQuery.hasData( elem ), false, "jQuery.hasData agrees no data exists even when an empty data obj exists" ); - dataObj["foo"] = "bar"; - equal( jQuery.data(elem, "foo"), "bar", "Data is readable by jQuery.data when set directly on a returned data object" ); + dataObj[ "foo" ] = "bar"; + equal( jQuery.data( elem, "foo" ), "bar", "Data is readable by jQuery.data when set directly on a returned data object" ); - strictEqual( jQuery.hasData(elem), true, "jQuery.hasData agrees data exists when data exists" ); + strictEqual( jQuery.hasData( elem ), true, "jQuery.hasData agrees data exists when data exists" ); - jQuery.data(elem, "foo", "baz"); - equal( jQuery.data(elem, "foo"), "baz", "Data can be changed by jQuery.data" ); - equal( dataObj["foo"], "baz", "Changes made through jQuery.data propagate to referenced data object" ); + jQuery.data( elem, "foo", "baz" ); + equal( jQuery.data( elem, "foo" ), "baz", "Data can be changed by jQuery.data" ); + equal( dataObj[ "foo" ], "baz", "Changes made through jQuery.data propagate to referenced data object" ); - jQuery.data(elem, "foo", undefined); - equal( jQuery.data(elem, "foo"), "baz", "Data is not unset by passing undefined to jQuery.data" ); + jQuery.data( elem, "foo", undefined ); + equal( jQuery.data( elem, "foo" ), "baz", "Data is not unset by passing undefined to jQuery.data" ); - jQuery.data(elem, "foo", null); - strictEqual( jQuery.data(elem, "foo"), null, "Setting null using jQuery.data works OK" ); + jQuery.data( elem, "foo", null ); + strictEqual( jQuery.data( elem, "foo" ), null, "Setting null using jQuery.data works OK" ); - jQuery.data(elem, "foo", "foo1"); + jQuery.data( elem, "foo", "foo1" ); - jQuery.data(elem, { "bar" : "baz", "boom" : "bloz" }); - strictEqual( jQuery.data(elem, "foo"), "foo1", "Passing an object extends the data object instead of replacing it" ); - equal( jQuery.data(elem, "boom"), "bloz", "Extending the data object works" ); + jQuery.data( elem, { "bar": "baz", "boom": "bloz" } ); + strictEqual( jQuery.data( elem, "foo" ), "foo1", "Passing an object extends the data object instead of replacing it" ); + equal( jQuery.data( elem, "boom" ), "bloz", "Extending the data object works" ); - jQuery._data(elem, "foo", "foo2", true); - equal( jQuery._data(elem, "foo"), "foo2", "Setting internal data works" ); - equal( jQuery.data(elem, "foo"), "foo1", "Setting internal data does not override user data" ); + jQuery._data( elem, "foo", "foo2", true ); + equal( jQuery._data( elem, "foo" ), "foo2", "Setting internal data works" ); + equal( jQuery.data( elem, "foo" ), "foo1", "Setting internal data does not override user data" ); internalDataObj = jQuery._data( elem ); ok( internalDataObj, "Internal data object exists" ); @@ -49,31 +49,31 @@ function dataTests( elem ) { strictEqual( elem.boom, undefined, "Data is never stored directly on the object" ); - jQuery.removeData(elem, "foo"); - strictEqual( jQuery.data(elem, "foo"), undefined, "jQuery.removeData removes single properties" ); + jQuery.removeData( elem, "foo" ); + strictEqual( jQuery.data( elem, "foo" ), undefined, "jQuery.removeData removes single properties" ); - jQuery.removeData(elem); - strictEqual( jQuery._data(elem), internalDataObj, "jQuery.removeData does not remove internal data if it exists" ); + jQuery.removeData( elem ); + strictEqual( jQuery._data( elem ), internalDataObj, "jQuery.removeData does not remove internal data if it exists" ); - jQuery.data(elem, "foo", "foo1"); - jQuery._data(elem, "foo", "foo2"); + jQuery.data( elem, "foo", "foo1" ); + jQuery._data( elem, "foo", "foo2" ); - equal( jQuery.data(elem, "foo"), "foo1", "(sanity check) Ensure data is set in user data object" ); - equal( jQuery._data(elem, "foo"), "foo2", "(sanity check) Ensure data is set in internal data object" ); + equal( jQuery.data( elem, "foo" ), "foo1", "(sanity check) Ensure data is set in user data object" ); + equal( jQuery._data( elem, "foo" ), "foo2", "(sanity check) Ensure data is set in internal data object" ); - strictEqual( jQuery._data(elem, jQuery.expando), undefined, "Removing the last item in internal data destroys the internal data object" ); + strictEqual( jQuery._data( elem, jQuery.expando ), undefined, "Removing the last item in internal data destroys the internal data object" ); - jQuery._data(elem, "foo", "foo2"); - equal( jQuery._data(elem, "foo"), "foo2", "(sanity check) Ensure data is set in internal data object" ); + jQuery._data( elem, "foo", "foo2" ); + equal( jQuery._data( elem, "foo" ), "foo2", "(sanity check) Ensure data is set in internal data object" ); - jQuery.removeData(elem, "foo"); - equal( jQuery._data(elem, "foo"), "foo2", "(sanity check) jQuery.removeData for user data does not remove internal data" ); + jQuery.removeData( elem, "foo" ); + equal( jQuery._data( elem, "foo" ), "foo2", "(sanity check) jQuery.removeData for user data does not remove internal data" ); } -test("jQuery.data(div)", function() { +test( "jQuery.data(div)", function() { expect( 25 ); - var div = document.createElement("div"); + var div = document.createElement( "div" ); dataTests( div ); @@ -81,15 +81,15 @@ test("jQuery.data(div)", function() { // assert that nothing else was put in there, and that that // one stayed there. QUnit.expectJqData( this, div, "foo" ); -}); +} ); -test("jQuery.data({})", function() { +test( "jQuery.data({})", function() { expect( 25 ); dataTests( {} ); -}); +} ); -test("jQuery.data(window)", function() { +test( "jQuery.data(window)", function() { expect( 25 ); // remove bound handlers from window object to stop potential false positives caused by fix for #5280 in @@ -97,53 +97,53 @@ test("jQuery.data(window)", function() { jQuery( window ).off( "unload" ); dataTests( window ); -}); +} ); -test("jQuery.data(document)", function() { +test( "jQuery.data(document)", function() { expect( 25 ); dataTests( document ); QUnit.expectJqData( this, document, "foo" ); -}); +} ); -test("Expando cleanup", function() { +test( "Expando cleanup", function() { expect( 4 ); - var div = document.createElement("div"); + var div = document.createElement( "div" ); - function assertExpandoAbsent(message) { + function assertExpandoAbsent( message ) { strictEqual( div[ jQuery.expando ], undefined, message ); } - assertExpandoAbsent("There is no expando on new elements"); + assertExpandoAbsent( "There is no expando on new elements" ); - jQuery.data(div, "foo", 100); - jQuery.data(div, "bar", 200); + jQuery.data( div, "foo", 100 ); + jQuery.data( div, "bar", 200 ); - ok(jQuery.expando in div, "There is an expando on the element after using $.data()"); + ok( jQuery.expando in div, "There is an expando on the element after using $.data()" ); - jQuery.removeData(div, "foo"); + jQuery.removeData( div, "foo" ); - ok(jQuery.expando in div, "There is still an expando on the element after removing (some) of the data"); + ok( jQuery.expando in div, "There is still an expando on the element after removing (some) of the data" ); - jQuery.removeData(div, "bar"); + jQuery.removeData( div, "bar" ); - assertExpandoAbsent("Removing the last item in the data store deletes the expando"); + assertExpandoAbsent( "Removing the last item in the data store deletes the expando" ); // Clean up unattached element - jQuery(div).remove(); -}); + jQuery( div ).remove(); +} ); -test("Data is not being set on comment and text nodes", function() { - expect(2); +test( "Data is not being set on comment and text nodes", function() { + expect( 2 ); - ok( !jQuery.hasData( jQuery("<!-- comment -->").data("foo", 0) ) ); - ok( !jQuery.hasData( jQuery("<span>text</span>").contents().data("foo", 0) ) ); + ok( !jQuery.hasData( jQuery( "<!-- comment -->" ).data( "foo", 0 ) ) ); + ok( !jQuery.hasData( jQuery( "<span>text</span>" ).contents().data( "foo", 0 ) ) ); -}); +} ); -test("jQuery.acceptData", function() { +test( "jQuery.acceptData", function() { expect( 10 ); var flash, pdf; @@ -168,43 +168,43 @@ test("jQuery.acceptData", function() { ok( jQuery.acceptData( jQuery( "#form" ).append( "<input id='nodeType'/><input id='nodeName'/>" )[ 0 ] ), "form with aliased DOM properties" ); -}); +} ); // attempting to access the data of an undefined jQuery element should be undefined -test("jQuery().data() === undefined (#14101)", function() { +test( "jQuery().data() === undefined (#14101)", function() { expect( 2 ); - strictEqual(jQuery().data(), undefined); - strictEqual(jQuery().data("key"), undefined); -}); + strictEqual( jQuery().data(), undefined ); + strictEqual( jQuery().data( "key" ), undefined ); +} ); -test(".data()", function() { - expect(5); +test( ".data()", function() { + expect( 5 ); var div, dataObj, nodiv, obj; - div = jQuery("#foo"); - strictEqual( div.data("foo"), undefined, "Make sure that missing result is undefined" ); - div.data("test", "success"); + div = jQuery( "#foo" ); + strictEqual( div.data( "foo" ), undefined, "Make sure that missing result is undefined" ); + div.data( "test", "success" ); dataObj = div.data(); - deepEqual( dataObj, {test: "success"}, "data() returns entire data object with expected properties" ); - strictEqual( div.data("foo"), undefined, "Make sure that missing result is still undefined" ); + deepEqual( dataObj, { test: "success" }, "data() returns entire data object with expected properties" ); + strictEqual( div.data( "foo" ), undefined, "Make sure that missing result is still undefined" ); - nodiv = jQuery("#unfound"); + nodiv = jQuery( "#unfound" ); equal( nodiv.data(), null, "data() on empty set returns null" ); obj = { foo: "bar" }; - jQuery(obj).data("foo", "baz"); + jQuery( obj ).data( "foo", "baz" ); - dataObj = jQuery.extend(true, {}, jQuery(obj).data()); + dataObj = jQuery.extend( true, {}, jQuery( obj ).data() ); deepEqual( dataObj, { "foo": "baz" }, "Retrieve data object from a wrapped JS object (#7524)" ); -}); +} ); function testDataTypes( $obj ) { - jQuery.each({ + jQuery.each( { "null": null, "true": true, "false": false, @@ -212,78 +212,78 @@ function testDataTypes( $obj ) { "one": 1, "empty string": "", "empty array": [], - "array": [1], + "array": [ 1 ], "empty object": {}, "object": { foo: "bar" }, "date": new Date(), "regex": /test/, "function": function() {} }, function( type, value ) { - strictEqual( $obj.data( "test", value ).data("test"), value, "Data set to " + type ); - }); + strictEqual( $obj.data( "test", value ).data( "test" ), value, "Data set to " + type ); + } ); } -test("jQuery(Element).data(String, Object).data(String)", function() { +test( "jQuery(Element).data(String, Object).data(String)", function() { expect( 18 ); - var parent = jQuery("<div><div></div></div>"), + var parent = jQuery( "<div><div></div></div>" ), div = parent.children(); - strictEqual( div.data("test"), undefined, "No data exists initially" ); - strictEqual( div.data("test", "success").data("test"), "success", "Data added" ); - strictEqual( div.data("test", "overwritten").data("test"), "overwritten", "Data overwritten" ); - strictEqual( div.data("test", undefined).data("test"), "overwritten", ".data(key,undefined) does nothing but is chainable (#5571)"); - strictEqual( div.data("notexist"), undefined, "No data exists for unset key" ); + strictEqual( div.data( "test" ), undefined, "No data exists initially" ); + strictEqual( div.data( "test", "success" ).data( "test" ), "success", "Data added" ); + strictEqual( div.data( "test", "overwritten" ).data( "test" ), "overwritten", "Data overwritten" ); + strictEqual( div.data( "test", undefined ).data( "test" ), "overwritten", ".data(key,undefined) does nothing but is chainable (#5571)" ); + strictEqual( div.data( "notexist" ), undefined, "No data exists for unset key" ); testDataTypes( div ); parent.remove(); -}); +} ); -test("jQuery(plain Object).data(String, Object).data(String)", function() { +test( "jQuery(plain Object).data(String, Object).data(String)", function() { expect( 16 ); // #3748 - var $obj = jQuery({ exists: true }); - strictEqual( $obj.data("nothing"), undefined, "Non-existent data returns undefined"); - strictEqual( $obj.data("exists"), undefined, "Object properties are not returned as data" ); + var $obj = jQuery( { exists: true } ); + strictEqual( $obj.data( "nothing" ), undefined, "Non-existent data returns undefined" ); + strictEqual( $obj.data( "exists" ), undefined, "Object properties are not returned as data" ); testDataTypes( $obj ); // Clean up $obj.removeData(); - deepEqual( $obj[0], { exists: true }, "removeData does not clear the object" ); -}); + deepEqual( $obj[ 0 ], { exists: true }, "removeData does not clear the object" ); +} ); -test("data-* attributes", function() { +test( "data-* attributes", function() { expect( 46 ); var prop, i, l, metadata, elem, obj, obj2, check, num, num2, parseJSON = jQuery.parseJSON, - div = jQuery("<div>"), - child = jQuery("<div data-myobj='old data' data-ignored=\"DOM\" data-other='test' data-foo-42='boosh'></div>"), - dummy = jQuery("<div data-myobj='old data' data-ignored=\"DOM\" data-other='test' data-foo-42='boosh'></div>"); + div = jQuery( "<div>" ), + child = jQuery( "<div data-myobj='old data' data-ignored=\"DOM\" data-other='test' data-foo-42='boosh'></div>" ), + dummy = jQuery( "<div data-myobj='old data' data-ignored=\"DOM\" data-other='test' data-foo-42='boosh'></div>" ); - equal( div.data("attr"), undefined, "Check for non-existing data-attr attribute" ); + equal( div.data( "attr" ), undefined, "Check for non-existing data-attr attribute" ); - div.attr("data-attr", "exists"); - equal( div.data("attr"), "exists", "Check for existing data-attr attribute" ); + div.attr( "data-attr", "exists" ); + equal( div.data( "attr" ), "exists", "Check for existing data-attr attribute" ); - div.attr("data-attr", "exists2"); - equal( div.data("attr"), "exists", "Check that updates to data- don't update .data()" ); + div.attr( "data-attr", "exists2" ); + equal( div.data( "attr" ), "exists", "Check that updates to data- don't update .data()" ); - div.data("attr", "internal").attr("data-attr", "external"); - equal( div.data("attr"), "internal", "Check for .data('attr') precedence (internal > external data-* attribute)" ); + div.data( "attr", "internal" ).attr( "data-attr", "external" ); + equal( div.data( "attr" ), "internal", "Check for .data('attr') precedence (internal > external data-* attribute)" ); div.remove(); - child.appendTo("#qunit-fixture"); - equal( child.data("myobj"), "old data", "Value accessed from data-* attribute"); - equal( child.data("foo-42"), "boosh", "camelCasing does not affect numbers (#1751)" ); + child.appendTo( "#qunit-fixture" ); + equal( child.data( "myobj" ), "old data", "Value accessed from data-* attribute" ); + equal( child.data( "foo-42" ), "boosh", "camelCasing does not affect numbers (#1751)" ); - child.data("myobj", "replaced"); - equal( child.data("myobj"), "replaced", "Original data overwritten"); + child.data( "myobj", "replaced" ); + equal( child.data( "myobj" ), "replaced", "Original data overwritten" ); - child.data("ignored", "cache"); - equal( child.data("ignored"), "cache", "Cached data used before DOM data-* fallback"); + child.data( "ignored", "cache" ); + equal( child.data( "ignored" ), "cache", "Cached data used before DOM data-* fallback" ); obj = child.data(); obj2 = dummy.data(); @@ -294,8 +294,8 @@ test("data-* attributes", function() { dummy.remove(); for ( i = 0, l = check.length; i < l; i++ ) { - ok( obj[ check[i] ], "Make sure data- property exists when calling data-." ); - ok( obj2[ check[i] ], "Make sure data- property exists when calling data-." ); + ok( obj[ check[ i ] ], "Make sure data- property exists when calling data-." ); + ok( obj2[ check[ i ] ], "Make sure data- property exists when calling data-." ); } for ( prop in obj ) { @@ -310,9 +310,9 @@ test("data-* attributes", function() { equal( num2, check.length, "Make sure that the right number of properties came through." ); - child.attr("data-other", "newvalue"); + child.attr( "data-other", "newvalue" ); - equal( child.data("other"), "test", "Make sure value was pulled in properly from a .data()." ); + equal( child.data( "other" ), "test", "Make sure value was pulled in properly from a .data()." ); // attribute parsing i = 0; @@ -322,218 +322,218 @@ test("data-* attributes", function() { }; child - .attr("data-true", "true") - .attr("data-false", "false") - .attr("data-five", "5") - .attr("data-point", "5.5") - .attr("data-pointe", "5.5E3") - .attr("data-grande", "5.574E9") - .attr("data-hexadecimal", "0x42") - .attr("data-pointbad", "5..5") - .attr("data-pointbad2", "-.") - .attr("data-bigassnum", "123456789123456789123456789") - .attr("data-badjson", "{123}") - .attr("data-badjson2", "[abc]") - .attr("data-notjson", " {}") - .attr("data-notjson2", "[] ") - .attr("data-empty", "") - .attr("data-space", " ") - .attr("data-null", "null") - .attr("data-string", "test"); - - strictEqual( child.data("true"), true, "Primitive true read from attribute"); - strictEqual( child.data("false"), false, "Primitive false read from attribute"); - strictEqual( child.data("five"), 5, "Integer read from attribute"); - strictEqual( child.data("point"), 5.5, "Floating-point number read from attribute"); - strictEqual( child.data("pointe"), "5.5E3", - "Exponential-notation number read from attribute as string"); - strictEqual( child.data("grande"), "5.574E9", - "Big exponential-notation number read from attribute as string"); - strictEqual( child.data("hexadecimal"), "0x42", - "Hexadecimal number read from attribute as string"); - strictEqual( child.data("pointbad"), "5..5", - "Extra-point non-number read from attribute as string"); - strictEqual( child.data("pointbad2"), "-.", - "No-digit non-number read from attribute as string"); - strictEqual( child.data("bigassnum"), "123456789123456789123456789", - "Bad bigass number read from attribute as string"); - strictEqual( child.data("badjson"), "{123}", "Bad JSON object read from attribute as string"); - strictEqual( child.data("badjson2"), "[abc]", "Bad JSON array read from attribute as string"); - strictEqual( child.data("notjson"), " {}", - "JSON object with leading non-JSON read from attribute as string"); - strictEqual( child.data("notjson2"), "[] ", - "JSON array with trailing non-JSON read from attribute as string"); - strictEqual( child.data("empty"), "", "Empty string read from attribute"); - strictEqual( child.data("space"), " ", "Whitespace string read from attribute"); - strictEqual( child.data("null"), null, "Primitive null read from attribute"); - strictEqual( child.data("string"), "test", "Typical string read from attribute"); + .attr( "data-true", "true" ) + .attr( "data-false", "false" ) + .attr( "data-five", "5" ) + .attr( "data-point", "5.5" ) + .attr( "data-pointe", "5.5E3" ) + .attr( "data-grande", "5.574E9" ) + .attr( "data-hexadecimal", "0x42" ) + .attr( "data-pointbad", "5..5" ) + .attr( "data-pointbad2", "-." ) + .attr( "data-bigassnum", "123456789123456789123456789" ) + .attr( "data-badjson", "{123}" ) + .attr( "data-badjson2", "[abc]" ) + .attr( "data-notjson", " {}" ) + .attr( "data-notjson2", "[] " ) + .attr( "data-empty", "" ) + .attr( "data-space", " " ) + .attr( "data-null", "null" ) + .attr( "data-string", "test" ); + + strictEqual( child.data( "true" ), true, "Primitive true read from attribute" ); + strictEqual( child.data( "false" ), false, "Primitive false read from attribute" ); + strictEqual( child.data( "five" ), 5, "Integer read from attribute" ); + strictEqual( child.data( "point" ), 5.5, "Floating-point number read from attribute" ); + strictEqual( child.data( "pointe" ), "5.5E3", + "Exponential-notation number read from attribute as string" ); + strictEqual( child.data( "grande" ), "5.574E9", + "Big exponential-notation number read from attribute as string" ); + strictEqual( child.data( "hexadecimal" ), "0x42", + "Hexadecimal number read from attribute as string" ); + strictEqual( child.data( "pointbad" ), "5..5", + "Extra-point non-number read from attribute as string" ); + strictEqual( child.data( "pointbad2" ), "-.", + "No-digit non-number read from attribute as string" ); + strictEqual( child.data( "bigassnum" ), "123456789123456789123456789", + "Bad bigass number read from attribute as string" ); + strictEqual( child.data( "badjson" ), "{123}", "Bad JSON object read from attribute as string" ); + strictEqual( child.data( "badjson2" ), "[abc]", "Bad JSON array read from attribute as string" ); + strictEqual( child.data( "notjson" ), " {}", + "JSON object with leading non-JSON read from attribute as string" ); + strictEqual( child.data( "notjson2" ), "[] ", + "JSON array with trailing non-JSON read from attribute as string" ); + strictEqual( child.data( "empty" ), "", "Empty string read from attribute" ); + strictEqual( child.data( "space" ), " ", "Whitespace string read from attribute" ); + strictEqual( child.data( "null" ), null, "Primitive null read from attribute" ); + strictEqual( child.data( "string" ), "test", "Typical string read from attribute" ); equal( i, 2, "Correct number of JSON parse attempts when reading from attributes" ); jQuery.parseJSON = parseJSON; child.remove(); // tests from metadata plugin - function testData(index, elem) { - switch (index) { + function testData( index, elem ) { + switch ( index ) { case 0: - equal(jQuery(elem).data("foo"), "bar", "Check foo property"); - equal(jQuery(elem).data("bar"), "baz", "Check baz property"); + equal( jQuery( elem ).data( "foo" ), "bar", "Check foo property" ); + equal( jQuery( elem ).data( "bar" ), "baz", "Check baz property" ); break; case 1: - equal(jQuery(elem).data("test"), "bar", "Check test property"); - equal(jQuery(elem).data("bar"), "baz", "Check bar property"); + equal( jQuery( elem ).data( "test" ), "bar", "Check test property" ); + equal( jQuery( elem ).data( "bar" ), "baz", "Check bar property" ); break; case 2: - equal(jQuery(elem).data("zoooo"), "bar", "Check zoooo property"); - deepEqual(jQuery(elem).data("bar"), {"test":"baz"}, "Check bar property"); + equal( jQuery( elem ).data( "zoooo" ), "bar", "Check zoooo property" ); + deepEqual( jQuery( elem ).data( "bar" ), { "test":"baz" }, "Check bar property" ); break; case 3: - equal(jQuery(elem).data("number"), true, "Check number property"); - deepEqual(jQuery(elem).data("stuff"), [2,8], "Check stuff property"); + equal( jQuery( elem ).data( "number" ), true, "Check number property" ); + deepEqual( jQuery( elem ).data( "stuff" ), [ 2,8 ], "Check stuff property" ); break; default: - ok(false, ["Assertion failed on index ", index, ", with data"].join("")); + ok( false, [ "Assertion failed on index ", index, ", with data" ].join( "" ) ); } } metadata = "<ol><li class='test test2' data-foo='bar' data-bar='baz' data-arr='[1,2]'>Some stuff</li><li class='test test2' data-test='bar' data-bar='baz'>Some stuff</li><li class='test test2' data-zoooo='bar' data-bar='{\"test\":\"baz\"}'>Some stuff</li><li class='test test2' data-number=true data-stuff='[2,8]'>Some stuff</li></ol>"; - elem = jQuery(metadata).appendTo("#qunit-fixture"); + elem = jQuery( metadata ).appendTo( "#qunit-fixture" ); - elem.find("li").each(testData); + elem.find( "li" ).each( testData ); elem.remove(); -}); +} ); -test(".data(Object)", function() { - expect(4); +test( ".data(Object)", function() { + expect( 4 ); var obj, jqobj, - div = jQuery("<div/>"); + div = jQuery( "<div/>" ); - div.data({ "test": "in", "test2": "in2" }); - equal( div.data("test"), "in", "Verify setting an object in data" ); - equal( div.data("test2"), "in2", "Verify setting an object in data" ); + div.data( { "test": "in", "test2": "in2" } ); + equal( div.data( "test" ), "in", "Verify setting an object in data" ); + equal( div.data( "test2" ), "in2", "Verify setting an object in data" ); - obj = {test:"unset"}; - jqobj = jQuery(obj); + obj = { test:"unset" }; + jqobj = jQuery( obj ); - jqobj.data("test", "unset"); - jqobj.data({ "test": "in", "test2": "in2" }); - equal( jQuery.data(obj)["test"], "in", "Verify setting an object on an object extends the data object" ); - equal( obj["test2"], undefined, "Verify setting an object on an object does not extend the object" ); + jqobj.data( "test", "unset" ); + jqobj.data( { "test": "in", "test2": "in2" } ); + equal( jQuery.data( obj )[ "test" ], "in", "Verify setting an object on an object extends the data object" ); + equal( obj[ "test2" ], undefined, "Verify setting an object on an object does not extend the object" ); // manually clean up detached elements div.remove(); -}); +} ); -test("jQuery.removeData", function() { - expect(10); +test( "jQuery.removeData", function() { + expect( 10 ); var obj, - div = jQuery("#foo")[0]; - jQuery.data(div, "test", "testing"); - jQuery.removeData(div, "test"); - equal( jQuery.data(div, "test"), undefined, "Check removal of data" ); + div = jQuery( "#foo" )[ 0 ]; + jQuery.data( div, "test", "testing" ); + jQuery.removeData( div, "test" ); + equal( jQuery.data( div, "test" ), undefined, "Check removal of data" ); - jQuery.data(div, "test2", "testing"); + jQuery.data( div, "test2", "testing" ); jQuery.removeData( div ); - ok( !jQuery.data(div, "test2"), "Make sure that the data property no longer exists." ); + ok( !jQuery.data( div, "test2" ), "Make sure that the data property no longer exists." ); ok( !div[ jQuery.expando ], "Make sure the expando no longer exists, as well." ); - jQuery.data(div, { + jQuery.data( div, { test3: "testing", test4: "testing" - }); + } ); jQuery.removeData( div, "test3 test4" ); - ok( !jQuery.data(div, "test3") || jQuery.data(div, "test4"), "Multiple delete with spaces." ); + ok( !jQuery.data( div, "test3" ) || jQuery.data( div, "test4" ), "Multiple delete with spaces." ); - jQuery.data(div, { + jQuery.data( div, { test3: "testing", test4: "testing" - }); + } ); jQuery.removeData( div, [ "test3", "test4" ] ); - ok( !jQuery.data(div, "test3") || jQuery.data(div, "test4"), "Multiple delete by array." ); + ok( !jQuery.data( div, "test3" ) || jQuery.data( div, "test4" ), "Multiple delete by array." ); - jQuery.data(div, { + jQuery.data( div, { "test3 test4": "testing", "test3": "testing" - }); + } ); jQuery.removeData( div, "test3 test4" ); - ok( !jQuery.data(div, "test3 test4"), "Multiple delete with spaces deleted key with exact name" ); - ok( jQuery.data(div, "test3"), "Left the partial matched key alone" ); + ok( !jQuery.data( div, "test3 test4" ), "Multiple delete with spaces deleted key with exact name" ); + ok( jQuery.data( div, "test3" ), "Left the partial matched key alone" ); obj = {}; - jQuery.data(obj, "test", "testing"); - equal( jQuery(obj).data("test"), "testing", "verify data on plain object"); - jQuery.removeData(obj, "test"); - equal( jQuery.data(obj, "test"), undefined, "Check removal of data on plain object" ); + jQuery.data( obj, "test", "testing" ); + equal( jQuery( obj ).data( "test" ), "testing", "verify data on plain object" ); + jQuery.removeData( obj, "test" ); + equal( jQuery.data( obj, "test" ), undefined, "Check removal of data on plain object" ); jQuery.data( window, "BAD", true ); jQuery.removeData( window, "BAD" ); ok( !jQuery.data( window, "BAD" ), "Make sure that the value was not still set." ); -}); +} ); -test(".removeData()", function() { - expect(6); - var div = jQuery("#foo"); - div.data("test", "testing"); - div.removeData("test"); - equal( div.data("test"), undefined, "Check removal of data" ); +test( ".removeData()", function() { + expect( 6 ); + var div = jQuery( "#foo" ); + div.data( "test", "testing" ); + div.removeData( "test" ); + equal( div.data( "test" ), undefined, "Check removal of data" ); - div.data("test", "testing"); - div.data("test.foo", "testing2"); - div.removeData("test.bar"); - equal( div.data("test.foo"), "testing2", "Make sure data is intact" ); - equal( div.data("test"), "testing", "Make sure data is intact" ); + div.data( "test", "testing" ); + div.data( "test.foo", "testing2" ); + div.removeData( "test.bar" ); + equal( div.data( "test.foo" ), "testing2", "Make sure data is intact" ); + equal( div.data( "test" ), "testing", "Make sure data is intact" ); - div.removeData("test"); - equal( div.data("test.foo"), "testing2", "Make sure data is intact" ); - equal( div.data("test"), undefined, "Make sure data is intact" ); + div.removeData( "test" ); + equal( div.data( "test.foo" ), "testing2", "Make sure data is intact" ); + equal( div.data( "test" ), undefined, "Make sure data is intact" ); - div.removeData("test.foo"); - equal( div.data("test.foo"), undefined, "Make sure data is intact" ); -}); + div.removeData( "test.foo" ); + equal( div.data( "test.foo" ), undefined, "Make sure data is intact" ); +} ); -if (window.JSON && window.JSON.stringify) { - test("JSON serialization (#8108)", function () { - expect(1); +if ( window.JSON && window.JSON.stringify ) { + test( "JSON serialization (#8108)", function() { + expect( 1 ); var obj = { "foo": "bar" }; - jQuery.data(obj, "hidden", true); + jQuery.data( obj, "hidden", true ); - equal( JSON.stringify(obj), "{\"foo\":\"bar\"}", "Expando is hidden from JSON.stringify" ); - }); + equal( JSON.stringify( obj ), "{\"foo\":\"bar\"}", "Expando is hidden from JSON.stringify" ); + } ); } -test("jQuery.data should follow html5 specification regarding camel casing", function() { - expect(10); +test( "jQuery.data should follow html5 specification regarding camel casing", function() { + expect( 10 ); - var div = jQuery("<div id='myObject' data-w-t-f='ftw' data-big-a-little-a='bouncing-b' data-foo='a' data-foo-bar='b' data-foo-bar-baz='c'></div>") - .prependTo("body"); + var div = jQuery( "<div id='myObject' data-w-t-f='ftw' data-big-a-little-a='bouncing-b' data-foo='a' data-foo-bar='b' data-foo-bar-baz='c'></div>" ) + .prependTo( "body" ); - equal( div.data()["wTF"], "ftw", "Verify single letter data-* key" ); - equal( div.data()["bigALittleA"], "bouncing-b", "Verify single letter mixed data-* key" ); + equal( div.data()[ "wTF" ], "ftw", "Verify single letter data-* key" ); + equal( div.data()[ "bigALittleA" ], "bouncing-b", "Verify single letter mixed data-* key" ); - equal( div.data()["foo"], "a", "Verify single word data-* key" ); - equal( div.data()["fooBar"], "b", "Verify multiple word data-* key" ); - equal( div.data()["fooBarBaz"], "c", "Verify multiple word data-* key" ); + equal( div.data()[ "foo" ], "a", "Verify single word data-* key" ); + equal( div.data()[ "fooBar" ], "b", "Verify multiple word data-* key" ); + equal( div.data()[ "fooBarBaz" ], "c", "Verify multiple word data-* key" ); - equal( div.data("foo"), "a", "Verify single word data-* key" ); - equal( div.data("fooBar"), "b", "Verify multiple word data-* key" ); - equal( div.data("fooBarBaz"), "c", "Verify multiple word data-* key" ); + equal( div.data( "foo" ), "a", "Verify single word data-* key" ); + equal( div.data( "fooBar" ), "b", "Verify multiple word data-* key" ); + equal( div.data( "fooBarBaz" ), "c", "Verify multiple word data-* key" ); - div.data("foo-bar", "d"); + div.data( "foo-bar", "d" ); - equal( div.data("fooBar"), "d", "Verify updated data-* key" ); - equal( div.data("foo-bar"), "d", "Verify updated data-* key" ); + equal( div.data( "fooBar" ), "d", "Verify updated data-* key" ); + equal( div.data( "foo-bar" ), "d", "Verify updated data-* key" ); div.remove(); -}); +} ); -test("jQuery.data should not miss data with preset hyphenated property names", function() { +test( "jQuery.data should not miss data with preset hyphenated property names", function() { - expect(2); + expect( 2 ); - var div = jQuery("<div/>", { id: "hyphened" }).appendTo("#qunit-fixture"), + var div = jQuery( "<div/>", { id: "hyphened" } ).appendTo( "#qunit-fixture" ), test = { "camelBar": "camelBar", "hyphen-foo": "hyphen-foo" @@ -541,36 +541,36 @@ test("jQuery.data should not miss data with preset hyphenated property names", f div.data( test ); - jQuery.each( test , function(i, k) { - equal( div.data(k), k, "data with property '"+k+"' was correctly found"); - }); -}); + jQuery.each( test, function( i, k ) { + equal( div.data( k ), k, "data with property '" + k + "' was correctly found" ); + } ); +} ); -test(".data should not miss attr() set data-* with hyphenated property names", function() { - expect(2); +test( ".data should not miss attr() set data-* with hyphenated property names", function() { + expect( 2 ); var a, b; - a = jQuery("<div/>").appendTo("#qunit-fixture"); + a = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ); a.attr( "data-long-param", "test" ); - a.data( "long-param", { a: 2 }); + a.data( "long-param", { a: 2 } ); - deepEqual( a.data("long-param"), { a: 2 }, "data with property long-param was found, 1" ); + deepEqual( a.data( "long-param" ), { a: 2 }, "data with property long-param was found, 1" ); - b = jQuery("<div/>").appendTo("#qunit-fixture"); + b = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ); b.attr( "data-long-param", "test" ); b.data( "long-param" ); - b.data( "long-param", { a: 2 }); + b.data( "long-param", { a: 2 } ); - deepEqual( b.data("long-param"), { a: 2 }, "data with property long-param was found, 2" ); -}); + deepEqual( b.data( "long-param" ), { a: 2 }, "data with property long-param was found, 2" ); +} ); -test(".data always sets data with the camelCased key (gh-2257)", function() { +test( ".data always sets data with the camelCased key (gh-2257)", function() { expect( 36 ); - var div = jQuery("<div>").appendTo("#qunit-fixture"), + var div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ), datas = { "non-empty": "a string", "empty-string": "", @@ -592,7 +592,7 @@ test(".data always sets data with the camelCased key (gh-2257)", function() { var allData = div.data(); equal( allData[ key ], undefined, ".data(key, val) does not store with hyphenated keys" ); equal( allData[ jQuery.camelCase( key ) ], val, ".data(key, val) stores the camelCased key" ); - }); + } ); div.removeData(); @@ -601,8 +601,8 @@ test(".data always sets data with the camelCased key (gh-2257)", function() { var allData = div.data(); equal( allData[ key ], undefined, ".data(object) does not store with hyphenated keys" ); equal( allData[ jQuery.camelCase( key ) ], val, ".data(object) stores the camelCased key" ); - }); -}); + } ); +} ); test( ".data should not strip more than one hyphen when camelCasing (gh-2070)", function() { expect( 3 ); @@ -612,10 +612,10 @@ test( ".data should not strip more than one hyphen when camelCasing (gh-2070)", equal( allData.nestedSingle, "single", "Key is correctly camelCased" ); equal( allData[ "nested-Double" ], "double", "Key with double hyphens is correctly camelCased" ); equal( allData[ "nested--Triple" ], "triple", "Key with triple hyphens is correctly camelCased" ); -}); +} ); -test(".data supports interoperable hyphenated/camelCase get/set of properties with arbitrary non-null|NaN|undefined values", function() { - var div = jQuery("<div/>", { id: "hyphened" }).appendTo("#qunit-fixture"), +test( ".data supports interoperable hyphenated/camelCase get/set of properties with arbitrary non-null|NaN|undefined values", function() { + var div = jQuery( "<div/>", { id: "hyphened" } ).appendTo( "#qunit-fixture" ), datas = { "non-empty": "a string", "empty-string": "", @@ -625,6 +625,7 @@ test(".data supports interoperable hyphenated/camelCase get/set of properties wi "an-object": {}, "bool-true": true, "bool-false": false, + // JSHint enforces double quotes, // but JSON strings need double quotes to parse // so we need escaped double quotes here @@ -641,11 +642,11 @@ test(".data supports interoperable hyphenated/camelCase get/set of properties wi deepEqual( div.data( key ), val, "get: " + key ); deepEqual( div.data( jQuery.camelCase( key ) ), val, "get: " + jQuery.camelCase( key ) ); - }); -}); + } ); +} ); -test("jQuery.data supports interoperable removal of hyphenated/camelCase properties", function() { - var div = jQuery("<div/>", { id: "hyphened" }).appendTo("#qunit-fixture"), +test( "jQuery.data supports interoperable removal of hyphenated/camelCase properties", function() { + var div = jQuery( "<div/>", { id: "hyphened" } ).appendTo( "#qunit-fixture" ), datas = { "non-empty": "a string", "empty-string": "", @@ -655,6 +656,7 @@ test("jQuery.data supports interoperable removal of hyphenated/camelCase propert "an-object": {}, "bool-true": true, "bool-false": false, + // JSHint enforces double quotes, // but JSON strings need double quotes to parse // so we need escaped double quotes here @@ -673,11 +675,11 @@ test("jQuery.data supports interoperable removal of hyphenated/camelCase propert equal( div.data( key ), undefined, "get: " + key ); - }); -}); + } ); +} ); -test(".data supports interoperable removal of properties SET TWICE #13850", function() { - var div = jQuery("<div>").appendTo("#qunit-fixture"), +test( ".data supports interoperable removal of properties SET TWICE #13850", function() { + var div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ), datas = { "non-empty": "a string", "empty-string": "", @@ -687,6 +689,7 @@ test(".data supports interoperable removal of properties SET TWICE #13850", func "an-object": {}, "bool-true": true, "bool-false": false, + // JSHint enforces double quotes, // but JSON strings need double quotes to parse // so we need escaped double quotes here @@ -702,51 +705,54 @@ test(".data supports interoperable removal of properties SET TWICE #13850", func div.removeData( key ); equal( div.data( key ), undefined, "removal: " + key ); - }); -}); + } ); +} ); test( ".removeData supports removal of hyphenated properties via array (#12786, gh-2257)", function() { expect( 4 ); var div, plain, compare; - div = jQuery("<div>").appendTo("#qunit-fixture"); - plain = jQuery({}); + div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ); + plain = jQuery( {} ); // Properties should always be camelCased compare = { + // From batch assignment .data({ "a-a": 1 }) "aA": 1, + // From property, value assignment .data( "b-b", 1 ) "bB": 1 }; // Mixed assignment - div.data({ "a-a": 1 }).data( "b-b", 1 ); - plain.data({ "a-a": 1 }).data( "b-b", 1 ); + div.data( { "a-a": 1 } ).data( "b-b", 1 ); + plain.data( { "a-a": 1 } ).data( "b-b", 1 ); deepEqual( div.data(), compare, "Data appears as expected. (div)" ); deepEqual( plain.data(), compare, "Data appears as expected. (plain)" ); - div.removeData([ "a-a", "b-b" ]); - plain.removeData([ "a-a", "b-b" ]); + div.removeData( [ "a-a", "b-b" ] ); + plain.removeData( [ "a-a", "b-b" ] ); deepEqual( div.data(), {}, "Data is empty. (div)" ); deepEqual( plain.data(), {}, "Data is empty. (plain)" ); -}); +} ); // Test originally by Moschel -test("Triggering the removeData should not throw exceptions. (#10080)", function() { - expect(1); +test( "Triggering the removeData should not throw exceptions. (#10080)", function() { + expect( 1 ); stop(); - var frame = jQuery("#loadediframe"); - jQuery(frame[0].contentWindow).on("unload", function() { - ok(true, "called unload"); + var frame = jQuery( "#loadediframe" ); + jQuery( frame[ 0 ].contentWindow ).on( "unload", function() { + ok( true, "called unload" ); start(); - }); + } ); + // change the url to trigger unload - frame.attr("src", "data/iframe.html?param=true"); -}); + frame.attr( "src", "data/iframe.html?param=true" ); +} ); test( "Only check element attributes once when calling .data() - #8909", function() { expect( 2 ); @@ -766,18 +772,18 @@ test( "Only check element attributes once when calling .data() - #8909", functio // clean up data cache element.remove(); -}); +} ); test( "JSON data- attributes can have newlines", function() { - expect(1); + expect( 1 ); - var x = jQuery("<div data-some='{\n\"foo\":\n\t\"bar\"\n}'></div>"); - equal( x.data("some").foo, "bar", "got a JSON data- attribute with spaces" ); + var x = jQuery( "<div data-some='{\n\"foo\":\n\t\"bar\"\n}'></div>" ); + equal( x.data( "some" ).foo, "bar", "got a JSON data- attribute with spaces" ); x.remove(); -}); +} ); testIframeWithCallback( "enumerate data attrs on body (#14894)", "data/dataAttrs.html", function( result ) { - expect(1); + expect( 1 ); - equal(result, "ok", "enumeration of data- attrs on body" ); -}); + equal( result, "ok", "enumeration of data- attrs on body" ); +} ); diff --git a/test/unit/deferred.js b/test/unit/deferred.js index 1aa15435f..3bf6ca49e 100644 --- a/test/unit/deferred.js +++ b/test/unit/deferred.js @@ -1,6 +1,6 @@ module( "deferred", { teardown: moduleTeardown -}); +} ); jQuery.each( [ "", " - new operator" ], function( _, withNew ) { @@ -16,32 +16,32 @@ jQuery.each( [ "", " - new operator" ], function( _, withNew ) { ok( jQuery.isFunction( defer.pipe ), "defer.pipe is a function" ); - createDeferred().resolve().done(function() { + createDeferred().resolve().done( function() { ok( true, "Success on resolve" ); strictEqual( this.state(), "resolved", "Deferred is resolved (state)" ); - }).fail(function() { + } ).fail( function() { ok( false, "Error on resolve" ); - }).always(function() { + } ).always( function() { ok( true, "Always callback on resolve" ); - }); + } ); - createDeferred().reject().done(function() { + createDeferred().reject().done( function() { ok( false, "Success on reject" ); - }).fail(function() { + } ).fail( function() { ok( true, "Error on reject" ); strictEqual( this.state(), "rejected", "Deferred is rejected (state)" ); - }).always(function() { + } ).always( function() { ok( true, "Always callback on reject" ); - }); + } ); - createDeferred(function( defer ) { + createDeferred( function( defer ) { ok( this === defer, "Defer passed as this & first argument" ); - this.resolve("done"); - }).done(function( value ) { + this.resolve( "done" ); + } ).done( function( value ) { strictEqual( value, "done", "Passed function executed" ); - }); + } ); - createDeferred(function( defer ) { + createDeferred( function( defer ) { var promise = defer.promise(), func = function() {}, funcPromise = defer.promise( func ); @@ -54,17 +54,17 @@ jQuery.each( [ "", " - new operator" ], function( _, withNew ) { if ( promise[ key ] !== func[ key ] ) { strictEqual( func[ key ], promise[ key ], key + " is the same" ); } - }); - }); + } ); + } ); jQuery.expandedEach = jQuery.each; - jQuery.expandedEach( "resolve reject".split(" "), function( _, change ) { - createDeferred(function( defer ) { + jQuery.expandedEach( "resolve reject".split( " " ), function( _, change ) { + createDeferred( function( defer ) { strictEqual( defer.state(), "pending", "pending after creation" ); var checked = 0; - defer.progress(function( value ) { + defer.progress( function( value ) { strictEqual( value, checked, "Progress: right value (" + value + ") received" ); - }); + } ); for ( checked = 0; checked < 3; checked++ ) { defer.notify( checked ); } @@ -72,11 +72,10 @@ jQuery.each( [ "", " - new operator" ], function( _, withNew ) { defer[ change ](); notStrictEqual( defer.state(), "pending", "not pending after " + change ); defer.notify(); - }); - }); - }); -}); - + } ); + } ); + } ); +} ); test( "jQuery.Deferred - chainability", function() { @@ -85,13 +84,13 @@ test( "jQuery.Deferred - chainability", function() { expect( 10 ); jQuery.expandedEach = jQuery.each; - jQuery.expandedEach( "resolve reject notify resolveWith rejectWith notifyWith done fail progress always".split(" "), function( _, method ) { + jQuery.expandedEach( "resolve reject notify resolveWith rejectWith notifyWith done fail progress always".split( " " ), function( _, method ) { var object = { m: defer[ method ] }; strictEqual( object.m(), object, method + " is chainable" ); - }); -}); + } ); +} ); test( "jQuery.Deferred.then - filtering (done)", function( assert ) { @@ -99,36 +98,36 @@ test( "jQuery.Deferred.then - filtering (done)", function( assert ) { var value1, value2, value3, defer = jQuery.Deferred(), - piped = defer.then(function( a, b ) { + piped = defer.then( function( a, b ) { return a * b; - }), + } ), done = jQuery.map( new Array( 3 ), function() { return assert.async(); } ); - piped.done(function( result ) { + piped.done( function( result ) { value3 = result; - }); + } ); - defer.done(function( a, b ) { + defer.done( function( a, b ) { value1 = a; value2 = b; - }); + } ); - defer.resolve( 2, 3 ).then(function() { + defer.resolve( 2, 3 ).then( function() { assert.strictEqual( value1, 2, "first resolve value ok" ); assert.strictEqual( value2, 3, "second resolve value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done.pop().call(); - }); + } ); - jQuery.Deferred().reject().then(function() { + jQuery.Deferred().reject().then( function() { assert.ok( false, "then should not be called on reject" ); - }).then( null, done.pop() ); + } ).then( null, done.pop() ); - jQuery.Deferred().resolve().then( jQuery.noop ).done(function( value ) { + jQuery.Deferred().resolve().then( jQuery.noop ).done( function( value ) { assert.strictEqual( value, undefined, "then done callback can return undefined/null" ); done.pop().call(); - }); -}); + } ); +} ); test( "jQuery.Deferred.then - filtering (fail)", function( assert ) { @@ -138,70 +137,70 @@ test( "jQuery.Deferred.then - filtering (fail)", function( assert ) { defer = jQuery.Deferred(), piped = defer.then( null, function( a, b ) { return a * b; - }), + } ), done = jQuery.map( new Array( 3 ), function() { return assert.async(); } ); - piped.done(function( result ) { + piped.done( function( result ) { value3 = result; - }); + } ); - defer.fail(function( a, b ) { + defer.fail( function( a, b ) { value1 = a; value2 = b; - }); + } ); defer.reject( 2, 3 ).then( null, function() { assert.strictEqual( value1, 2, "first reject value ok" ); assert.strictEqual( value2, 3, "second reject value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done.pop().call(); - }); + } ); jQuery.Deferred().resolve().then( null, function() { assert.ok( false, "then should not be called on resolve" ); - }).then( done.pop() ); + } ).then( done.pop() ); - jQuery.Deferred().reject().then( null, jQuery.noop ).done(function( value ) { + jQuery.Deferred().reject().then( null, jQuery.noop ).done( function( value ) { assert.strictEqual( value, undefined, "then fail callback can return undefined/null" ); done.pop().call(); - }); -}); + } ); +} ); test( "jQuery.Deferred.catch", function( assert ) { assert.expect( 4 ); var value1, value2, value3, defer = jQuery.Deferred(), - piped = defer[ "catch" ](function( a, b ) { + piped = defer[ "catch" ]( function( a, b ) { return a * b; - }), + } ), done = jQuery.map( new Array( 3 ), function() { return assert.async(); } ); - piped.done(function( result ) { + piped.done( function( result ) { value3 = result; - }); + } ); - defer.fail(function( a, b ) { + defer.fail( function( a, b ) { value1 = a; value2 = b; - }); + } ); - defer.reject( 2, 3 )[ "catch" ](function() { + defer.reject( 2, 3 )[ "catch" ]( function() { assert.strictEqual( value1, 2, "first reject value ok" ); assert.strictEqual( value2, 3, "second reject value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done.pop().call(); - }); + } ); - jQuery.Deferred().resolve()[ "catch" ](function() { + jQuery.Deferred().resolve()[ "catch" ]( function() { assert.ok( false, "then should not be called on resolve" ); - }).then( done.pop() ); + } ).then( done.pop() ); - jQuery.Deferred().reject()[ "catch" ]( jQuery.noop ).done(function( value ) { + jQuery.Deferred().reject()[ "catch" ]( jQuery.noop ).done( function( value ) { assert.strictEqual( value, undefined, "then fail callback can return undefined/null" ); done.pop().call(); - }); -}); + } ); +} ); test( "[PIPE ONLY] jQuery.Deferred.pipe - filtering (fail)", function( assert ) { @@ -211,34 +210,34 @@ test( "[PIPE ONLY] jQuery.Deferred.pipe - filtering (fail)", function( assert ) defer = jQuery.Deferred(), piped = defer.pipe( null, function( a, b ) { return a * b; - }), + } ), done = jQuery.map( new Array( 3 ), function() { return assert.async(); } ); - piped.fail(function( result ) { + piped.fail( function( result ) { value3 = result; - }); + } ); - defer.fail(function( a, b ) { + defer.fail( function( a, b ) { value1 = a; value2 = b; - }); + } ); defer.reject( 2, 3 ).pipe( null, function() { assert.strictEqual( value1, 2, "first reject value ok" ); assert.strictEqual( value2, 3, "second reject value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done.pop().call(); - }); + } ); jQuery.Deferred().resolve().pipe( null, function() { assert.ok( false, "then should not be called on resolve" ); - }).then( done.pop() ); + } ).then( done.pop() ); - jQuery.Deferred().reject().pipe( null, jQuery.noop ).fail(function( value ) { + jQuery.Deferred().reject().pipe( null, jQuery.noop ).fail( function( value ) { assert.strictEqual( value, undefined, "then fail callback can return undefined/null" ); done.pop().call(); - }); -}); + } ); +} ); test( "jQuery.Deferred.then - filtering (progress)", function( assert ) { @@ -248,25 +247,25 @@ test( "jQuery.Deferred.then - filtering (progress)", function( assert ) { defer = jQuery.Deferred(), piped = defer.then( null, null, function( a, b ) { return a * b; - }), + } ), done = assert.async(); - piped.progress(function( result ) { + piped.progress( function( result ) { value3 = result; - }); + } ); - defer.progress(function( a, b ) { + defer.progress( function( a, b ) { value1 = a; value2 = b; - }); + } ); defer.notify( 2, 3 ).then( null, null, function() { assert.strictEqual( value1, 2, "first progress value ok" ); assert.strictEqual( value2, 3, "second progress value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done(); - }); -}); + } ); +} ); test( "jQuery.Deferred.then - deferred (done)", function( assert ) { @@ -274,31 +273,31 @@ test( "jQuery.Deferred.then - deferred (done)", function( assert ) { var value1, value2, value3, defer = jQuery.Deferred(), - piped = defer.then(function( a, b ) { - return jQuery.Deferred(function( defer ) { + piped = defer.then( function( a, b ) { + return jQuery.Deferred( function( defer ) { defer.reject( a * b ); - }); - }), + } ); + } ), done = assert.async(); - piped.fail(function( result ) { + piped.fail( function( result ) { value3 = result; - }); + } ); - defer.done(function( a, b ) { + defer.done( function( a, b ) { value1 = a; value2 = b; - }); + } ); defer.resolve( 2, 3 ); - piped.fail(function() { + piped.fail( function() { assert.strictEqual( value1, 2, "first resolve value ok" ); assert.strictEqual( value2, 3, "second resolve value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done(); - }); -}); + } ); +} ); test( "jQuery.Deferred.then - deferred (fail)", function( assert ) { @@ -307,30 +306,30 @@ test( "jQuery.Deferred.then - deferred (fail)", function( assert ) { var value1, value2, value3, defer = jQuery.Deferred(), piped = defer.then( null, function( a, b ) { - return jQuery.Deferred(function( defer ) { + return jQuery.Deferred( function( defer ) { defer.resolve( a * b ); - }); - }), + } ); + } ), done = assert.async(); - piped.done(function( result ) { + piped.done( function( result ) { value3 = result; - }); + } ); - defer.fail(function( a, b ) { + defer.fail( function( a, b ) { value1 = a; value2 = b; - }); + } ); defer.reject( 2, 3 ); - piped.done(function() { + piped.done( function() { assert.strictEqual( value1, 2, "first reject value ok" ); assert.strictEqual( value2, 3, "second reject value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done(); - }); -}); + } ); +} ); test( "jQuery.Deferred.then - deferred (progress)", function( assert ) { @@ -339,38 +338,38 @@ test( "jQuery.Deferred.then - deferred (progress)", function( assert ) { var value1, value2, value3, defer = jQuery.Deferred(), piped = defer.then( null, null, function( a, b ) { - return jQuery.Deferred(function( defer ) { + return jQuery.Deferred( function( defer ) { defer.resolve( a * b ); - }); - }), + } ); + } ), done = assert.async(); - piped.progress(function( result ) { - return jQuery.Deferred().resolve().then(function() { + piped.progress( function( result ) { + return jQuery.Deferred().resolve().then( function() { return result; - }).then(function( result ) { + } ).then( function( result ) { value3 = result; - }); - }); + } ); + } ); - defer.progress(function( a, b ) { + defer.progress( function( a, b ) { value1 = a; value2 = b; - }); + } ); defer.notify( 2, 3 ); piped.then( null, null, function( result ) { - return jQuery.Deferred().resolve().then(function() { + return jQuery.Deferred().resolve().then( function() { return result; - }).then(function() { + } ).then( function() { assert.strictEqual( value1, 2, "first progress value ok" ); assert.strictEqual( value2, 3, "second progress value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done(); - }); - }); -}); + } ); + } ); +} ); test( "[PIPE ONLY] jQuery.Deferred.pipe - deferred (progress)", function( assert ) { @@ -379,30 +378,30 @@ test( "[PIPE ONLY] jQuery.Deferred.pipe - deferred (progress)", function( assert var value1, value2, value3, defer = jQuery.Deferred(), piped = defer.pipe( null, null, function( a, b ) { - return jQuery.Deferred(function( defer ) { + return jQuery.Deferred( function( defer ) { defer.resolve( a * b ); - }); - }), + } ); + } ), done = assert.async(); - piped.done(function( result ) { + piped.done( function( result ) { value3 = result; - }); + } ); - defer.progress(function( a, b ) { + defer.progress( function( a, b ) { value1 = a; value2 = b; - }); + } ); defer.notify( 2, 3 ); - piped.done(function() { + piped.done( function() { assert.strictEqual( value1, 2, "first progress value ok" ); assert.strictEqual( value2, 3, "second progress value ok" ); assert.strictEqual( value3, 6, "result of filter ok" ); done(); - }); -}); + } ); +} ); test( "jQuery.Deferred.then - context", function( assert ) { @@ -412,48 +411,48 @@ test( "jQuery.Deferred.then - context", function( assert ) { context = {}, done = jQuery.map( new Array( 4 ), function() { return assert.async(); } ); - jQuery.Deferred().resolveWith( context, [ 2 ] ).then(function( value ) { + jQuery.Deferred().resolveWith( context, [ 2 ] ).then( function( value ) { return value * 3; - }).done(function( value ) { + } ).done( function( value ) { assert.notStrictEqual( this, context, "custom context not propagated through .then" ); assert.strictEqual( value, 6, "proper value received" ); done.pop().call(); - }); + } ); - jQuery.Deferred().resolve().then(function() { + jQuery.Deferred().resolve().then( function() { return jQuery.Deferred().resolveWith( context ); - }).done(function() { + } ).done( function() { assert.strictEqual( this, context, "custom context of returned deferred correctly propagated" ); done.pop().call(); - }); + } ); defer = jQuery.Deferred(); - piped = defer.then(function( value ) { + piped = defer.then( function( value ) { return value * 3; - }); + } ); defer.resolve( 2 ); - piped.done(function( value ) { + piped.done( function( value ) { assert.strictEqual( this, piped, "default context gets updated to latest promise in the chain" ); assert.strictEqual( value, 6, "proper value received" ); done.pop().call(); - }); + } ); defer2 = jQuery.Deferred(); piped2 = defer2.then(); defer2.resolve( 2 ); - piped2.done(function( value ) { + piped2.done( function( value ) { assert.strictEqual( this, piped2, "default context updated to latest promise in the chain (without passing function)" ); assert.strictEqual( value, 2, "proper value received (without passing function)" ); done.pop().call(); - }); -}); + } ); +} ); test( "[PIPE ONLY] jQuery.Deferred.pipe - context", function( assert ) { @@ -463,66 +462,66 @@ test( "[PIPE ONLY] jQuery.Deferred.pipe - context", function( assert ) { context = {}, done = jQuery.map( new Array( 4 ), function() { return assert.async(); } ); - jQuery.Deferred().resolveWith( context, [ 2 ] ).pipe(function( value ) { + jQuery.Deferred().resolveWith( context, [ 2 ] ).pipe( function( value ) { return value * 3; - }).done(function( value ) { + } ).done( function( value ) { assert.strictEqual( this, context, "[PIPE ONLY] custom context correctly propagated" ); assert.strictEqual( value, 6, "proper value received" ); done.pop().call(); - }); + } ); - jQuery.Deferred().resolve().pipe(function() { - return jQuery.Deferred().resolveWith(context); - }).done(function() { + jQuery.Deferred().resolve().pipe( function() { + return jQuery.Deferred().resolveWith( context ); + } ).done( function() { assert.strictEqual( this, context, "custom context of returned deferred correctly propagated" ); done.pop().call(); - }); + } ); defer = jQuery.Deferred(); - piped = defer.pipe(function( value ) { + piped = defer.pipe( function( value ) { return value * 3; - }); + } ); defer.resolve( 2 ); - piped.done(function( value ) { + piped.done( function( value ) { assert.strictEqual( this, piped, "default context gets updated to latest promise in the chain" ); assert.strictEqual( value, 6, "proper value received" ); done.pop().call(); - }); + } ); defer2 = jQuery.Deferred(); piped2 = defer2.pipe(); defer2.resolve( 2 ); - piped2.done(function( value ) { + piped2.done( function( value ) { assert.strictEqual( this, piped2, "default context updated to latest promise in the chain (without passing function)" ); assert.strictEqual( value, 2, "proper value received (without passing function)" ); done.pop().call(); - }); -}); + } ); +} ); asyncTest( "jQuery.Deferred.then - spec compatibility", function() { expect( 1 ); - var defer = jQuery.Deferred().done(function() { + var defer = jQuery.Deferred().done( function() { setTimeout( start ); throw new Error(); - }); + } ); - defer.then(function() { + defer.then( function() { ok( true, "errors in .done callbacks don't stop .then handlers" ); - }); + } ); try { defer.resolve(); } catch ( _ ) {} -}); +} ); test( "jQuery.Deferred - 1.x/2.x compatibility", function( assert ) { @@ -534,46 +533,46 @@ test( "jQuery.Deferred - 1.x/2.x compatibility", function( assert ) { thenable.unwrapped = false; - jQuery.Deferred().resolve( 1, 2 ).then(function() { + jQuery.Deferred().resolve( 1, 2 ).then( function() { assert.deepEqual( [].slice.call( arguments ), [ 1, 2 ], ".then fulfillment callbacks receive all resolution values" ); done.pop().call(); - }); + } ); jQuery.Deferred().reject( 1, 2 ).then( null, function() { assert.deepEqual( [].slice.call( arguments ), [ 1, 2 ], ".then rejection callbacks receive all rejection values" ); done.pop().call(); - }); + } ); jQuery.Deferred().notify( 1, 2 ).then( null, null, function() { assert.deepEqual( [].slice.call( arguments ), [ 1, 2 ], ".then progress callbacks receive all progress values" ); done.pop().call(); - }); + } ); - jQuery.Deferred().resolveWith( context ).then(function() { + jQuery.Deferred().resolveWith( context ).then( function() { assert.deepEqual( this, context, ".then fulfillment callbacks receive context" ); done.pop().call(); - }); + } ); jQuery.Deferred().rejectWith( context ).then( null, function() { assert.deepEqual( this, context, ".then rejection callbacks receive context" ); done.pop().call(); - }); + } ); jQuery.Deferred().notifyWith( context ).then( null, null, function() { assert.deepEqual( this, context, ".then progress callbacks receive context" ); done.pop().call(); - }); + } ); - jQuery.Deferred().resolve( thenable ).done(function( value ) { + jQuery.Deferred().resolve( thenable ).done( function( value ) { assert.strictEqual( value, thenable, ".done doesn't unwrap thenables" ); done.pop().call(); - }); + } ); jQuery.Deferred().notify( thenable ).then().then( null, null, function( value ) { assert.strictEqual( value, "thenable fulfillment", ".then implicit progress callbacks unwrap thenables" ); done.pop().call(); - }); -}); + } ); +} ); test( "jQuery.Deferred.then - progress and thenables", function( assert ) { @@ -590,16 +589,16 @@ test( "jQuery.Deferred.then - progress and thenables", function( assert ) { trigger.then( null, null, function() { var notifier = jQuery.Deferred().notify( "foo" ); - setTimeout(function() { + setTimeout( function() { notifier.notify( "bar" ).resolve( "baz" ); - }); + } ); return notifier; - }).then( failer( "fulfill" ), failer( "reject" ), function( v ) { + } ).then( failer( "fulfill" ), failer( "reject" ), function( v ) { assert.strictEqual( v, expectedProgress.shift(), "expected progress value" ); done.pop().call(); - }); + } ); trigger.notify(); -}); +} ); test( "jQuery.Deferred - notify and resolve", function( assert ) { @@ -643,18 +642,19 @@ test( "jQuery.Deferred - notify and resolve", function( assert ) { notifiedResolved.then( null, null, function() { return jQuery.Deferred().notify( "baz" ).resolve( "quux" ); } ).progress( function( v ) { + // Progress from the surrogate deferred is ignored assert.strictEqual( v, "quux", "deferred replaced then'd progress value" ); done.pop().call(); } ); -}); +} ); test( "jQuery.when", function() { expect( 37 ); // Some other objects - jQuery.each({ + jQuery.each( { "an empty string": "", "a non-empty string": "some string", "zero": 0, @@ -669,21 +669,21 @@ test( "jQuery.when", function() { }, function( message, value ) { ok( jQuery.isFunction( - jQuery.when( value ).done(function( resolveValue ) { + jQuery.when( value ).done( function( resolveValue ) { strictEqual( this, window, "Context is the global object with " + message ); strictEqual( resolveValue, value, "Test the promise was resolved with " + message ); - }).promise + } ).promise ), "Test " + message + " triggers the creation of a new Promise" ); - }); + } ); ok( jQuery.isFunction( - jQuery.when().done(function( resolveValue ) { + jQuery.when().done( function( resolveValue ) { strictEqual( this, window, "Test the promise was resolved with window as its context" ); strictEqual( resolveValue, undefined, "Test the promise was resolved with no parameter" ); - }).promise + } ).promise ), "Test calling when with no parameter triggers the creation of a new Promise" ); @@ -691,23 +691,23 @@ test( "jQuery.when", function() { var cache, context = {}; - jQuery.when( jQuery.Deferred().resolveWith( context ) ).done(function() { + jQuery.when( jQuery.Deferred().resolveWith( context ) ).done( function() { strictEqual( this, context, "when( promise ) propagates context" ); - }); + } ); - jQuery.each([ 1, 2, 3 ], function( k, i ) { + jQuery.each( [ 1, 2, 3 ], function( k, i ) { - jQuery.when( cache || jQuery.Deferred(function() { + jQuery.when( cache || jQuery.Deferred( function() { this.resolve( i ); - }) - ).done(function( value ) { + } ) + ).done( function( value ) { strictEqual( value, 1, "Function executed" + ( i > 1 ? " only once" : "" ) ); cache = value; - }); + } ); - }); -}); + } ); +} ); test( "jQuery.when - joined", function() { @@ -762,7 +762,7 @@ test( "jQuery.when - joined", function() { context2 = defer2 && jQuery.isFunction( defer2.promise ) ? defer2.promise() : ( defer2.then ? window : undefined ); - jQuery.when( defer1, defer2 ).done(function( a, b ) { + jQuery.when( defer1, defer2 ).done( function( a, b ) { if ( shouldResolve ) { deepEqual( [ a, b ], expected, code + " => resolve" ); strictEqual( this[ 0 ], context1, code + " => first context OK" ); @@ -770,22 +770,22 @@ test( "jQuery.when - joined", function() { } else { ok( false, code + " => resolve" ); } - }).fail(function( a, b ) { + } ).fail( function( a, b ) { if ( shouldError ) { deepEqual( [ a, b ], expected, code + " => reject" ); } else { ok( false, code + " => reject" ); } - }).progress(function( a, b ) { + } ).progress( function( a, b ) { deepEqual( [ a, b ], expectedNotify, code + " => progress" ); strictEqual( this[ 0 ], expectedNotify[ 0 ] ? context1 : undefined, code + " => first context OK" ); strictEqual( this[ 1 ], expectedNotify[ 1 ] ? context2 : undefined, code + " => second context OK" ); - }).always( restart ); - }); - }); + } ).always( restart ); + } ); + } ); deferreds.eventuallyFulfilled.resolve( 1 ); deferreds.eventuallyRejected.reject( 0 ); -}); +} ); test( "jQuery.when - resolved", function() { @@ -795,18 +795,18 @@ test( "jQuery.when - resolved", function() { b = jQuery.Deferred().notify( 2 ).resolve( 5 ), c = jQuery.Deferred().notify( 3 ).resolve( 6 ); - jQuery.when( a, b, c ).progress(function( a, b, c ) { + jQuery.when( a, b, c ).progress( function( a, b, c ) { strictEqual( a, 1, "first notify value ok" ); strictEqual( b, 2, "second notify value ok" ); strictEqual( c, 3, "third notify value ok" ); - }).done(function( a, b, c ) { + } ).done( function( a, b, c ) { strictEqual( a, 4, "first resolve value ok" ); strictEqual( b, 5, "second resolve value ok" ); strictEqual( c, 6, "third resolve value ok" ); - }).fail(function() { + } ).fail( function() { ok( false, "Error on resolve" ); - }); -}); + } ); +} ); test( "jQuery.when - filtering", function() { @@ -821,12 +821,12 @@ test( "jQuery.when - filtering", function() { jQuery.when( jQuery.Deferred().resolve( 3 ).then( increment ), jQuery.Deferred().reject( 5 ).then( null, increment ) - ).done(function( four, six ) { + ).done( function( four, six ) { strictEqual( four, 4, "resolved value incremented" ); strictEqual( six, 6, "rejected value incremented" ); start(); - }); -}); + } ); +} ); test( "jQuery.when - exceptions", function() { @@ -838,14 +838,14 @@ test( "jQuery.when - exceptions", function() { stop(); - jQuery.Deferred().resolve().then( woops ).fail(function( doneException ) { + jQuery.Deferred().resolve().then( woops ).fail( function( doneException ) { strictEqual( doneException, "exception thrown", "throwing in done handler" ); - jQuery.Deferred().reject().then( null, woops ).fail(function( failException ) { + jQuery.Deferred().reject().then( null, woops ).fail( function( failException ) { strictEqual( failException, "exception thrown", "throwing in fail handler" ); start(); - }); - }); -}); + } ); + } ); +} ); test( "jQuery.when - chaining", function() { @@ -868,13 +868,13 @@ test( "jQuery.when - chaining", function() { jQuery.Deferred().reject( 5 ).then( null, chain ), jQuery.Deferred().resolve( 3 ).then( chainStandard ), jQuery.Deferred().reject( 5 ).then( null, chainStandard ) - ).done(function( v1, v2, s1, s2 ) { + ).done( function( v1, v2, s1, s2 ) { strictEqual( v1, "other deferred", "chaining in done handler" ); strictEqual( v2, "other deferred", "chaining in fail handler" ); strictEqual( s1, "std deferred", "chaining thenable in done handler" ); strictEqual( s2, "std deferred", "chaining thenable in fail handler" ); start(); - }); + } ); defer.resolve( "other deferred" ); -}); +} ); diff --git a/test/unit/deprecated.js b/test/unit/deprecated.js index 9dcad77e4..9052c6acf 100644 --- a/test/unit/deprecated.js +++ b/test/unit/deprecated.js @@ -1,2 +1,2 @@ -module("deprecated", { teardown: moduleTeardown }); +module( "deprecated", { teardown: moduleTeardown } ); diff --git a/test/unit/dimensions.js b/test/unit/dimensions.js index 2eb6e73df..eadb06050 100644 --- a/test/unit/dimensions.js +++ b/test/unit/dimensions.js @@ -1,10 +1,10 @@ -(function() { +( function() { if ( !jQuery.fn.width ) { return; } -module("dimensions", { teardown: moduleTeardown }); +module( "dimensions", { teardown: moduleTeardown } ); function pass( val ) { return val; @@ -29,111 +29,111 @@ function fn( val ) { */ function testWidth( val ) { - expect(9); + expect( 9 ); var $div, blah; - $div = jQuery("#nothiddendiv"); - $div.width( val(30) ); - equal($div.width(), 30, "Test set to 30 correctly"); + $div = jQuery( "#nothiddendiv" ); + $div.width( val( 30 ) ); + equal( $div.width(), 30, "Test set to 30 correctly" ); $div.hide(); - equal($div.width(), 30, "Test hidden div"); + equal( $div.width(), 30, "Test hidden div" ); $div.show(); - $div.width( val(-1) ); // handle negative numbers by setting to 0 #11604 - equal($div.width(), 0, "Test negative width normalized to 0"); - $div.css("padding", "20px"); - equal($div.width(), 0, "Test padding specified with pixels"); - $div.css("border", "2px solid #fff"); - equal($div.width(), 0, "Test border specified with pixels"); + $div.width( val( -1 ) ); // handle negative numbers by setting to 0 #11604 + equal( $div.width(), 0, "Test negative width normalized to 0" ); + $div.css( "padding", "20px" ); + equal( $div.width(), 0, "Test padding specified with pixels" ); + $div.css( "border", "2px solid #fff" ); + equal( $div.width(), 0, "Test border specified with pixels" ); - $div.css({ "display": "", "border": "", "padding": "" }); + $div.css( { "display": "", "border": "", "padding": "" } ); - jQuery("#nothiddendivchild").css({ "width": 20, "padding": "3px", "border": "2px solid #fff" }); - equal(jQuery("#nothiddendivchild").width(), 20, "Test child width with border and padding"); - jQuery("#nothiddendiv, #nothiddendivchild").css({ "border": "", "padding": "", "width": "" }); + jQuery( "#nothiddendivchild" ).css( { "width": 20, "padding": "3px", "border": "2px solid #fff" } ); + equal( jQuery( "#nothiddendivchild" ).width(), 20, "Test child width with border and padding" ); + jQuery( "#nothiddendiv, #nothiddendivchild" ).css( { "border": "", "padding": "", "width": "" } ); - blah = jQuery("blah"); - equal( blah.width( val(10) ), blah, "Make sure that setting a width on an empty set returns the set." ); - equal( blah.width(), null, "Make sure 'null' is returned on an empty set"); + blah = jQuery( "blah" ); + equal( blah.width( val( 10 ) ), blah, "Make sure that setting a width on an empty set returns the set." ); + equal( blah.width(), null, "Make sure 'null' is returned on an empty set" ); - equal( jQuery(window).width(), document.documentElement.clientWidth, "Window width is equal to width reported by window/document." ); + equal( jQuery( window ).width(), document.documentElement.clientWidth, "Window width is equal to width reported by window/document." ); - QUnit.expectJqData( this, $div[0], "display" ); + QUnit.expectJqData( this, $div[ 0 ], "display" ); } -test("width()", function() { +test( "width()", function() { testWidth( pass ); -}); +} ); -test("width(Function)", function() { +test( "width(Function)", function() { testWidth( fn ); -}); +} ); -test("width(Function(args))", function() { +test( "width(Function(args))", function() { expect( 2 ); - var $div = jQuery("#nothiddendiv"); - $div.width( 30 ).width(function(i, width) { + var $div = jQuery( "#nothiddendiv" ); + $div.width( 30 ).width( function( i, width ) { equal( width, 30, "Make sure previous value is correct." ); return width + 1; - }); + } ); equal( $div.width(), 31, "Make sure value was modified correctly." ); -}); +} ); function testHeight( val ) { - expect(9); + expect( 9 ); var $div, blah; - $div = jQuery("#nothiddendiv"); - $div.height( val(30) ); - equal($div.height(), 30, "Test set to 30 correctly"); + $div = jQuery( "#nothiddendiv" ); + $div.height( val( 30 ) ); + equal( $div.height(), 30, "Test set to 30 correctly" ); $div.hide(); - equal($div.height(), 30, "Test hidden div"); + equal( $div.height(), 30, "Test hidden div" ); $div.show(); - $div.height( val(-1) ); // handle negative numbers by setting to 0 #11604 - equal($div.height(), 0, "Test negative height normalized to 0"); - $div.css("padding", "20px"); - equal($div.height(), 0, "Test padding specified with pixels"); - $div.css("border", "2px solid #fff"); - equal($div.height(), 0, "Test border specified with pixels"); + $div.height( val( -1 ) ); // handle negative numbers by setting to 0 #11604 + equal( $div.height(), 0, "Test negative height normalized to 0" ); + $div.css( "padding", "20px" ); + equal( $div.height(), 0, "Test padding specified with pixels" ); + $div.css( "border", "2px solid #fff" ); + equal( $div.height(), 0, "Test border specified with pixels" ); - $div.css({ "display": "", "border": "", "padding": "", "height": "1px" }); + $div.css( { "display": "", "border": "", "padding": "", "height": "1px" } ); - jQuery("#nothiddendivchild").css({ "height": 20, "padding": "3px", "border": "2px solid #fff" }); - equal(jQuery("#nothiddendivchild").height(), 20, "Test child height with border and padding"); - jQuery("#nothiddendiv, #nothiddendivchild").css({ "border": "", "padding": "", "height": "" }); + jQuery( "#nothiddendivchild" ).css( { "height": 20, "padding": "3px", "border": "2px solid #fff" } ); + equal( jQuery( "#nothiddendivchild" ).height(), 20, "Test child height with border and padding" ); + jQuery( "#nothiddendiv, #nothiddendivchild" ).css( { "border": "", "padding": "", "height": "" } ); - blah = jQuery("blah"); - equal( blah.height( val(10) ), blah, "Make sure that setting a height on an empty set returns the set." ); - equal( blah.height(), null, "Make sure 'null' is returned on an empty set"); + blah = jQuery( "blah" ); + equal( blah.height( val( 10 ) ), blah, "Make sure that setting a height on an empty set returns the set." ); + equal( blah.height(), null, "Make sure 'null' is returned on an empty set" ); - equal( jQuery(window).height(), document.documentElement.clientHeight, "Window width is equal to width reported by window/document." ); + equal( jQuery( window ).height(), document.documentElement.clientHeight, "Window width is equal to width reported by window/document." ); - QUnit.expectJqData( this, $div[0], "display" ); + QUnit.expectJqData( this, $div[ 0 ], "display" ); } -test("height()", function() { +test( "height()", function() { testHeight( pass ); -}); +} ); -test("height(Function)", function() { +test( "height(Function)", function() { testHeight( fn ); -}); +} ); -test("height(Function(args))", function() { +test( "height(Function(args))", function() { expect( 2 ); - var $div = jQuery("#nothiddendiv"); - $div.height( 30 ).height(function(i, height) { + var $div = jQuery( "#nothiddendiv" ); + $div.height( 30 ).height( function( i, height ) { equal( height, 30, "Make sure previous value is correct." ); return height + 1; - }); + } ); equal( $div.height(), 31, "Make sure value was modified correctly." ); -}); +} ); -test("innerWidth()", function() { +test( "innerWidth()", function() { expect( 6 ); var $div, div, @@ -144,11 +144,11 @@ test("innerWidth()", function() { equal( jQuery( document ).innerWidth(), $doc.width(), "Test on document" ); $div = jQuery( "#nothiddendiv" ); - $div.css({ + $div.css( { "margin": 10, "border": "2px solid #fff", "width": 30 - }); + } ); equal( $div.innerWidth(), 30, "Test with margin and border" ); $div.css( "padding", "20px" ); @@ -157,7 +157,7 @@ test("innerWidth()", function() { equal( $div.innerWidth(), 70, "Test hidden div" ); // reset styles - $div.css({ "display": "", "border": "", "padding": "", "width": "", "height": "" }); + $div.css( { "display": "", "border": "", "padding": "", "width": "", "height": "" } ); div = jQuery( "<div>" ); @@ -166,9 +166,9 @@ test("innerWidth()", function() { div.remove(); QUnit.expectJqData( this, $div[ 0 ], "display" ); -}); +} ); -test("innerHeight()", function() { +test( "innerHeight()", function() { expect( 6 ); var $div, div, @@ -179,11 +179,11 @@ test("innerHeight()", function() { equal( jQuery( document ).innerHeight(), $doc.height(), "Test on document" ); $div = jQuery( "#nothiddendiv" ); - $div.css({ + $div.css( { "margin": 10, "border": "2px solid #fff", "height": 30 - }); + } ); equal( $div.innerHeight(), 30, "Test with margin and border" ); $div.css( "padding", "20px" ); @@ -192,7 +192,7 @@ test("innerHeight()", function() { equal( $div.innerHeight(), 70, "Test hidden div" ); // reset styles - $div.css({ "display": "", "border": "", "padding": "", "width": "", "height": "" }); + $div.css( { "display": "", "border": "", "padding": "", "width": "", "height": "" } ); div = jQuery( "<div>" ); @@ -201,9 +201,9 @@ test("innerHeight()", function() { div.remove(); QUnit.expectJqData( this, $div[ 0 ], "display" ); -}); +} ); -test("outerWidth()", function() { +test( "outerWidth()", function() { expect( 11 ); var $div, div, @@ -231,7 +231,7 @@ test("outerWidth()", function() { equal( $div.outerWidth( true ), 94, "Test hidden div with padding, border and margin with margin option" ); // reset styles - $div.css({ "position": "", "display": "", "border": "", "padding": "", "width": "", "height": "" }); + $div.css( { "position": "", "display": "", "border": "", "padding": "", "width": "", "height": "" } ); div = jQuery( "<div>" ); @@ -240,23 +240,23 @@ test("outerWidth()", function() { div.remove(); QUnit.expectJqData( this, $div[ 0 ], "display" ); -}); +} ); -test("child of a hidden elem (or unconnected node) has accurate inner/outer/Width()/Height() see #9441 #9300", function() { - expect(16); +test( "child of a hidden elem (or unconnected node) has accurate inner/outer/Width()/Height() see #9441 #9300", function() { + expect( 16 ); // setup html - var $divNormal = jQuery("<div>").css({ "width": "100px", "height": "100px", "border": "10px solid white", "padding": "2px", "margin": "3px" }), + var $divNormal = jQuery( "<div>" ).css( { "width": "100px", "height": "100px", "border": "10px solid white", "padding": "2px", "margin": "3px" } ), $divChild = $divNormal.clone(), $divUnconnected = $divNormal.clone(), - $divHiddenParent = jQuery("<div>").css( "display", "none" ).append( $divChild ).appendTo("body"); - $divNormal.appendTo("body"); + $divHiddenParent = jQuery( "<div>" ).css( "display", "none" ).append( $divChild ).appendTo( "body" ); + $divNormal.appendTo( "body" ); // tests that child div of a hidden div works the same as a normal div equal( $divChild.width(), $divNormal.width(), "child of a hidden element width() is wrong see #9441" ); equal( $divChild.innerWidth(), $divNormal.innerWidth(), "child of a hidden element innerWidth() is wrong see #9441" ); equal( $divChild.outerWidth(), $divNormal.outerWidth(), "child of a hidden element outerWidth() is wrong see #9441" ); - equal( $divChild.outerWidth(true), $divNormal.outerWidth( true ), "child of a hidden element outerWidth( true ) is wrong see #9300" ); + equal( $divChild.outerWidth( true ), $divNormal.outerWidth( true ), "child of a hidden element outerWidth( true ) is wrong see #9300" ); // Support: IE 10-11, Edge // Child height is not always decimal @@ -269,7 +269,7 @@ test("child of a hidden elem (or unconnected node) has accurate inner/outer/Widt equal( $divUnconnected.width(), $divNormal.width(), "unconnected element width() is wrong see #9441" ); equal( $divUnconnected.innerWidth(), $divNormal.innerWidth(), "unconnected element innerWidth() is wrong see #9441" ); equal( $divUnconnected.outerWidth(), $divNormal.outerWidth(), "unconnected element outerWidth() is wrong see #9441" ); - equal( $divUnconnected.outerWidth(true), $divNormal.outerWidth( true ), "unconnected element outerWidth( true ) is wrong see #9300" ); + equal( $divUnconnected.outerWidth( true ), $divNormal.outerWidth( true ), "unconnected element outerWidth( true ) is wrong see #9300" ); // Support: IE 10-11, Edge // Child height is not always decimal @@ -281,9 +281,9 @@ test("child of a hidden elem (or unconnected node) has accurate inner/outer/Widt // teardown html $divHiddenParent.remove(); $divNormal.remove(); -}); +} ); -test("getting dimensions shouldn't modify runtimeStyle see #9233", function() { +test( "getting dimensions shouldn't modify runtimeStyle see #9233", function() { expect( 1 ); var $div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ), @@ -304,36 +304,36 @@ test("getting dimensions shouldn't modify runtimeStyle see #9233", function() { } $div.remove(); -}); +} ); test( "table dimensions", function() { expect( 2 ); - var table = jQuery("<table><colgroup><col/><col/></colgroup><tbody><tr><td></td><td>a</td></tr><tr><td></td><td>a</td></tr></tbody></table>").appendTo("#qunit-fixture"), - tdElem = table.find("td").first(), - colElem = table.find("col").first().width( 300 ); + var table = jQuery( "<table><colgroup><col/><col/></colgroup><tbody><tr><td></td><td>a</td></tr><tr><td></td><td>a</td></tr></tbody></table>" ).appendTo( "#qunit-fixture" ), + tdElem = table.find( "td" ).first(), + colElem = table.find( "col" ).first().width( 300 ); - table.find("td").css({ "margin": 0, "padding": 0 }); + table.find( "td" ).css( { "margin": 0, "padding": 0 } ); equal( tdElem.width(), tdElem.width(), "width() doesn't alter dimension values of empty cells, see #11293" ); equal( colElem.width(), 300, "col elements have width(), see #12243" ); -}); +} ); -test("box-sizing:border-box child of a hidden elem (or unconnected node) has accurate inner/outer/Width()/Height() see #10413", function() { - expect(16); +test( "box-sizing:border-box child of a hidden elem (or unconnected node) has accurate inner/outer/Width()/Height() see #10413", function() { + expect( 16 ); // setup html - var $divNormal = jQuery("<div>").css({ "boxSizing": "border-box", "width": "100px", "height": "100px", "border": "10px solid white", "padding": "2px", "margin": "3px" }), + var $divNormal = jQuery( "<div>" ).css( { "boxSizing": "border-box", "width": "100px", "height": "100px", "border": "10px solid white", "padding": "2px", "margin": "3px" } ), $divChild = $divNormal.clone(), $divUnconnected = $divNormal.clone(), - $divHiddenParent = jQuery("<div>").css( "display", "none" ).append( $divChild ).appendTo("body"); - $divNormal.appendTo("body"); + $divHiddenParent = jQuery( "<div>" ).css( "display", "none" ).append( $divChild ).appendTo( "body" ); + $divNormal.appendTo( "body" ); // tests that child div of a hidden div works the same as a normal div equal( $divChild.width(), $divNormal.width(), "child of a hidden element width() is wrong see #10413" ); equal( $divChild.innerWidth(), $divNormal.innerWidth(), "child of a hidden element innerWidth() is wrong see #10413" ); equal( $divChild.outerWidth(), $divNormal.outerWidth(), "child of a hidden element outerWidth() is wrong see #10413" ); - equal( $divChild.outerWidth(true), $divNormal.outerWidth( true ), "child of a hidden element outerWidth( true ) is wrong see #10413" ); + equal( $divChild.outerWidth( true ), $divNormal.outerWidth( true ), "child of a hidden element outerWidth( true ) is wrong see #10413" ); // Support: IE 10-11, Edge // Child height is not always decimal @@ -346,7 +346,7 @@ test("box-sizing:border-box child of a hidden elem (or unconnected node) has acc equal( $divUnconnected.width(), $divNormal.width(), "unconnected element width() is wrong see #10413" ); equal( $divUnconnected.innerWidth(), $divNormal.innerWidth(), "unconnected element innerWidth() is wrong see #10413" ); equal( $divUnconnected.outerWidth(), $divNormal.outerWidth(), "unconnected element outerWidth() is wrong see #10413" ); - equal( $divUnconnected.outerWidth(true), $divNormal.outerWidth( true ), "unconnected element outerWidth( true ) is wrong see #10413" ); + equal( $divUnconnected.outerWidth( true ), $divNormal.outerWidth( true ), "unconnected element outerWidth( true ) is wrong see #10413" ); // Support: IE 10-11, Edge // Child height is not always decimal @@ -358,9 +358,9 @@ test("box-sizing:border-box child of a hidden elem (or unconnected node) has acc // teardown html $divHiddenParent.remove(); $divNormal.remove(); -}); +} ); -test("outerHeight()", function() { +test( "outerHeight()", function() { expect( 11 ); var $div, div, @@ -387,7 +387,7 @@ test("outerHeight()", function() { equal( $div.outerHeight( true ), 94, "Test hidden div with padding, border and margin with margin option" ); // reset styles - $div.css({ "display": "", "border": "", "padding": "", "width": "", "height": "" }); + $div.css( { "display": "", "border": "", "padding": "", "width": "", "height": "" } ); div = jQuery( "<div>" ); @@ -396,20 +396,20 @@ test("outerHeight()", function() { div.remove(); QUnit.expectJqData( this, $div[ 0 ], "display" ); -}); +} ); -test("passing undefined is a setter #5571", function() { - expect(4); - equal(jQuery("#nothiddendiv").height(30).height(undefined).height(), 30, ".height(undefined) is chainable (#5571)"); - equal(jQuery("#nothiddendiv").height(30).innerHeight(undefined).height(), 30, ".innerHeight(undefined) is chainable (#5571)"); - equal(jQuery("#nothiddendiv").height(30).outerHeight(undefined).height(), 30, ".outerHeight(undefined) is chainable (#5571)"); - equal(jQuery("#nothiddendiv").width(30).width(undefined).width(), 30, ".width(undefined) is chainable (#5571)"); -}); +test( "passing undefined is a setter #5571", function() { + expect( 4 ); + equal( jQuery( "#nothiddendiv" ).height( 30 ).height( undefined ).height(), 30, ".height(undefined) is chainable (#5571)" ); + equal( jQuery( "#nothiddendiv" ).height( 30 ).innerHeight( undefined ).height(), 30, ".innerHeight(undefined) is chainable (#5571)" ); + equal( jQuery( "#nothiddendiv" ).height( 30 ).outerHeight( undefined ).height(), 30, ".outerHeight(undefined) is chainable (#5571)" ); + equal( jQuery( "#nothiddendiv" ).width( 30 ).width( undefined ).width(), 30, ".width(undefined) is chainable (#5571)" ); +} ); test( "getters on non elements should return null", function() { expect( 8 ); - var nonElem = jQuery("notAnElement"); + var nonElem = jQuery( "notAnElement" ); strictEqual( nonElem.width(), null, ".width() is not null (#12283)" ); strictEqual( nonElem.innerWidth(), null, ".innerWidth() is not null (#12283)" ); @@ -420,14 +420,14 @@ test( "getters on non elements should return null", function() { strictEqual( nonElem.innerHeight(), null, ".innerHeight() is not null (#12283)" ); strictEqual( nonElem.outerHeight(), null, ".outerHeight() is not null (#12283)" ); strictEqual( nonElem.outerHeight( true ), null, ".outerHeight(true) is not null (#12283)" ); -}); +} ); -test("setters with and without box-sizing:border-box", function(){ - expect(20); +test( "setters with and without box-sizing:border-box", function() { + expect( 20 ); // Support: Android 2.3 (-webkit-box-sizing). - var el_bb = jQuery("<div style='width:114px;height:114px;margin:5px;padding:3px;border:4px solid white;-webkit-box-sizing:border-box;box-sizing:border-box;'>test</div>").appendTo("#qunit-fixture"), - el = jQuery("<div style='width:100px;height:100px;margin:5px;padding:3px;border:4px solid white;'>test</div>").appendTo("#qunit-fixture"), + var el_bb = jQuery( "<div style='width:114px;height:114px;margin:5px;padding:3px;border:4px solid white;-webkit-box-sizing:border-box;box-sizing:border-box;'>test</div>" ).appendTo( "#qunit-fixture" ), + el = jQuery( "<div style='width:100px;height:100px;margin:5px;padding:3px;border:4px solid white;'>test</div>" ).appendTo( "#qunit-fixture" ), expected = 100; equal( el_bb.width( 101 ).width(), expected + 1, "test border-box width(int) by roundtripping" ); @@ -453,9 +453,10 @@ test("setters with and without box-sizing:border-box", function(){ equal( el.outerHeight( 117 ).height(), expected + 3, "test border-box outerHeight(int) by roundtripping" ); equal( el.outerHeight( 118, false ).height(), expected + 4, "test border-box outerHeight(int, false) by roundtripping" ); equal( el.outerHeight( 129, true ).height(), expected + 5, "test border-box innerHeight(int, true) by roundtripping" ); -}); +} ); testIframe( "dimensions/documentSmall", "window vs. small document", function( jQuery, window, document ) { + // this test is practically tautological, but there is a bug in IE8 // with no simple workaround, so this test exposes the bug and works around it if ( document.body.offsetWidth >= document.documentElement.offsetWidth ) { @@ -464,18 +465,19 @@ testIframe( "dimensions/documentSmall", "window vs. small document", function( j equal( jQuery( document ).height(), jQuery( window ).height(), "document height matches window height" ); equal( jQuery( document ).width(), jQuery( window ).width(), "document width matches window width" ); } else { + // all tests should have at least one assertion expect( 1 ); ok( true, "skipping test (conditions not satisfied)" ); } -}); +} ); testIframe( "dimensions/documentLarge", "window vs. large document", function( jQuery, window, document ) { - expect(2); + expect( 2 ); ok( jQuery( document ).height() > jQuery( window ).height(), "document height is larger than window height" ); ok( jQuery( document ).width() > jQuery( window ).width(), "document width is larger than window width" ); -}); +} ); test( "allow modification of coordinates argument (gh-1848)", function() { expect( 1 ); @@ -483,15 +485,15 @@ test( "allow modification of coordinates argument (gh-1848)", function() { var offsetTop, element = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ); - element.offset(function( index, coords ) { + element.offset( function( index, coords ) { coords.top = 100; return coords; - }); + } ); offsetTop = element.offset().top; - ok( Math.abs(offsetTop - 100) < 0.02, - "coordinates are modified (got offset.top: " + offsetTop + ")"); -}); + ok( Math.abs( offsetTop - 100 ) < 0.02, + "coordinates are modified (got offset.top: " + offsetTop + ")" ); +} ); -})(); +} )(); diff --git a/test/unit/effects.js b/test/unit/effects.js index cd367c11a..f4bd9c145 100644 --- a/test/unit/effects.js +++ b/test/unit/effects.js @@ -1,4 +1,4 @@ -(function() { +( function() { // Can't test what ain't there if ( !jQuery.fx ) { @@ -7,7 +7,7 @@ if ( !jQuery.fx ) { var oldRaf = window.requestAnimationFrame; -module("effects", { +module( "effects", { setup: function() { window.requestAnimationFrame = null; this.sandbox = sinon.sandbox.create(); @@ -23,48 +23,48 @@ module("effects", { window.requestAnimationFrame = oldRaf; return moduleTeardown.apply( this, arguments ); } -}); +} ); -test("sanity check", function() { - expect(1); - equal( jQuery("#dl:visible, #qunit-fixture:visible, #foo:visible").length, 3, "QUnit state is correct for testing effects" ); -}); +test( "sanity check", function() { + expect( 1 ); + equal( jQuery( "#dl:visible, #qunit-fixture:visible, #foo:visible" ).length, 3, "QUnit state is correct for testing effects" ); +} ); -test("show() basic", function() { +test( "show() basic", function() { expect( 1 ); - var div = jQuery("<div>").hide().appendTo("#qunit-fixture").show(); + var div = jQuery( "<div>" ).hide().appendTo( "#qunit-fixture" ).show(); - equal( div.css("display"), "block", "Make sure pre-hidden divs show" ); + equal( div.css( "display" ), "block", "Make sure pre-hidden divs show" ); // Clean up the detached node div.remove(); -}); +} ); -test("show()", function () { +test( "show()", function() { expect( 27 ); var div, speeds, test, displaysActual, displaysExpected, - hiddendiv = jQuery("div.hidden"); + hiddendiv = jQuery( "div.hidden" ); - equal(jQuery.css( hiddendiv[0], "display"), "none", "hiddendiv is display: none"); + equal( jQuery.css( hiddendiv[ 0 ], "display" ), "none", "hiddendiv is display: none" ); - hiddendiv.css("display", "block"); - equal(jQuery.css( hiddendiv[0], "display"), "block", "hiddendiv is display: block"); + hiddendiv.css( "display", "block" ); + equal( jQuery.css( hiddendiv[ 0 ], "display" ), "block", "hiddendiv is display: block" ); hiddendiv.show(); - equal(jQuery.css( hiddendiv[0], "display"), "block", "hiddendiv is display: block"); + equal( jQuery.css( hiddendiv[ 0 ], "display" ), "block", "hiddendiv is display: block" ); - hiddendiv.css("display",""); + hiddendiv.css( "display", "" ); displaysActual = []; displaysExpected = []; - div = jQuery("#fx-queue div").slice(0, 4); - div.show().each(function() { - notEqual(this.style.display, "none", "don't change any <div> with display block"); - }); + div = jQuery( "#fx-queue div" ).slice( 0, 4 ); + div.show().each( function() { + notEqual( this.style.display, "none", "don't change any <div> with display block" ); + } ); speeds = { "null speed": null, @@ -72,23 +72,23 @@ test("show()", function () { "false speed": false }; - jQuery.each(speeds, function(name, speed) { + jQuery.each( speeds, function( name, speed ) { var pass = true; - div.hide().show(speed).each(function() { + div.hide().show( speed ).each( function() { if ( this.style.display === "none" ) { pass = false; } - }); - ok( pass, "Show with " + name); - }); + } ); + ok( pass, "Show with " + name ); + } ); - jQuery.each(speeds, function(name, speed) { + jQuery.each( speeds, function( name, speed ) { var pass = true; - div.hide().show(speed, function() { + div.hide().show( speed, function() { pass = false; - }); + } ); ok( pass, "Show with " + name + " does not call animate callback" ); - }); + } ); // Tolerate data from show()/hide() QUnit.expectJqData( this, div, "display" ); @@ -101,39 +101,39 @@ test("show()", function () { "<table id='test-table'></table>" ).appendTo( "#qunit-fixture" ).find( "*" ).css( "display", "none" ); - jQuery("#test-table").remove(); + jQuery( "#test-table" ).remove(); test = { - "div" : "block", - "p" : "block", - "a" : "inline", - "code" : "inline", - "pre" : "block", - "span" : "inline", - "table" : "table", - "thead" : "table-header-group", - "tbody" : "table-row-group", - "tr" : "table-row", - "th" : "table-cell", - "td" : "table-cell", - "ul" : "block", - "li" : "list-item" + "div": "block", + "p": "block", + "a": "inline", + "code": "inline", + "pre": "block", + "span": "inline", + "table": "table", + "thead": "table-header-group", + "tbody": "table-row-group", + "tr": "table-row", + "th": "table-cell", + "td": "table-cell", + "ul": "block", + "li": "list-item" }; - jQuery.each(test, function(selector, expected) { - var elem = jQuery(selector, "#show-tests").show(); - equal( elem.css("display"), expected, "Show using correct display type for " + selector ); - }); + jQuery.each( test, function( selector, expected ) { + var elem = jQuery( selector, "#show-tests" ).show(); + equal( elem.css( "display" ), expected, "Show using correct display type for " + selector ); + } ); - jQuery("#show-tests").remove(); + jQuery( "#show-tests" ).remove(); // Make sure that showing or hiding a text node doesn't cause an error - jQuery("<div>test</div> text <span>test</span>").show().remove(); - jQuery("<div>test</div> text <span>test</span>").hide().remove(); -}); + jQuery( "<div>test</div> text <span>test</span>" ).show().remove(); + jQuery( "<div>test</div> text <span>test</span>" ).hide().remove(); +} ); -test("show(Number) - other displays", function() { - expect(30); +test( "show(Number) - other displays", function() { + expect( 30 ); jQuery( "<div id='show-tests'>" + @@ -145,103 +145,103 @@ test("show(Number) - other displays", function() { var test; - jQuery("#test-table").remove(); + jQuery( "#test-table" ).remove(); // Note: inline elements are expected to be inline-block // because we're showing width/height // Can't animate width/height inline // See #14344 test = { - "div" : "block", - "p" : "block", - "a" : "inline", - "code" : "inline", - "pre" : "block", - "span" : "inline", - "table" : "table", - "thead" : "table-header-group", - "tbody" : "table-row-group", - "tr" : "table-row", - "th" : "table-cell", - "td" : "table-cell", - "ul" : "block", - "li" : "list-item" + "div": "block", + "p": "block", + "a": "inline", + "code": "inline", + "pre": "block", + "span": "inline", + "table": "table", + "thead": "table-header-group", + "tbody": "table-row-group", + "tr": "table-row", + "th": "table-cell", + "td": "table-cell", + "ul": "block", + "li": "list-item" }; jQuery.each( test, function( selector ) { jQuery( selector, "#show-tests" ).show( 100 ); - }); + } ); this.clock.tick( 50 ); jQuery.each( test, function( selector, expected ) { - jQuery( selector, "#show-tests" ).each(function() { + jQuery( selector, "#show-tests" ).each( function() { equal( jQuery( this ).css( "display" ), expected === "inline" ? "inline-block" : expected, "Correct display type during animation for " + selector ); - }); - }); + } ); + } ); this.clock.tick( 50 ); jQuery.each( test, function( selector, expected ) { - jQuery( selector, "#show-tests" ).each(function() { + jQuery( selector, "#show-tests" ).each( function() { equal( jQuery( this ).css( "display" ), expected, "Correct display type after animation for " + selector ); - }); - }); + } ); + } ); - jQuery("#show-tests").remove(); -}); + jQuery( "#show-tests" ).remove(); +} ); // Supports #7397 -test("Persist correct display value", function() { - expect(3); +test( "Persist correct display value", function() { + expect( 3 ); jQuery( "<div id='show-tests'><span style='position:absolute;'>foo</span></div>" ) .appendTo( "#qunit-fixture" ).find( "*" ).css( "display", "none" ); - var $span = jQuery("#show-tests span"), - displayNone = $span.css("display"), + var $span = jQuery( "#show-tests span" ), + displayNone = $span.css( "display" ), display = "", clock = this.clock; $span.show(); - display = $span.css("display"); + display = $span.css( "display" ); $span.hide(); - $span.fadeIn(100, function() { - equal($span.css("display"), display, "Expecting display: " + display); - $span.fadeOut(100, function () { - equal($span.css("display"), displayNone, "Expecting display: " + displayNone); - $span.fadeIn(100, function() { - equal($span.css("display"), display, "Expecting display: " + display); - }); - }); - }); + $span.fadeIn( 100, function() { + equal( $span.css( "display" ), display, "Expecting display: " + display ); + $span.fadeOut( 100, function() { + equal( $span.css( "display" ), displayNone, "Expecting display: " + displayNone ); + $span.fadeIn( 100, function() { + equal( $span.css( "display" ), display, "Expecting display: " + display ); + } ); + } ); + } ); clock.tick( 300 ); QUnit.expectJqData( this, $span, "display" ); -}); +} ); -test("animate(Hash, Object, Function)", function() { - expect(1); - var hash = {opacity: "show"}, - hashCopy = jQuery.extend({}, hash); - jQuery("#foo").animate(hash, 0, function() { +test( "animate(Hash, Object, Function)", function() { + expect( 1 ); + var hash = { opacity: "show" }, + hashCopy = jQuery.extend( {}, hash ); + jQuery( "#foo" ).animate( hash, 0, function() { equal( hash.opacity, hashCopy.opacity, "Check if animate changed the hash parameter" ); - }); -}); + } ); +} ); -test("animate relative values", function() { +test( "animate relative values", function() { var value = 40, clock = this.clock, bases = [ "%", "px", "em" ], adjustments = [ "px", "em" ], - container = jQuery("<div></div>") - .css({ position: "absolute", height: "50em", width: "50em" }), + container = jQuery( "<div></div>" ) + .css( { position: "absolute", height: "50em", width: "50em" } ), animations = bases.length * adjustments.length; expect( 2 * animations ); @@ -250,13 +250,13 @@ test("animate relative values", function() { jQuery.each( adjustments, function( _, adjustUnit ) { var base = value + baseUnit, adjust = { height: "+=2" + adjustUnit, width: "-=2" + adjustUnit }, - elem = jQuery("<div></div>") - .appendTo( container.clone().appendTo("#qunit-fixture") ) - .css({ + elem = jQuery( "<div></div>" ) + .appendTo( container.clone().appendTo( "#qunit-fixture" ) ) + .css( { position: "absolute", height: base, width: value + adjustUnit - }), + } ), baseScale = elem[ 0 ].offsetHeight / value, adjustScale = elem[ 0 ].offsetWidth / value; @@ -266,89 +266,89 @@ test("animate relative values", function() { equal( this.offsetWidth, value * baseScale - 2 * adjustScale, baseUnit + "-=" + adjustUnit ); - }); + } ); clock.tick( 100 ); - }); - }); -}); + } ); + } ); +} ); -test("animate negative height", function() { - expect(1); - jQuery("#foo").animate({ height: -100 }, 100, function() { +test( "animate negative height", function() { + expect( 1 ); + jQuery( "#foo" ).animate( { height: -100 }, 100, function() { equal( this.offsetHeight, 0, "Verify height." ); - }); + } ); this.clock.tick( 100 ); -}); +} ); -test("animate negative margin", function() { - expect(1); - jQuery("#foo").animate({ "marginTop": -100 }, 100, function() { - equal( jQuery(this).css("marginTop"), "-100px", "Verify margin." ); - }); +test( "animate negative margin", function() { + expect( 1 ); + jQuery( "#foo" ).animate( { "marginTop": -100 }, 100, function() { + equal( jQuery( this ).css( "marginTop" ), "-100px", "Verify margin." ); + } ); this.clock.tick( 100 ); -}); +} ); -test("animate negative margin with px", function() { - expect(1); - jQuery("#foo").animate({ marginTop: "-100px" }, 100, function() { - equal( jQuery(this).css("marginTop"), "-100px", "Verify margin." ); - }); +test( "animate negative margin with px", function() { + expect( 1 ); + jQuery( "#foo" ).animate( { marginTop: "-100px" }, 100, function() { + equal( jQuery( this ).css( "marginTop" ), "-100px", "Verify margin." ); + } ); this.clock.tick( 100 ); -}); +} ); -test("animate negative padding", function() { - expect(1); - jQuery("#foo").animate({ "paddingBottom": -100 }, 100, function() { - equal( jQuery(this).css("paddingBottom"), "0px", "Verify paddingBottom." ); - }); +test( "animate negative padding", function() { + expect( 1 ); + jQuery( "#foo" ).animate( { "paddingBottom": -100 }, 100, function() { + equal( jQuery( this ).css( "paddingBottom" ), "0px", "Verify paddingBottom." ); + } ); this.clock.tick( 100 ); -}); +} ); -test("animate block as inline width/height", function() { - expect(3); +test( "animate block as inline width/height", function() { + expect( 3 ); - var span = jQuery("<span>").css("display", "inline-block").appendTo("body"); + var span = jQuery( "<span>" ).css( "display", "inline-block" ).appendTo( "body" ); span.remove(); - jQuery("#foo").css({ display: "inline", width: "", height: "" }).animate({ width: 42, height: 42 }, 100, function() { - equal( jQuery(this).css("display"), "inline-block", "inline-block was set on non-floated inline element when animating width/height" ); + jQuery( "#foo" ).css( { display: "inline", width: "", height: "" } ).animate( { width: 42, height: 42 }, 100, function() { + equal( jQuery( this ).css( "display" ), "inline-block", "inline-block was set on non-floated inline element when animating width/height" ); equal( this.offsetWidth, 42, "width was animated" ); equal( this.offsetHeight, 42, "height was animated" ); - }); + } ); this.clock.tick( 100 ); -}); +} ); -test("animate native inline width/height", function() { - expect(3); +test( "animate native inline width/height", function() { + expect( 3 ); - var span = jQuery("<span>").css("display", "inline-block").appendTo("body"); + var span = jQuery( "<span>" ).css( "display", "inline-block" ).appendTo( "body" ); span.remove(); - jQuery("#foo").css({ display: "", width: "", height: "" }) - .append("<span>text</span>") - .children("span") - .animate({ width: 42, height: 42 }, 100, function() { - equal( jQuery(this).css("display"), "inline-block", "inline-block was set on non-floated inline element when animating width/height" ); + jQuery( "#foo" ).css( { display: "", width: "", height: "" } ) + .append( "<span>text</span>" ) + .children( "span" ) + .animate( { width: 42, height: 42 }, 100, function() { + equal( jQuery( this ).css( "display" ), "inline-block", "inline-block was set on non-floated inline element when animating width/height" ); equal( this.offsetWidth, 42, "width was animated" ); equal( this.offsetHeight, 42, "height was animated" ); - }); + } ); this.clock.tick( 100 ); -}); +} ); test( "animate block width/height", function() { expect( 3 ); - jQuery("<div>").appendTo("#qunit-fixture").css({ + jQuery( "<div>" ).appendTo( "#qunit-fixture" ).css( { display: "block", width: 20, height: 20, paddingLeft: 60 - }).animate({ + } ).animate( { width: 42, height: 42 }, { @@ -359,78 +359,78 @@ test( "animate block width/height", function() { } }, complete: function() { - equal( jQuery( this ).css("display"), "block", "inline-block was not set on block element when animating width/height" ); + equal( jQuery( this ).css( "display" ), "block", "inline-block was not set on block element when animating width/height" ); equal( jQuery( this ).width(), 42, "width was animated" ); equal( jQuery( this ).height(), 42, "height was animated" ); } - }); + } ); this.clock.tick( 100 ); -}); +} ); test( "animate table width/height", function() { - expect(1); + expect( 1 ); - jQuery( "#table" ).animate({ width: 42, height: 42 }, 100, function() { + jQuery( "#table" ).animate( { width: 42, height: 42 }, 100, function() { equal( jQuery( this ).css( "display" ), "table", "display mode is correct" ); - }); + } ); this.clock.tick( 100 ); -}); +} ); -test("animate table-row width/height", function() { - expect(3); - var tr = jQuery("#table") - .attr({ "cellspacing": 0, "cellpadding": 0, "border": 0 }) - .html("<tr style='height:42px;'><td style='padding:0;'><div style='width:20px;height:20px;'></div></td></tr>") - .find("tr"); +test( "animate table-row width/height", function() { + expect( 3 ); + var tr = jQuery( "#table" ) + .attr( { "cellspacing": 0, "cellpadding": 0, "border": 0 } ) + .html( "<tr style='height:42px;'><td style='padding:0;'><div style='width:20px;height:20px;'></div></td></tr>" ) + .find( "tr" ); - tr.animate({ width: 10, height: 10 }, 100, function() { + tr.animate( { width: 10, height: 10 }, 100, function() { equal( jQuery( this ).css( "display" ), "table-row", "display mode is correct" ); equal( this.offsetWidth, 20, "width animated to shrink wrap point" ); equal( this.offsetHeight, 20, "height animated to shrink wrap point" ); - }); + } ); this.clock.tick( 100 ); -}); +} ); -test("animate table-cell width/height", function() { - expect(3); +test( "animate table-cell width/height", function() { + expect( 3 ); var td = jQuery( "#table" ) - .attr({ "cellspacing": 0, "cellpadding": 0, "border": 0 }) + .attr( { "cellspacing": 0, "cellpadding": 0, "border": 0 } ) .html( "<tr><td style='width:42px;height:42px;padding:0;'><div style='width:20px;height:20px;'></div></td></tr>" ) .find( "td" ); - td.animate({ width: 10, height: 10 }, 100, function() { + td.animate( { width: 10, height: 10 }, 100, function() { equal( jQuery( this ).css( "display" ), "table-cell", "display mode is correct" ); equal( this.offsetWidth, 20, "width animated to shrink wrap point" ); equal( this.offsetHeight, 20, "height animated to shrink wrap point" ); - }); + } ); this.clock.tick( 100 ); -}); +} ); -test("animate percentage(%) on width/height", function() { +test( "animate percentage(%) on width/height", function() { expect( 2 ); - var $div = jQuery("<div style='position:absolute;top:-999px;left:-999px;width:60px;height:60px;'><div style='width:50%;height:50%;'></div></div>") - .appendTo("#qunit-fixture").children("div"); + var $div = jQuery( "<div style='position:absolute;top:-999px;left:-999px;width:60px;height:60px;'><div style='width:50%;height:50%;'></div></div>" ) + .appendTo( "#qunit-fixture" ).children( "div" ); - $div.animate({ width: "25%", height: "25%" }, 13, function() { - var $this = jQuery(this); - equal( $this.css("width"), "15px", "Width was animated to 15px rather than 25px"); - equal( $this.css("height"), "15px", "Height was animated to 15px rather than 25px"); - }); + $div.animate( { width: "25%", height: "25%" }, 13, function() { + var $this = jQuery( this ); + equal( $this.css( "width" ), "15px", "Width was animated to 15px rather than 25px" ); + equal( $this.css( "height" ), "15px", "Height was animated to 15px rather than 25px" ); + } ); this.clock.tick( 20 ); -}); +} ); -test("animate resets overflow-x and overflow-y when finished", function() { - expect(2); - jQuery("#foo") - .css({ display: "block", width: 20, height: 20, overflowX: "visible", overflowY: "auto" }) - .animate({ width: 42, height: 42 }, 100, function() { +test( "animate resets overflow-x and overflow-y when finished", function() { + expect( 2 ); + jQuery( "#foo" ) + .css( { display: "block", width: 20, height: 20, overflowX: "visible", overflowY: "auto" } ) + .animate( { width: 42, height: 42 }, 100, function() { equal( this.style.overflowX, "visible", "overflow-x is visible" ); equal( this.style.overflowY, "auto", "overflow-y is auto" ); - }); + } ); this.clock.tick( 100 ); -}); +} ); /* // This test ends up being flaky depending upon the CPU load test("animate option (queue === false)", function () { @@ -457,7 +457,7 @@ test( "animate option { queue: false }", function() { expect( 2 ); var foo = jQuery( "#foo" ); - foo.animate({ + foo.animate( { fontSize: "2em" }, { queue: false, @@ -465,17 +465,17 @@ test( "animate option { queue: false }", function() { complete: function() { ok( true, "Animation Completed" ); } - }); + } ); this.clock.tick( 10 ); equal( foo.queue().length, 0, "Queue is empty" ); -}); +} ); test( "animate option { queue: true }", function() { expect( 2 ); var foo = jQuery( "#foo" ); - foo.animate({ + foo.animate( { fontSize: "2em" }, { queue: true, @@ -483,18 +483,18 @@ test( "animate option { queue: true }", function() { complete: function() { ok( true, "Animation Completed" ); } - }); + } ); notEqual( foo.queue().length, 0, "Default queue is not empty" ); //clear out existing timers before next test this.clock.tick( 10 ); -}); +} ); test( "animate option { queue: 'name' }", function() { expect( 5 ); var foo = jQuery( "#foo" ), - origWidth = parseFloat( foo.css("width") ), + origWidth = parseFloat( foo.css( "width" ) ), order = []; foo.animate( { width: origWidth + 100 }, { @@ -504,128 +504,127 @@ test( "animate option { queue: 'name' }", function() { // second callback function order.push( 2 ); - equal( parseFloat( foo.css("width") ), origWidth + 100, "Animation ended" ); - equal( foo.queue("name").length, 1, "Queue length of 'name' queue" ); + equal( parseFloat( foo.css( "width" ) ), origWidth + 100, "Animation ended" ); + equal( foo.queue( "name" ).length, 1, "Queue length of 'name' queue" ); } - }).queue( "name", function() { + } ).queue( "name", function() { // last callback function deepEqual( order, [ 1, 2 ], "Callbacks in expected order" ); - }); - + } ); // this is the first callback function that should be called order.push( 1 ); - equal( parseFloat( foo.css("width") ), origWidth, "Animation does not start on its own." ); - equal( foo.queue("name").length, 2, "Queue length of 'name' queue" ); + equal( parseFloat( foo.css( "width" ) ), origWidth, "Animation does not start on its own." ); + equal( foo.queue( "name" ).length, 2, "Queue length of 'name' queue" ); foo.dequeue( "name" ); this.clock.tick( 10 ); -}); +} ); -test("animate with no properties", function() { - expect(2); +test( "animate with no properties", function() { + expect( 2 ); var foo, - divs = jQuery("div"), + divs = jQuery( "div" ), count = 0; - divs.animate({}, function(){ + divs.animate( {}, function() { count++; - }); + } ); equal( divs.length, count, "Make sure that callback is called for each element in the set." ); + foo = jQuery( "#foo" ); - foo = jQuery("#foo"); - - foo.animate({}); - foo.animate({top: 10}, 100, function(){ + foo.animate( {} ); + foo.animate( { top: 10 }, 100, function() { ok( true, "Animation was properly dequeued." ); - }); + } ); this.clock.tick( 100 ); -}); - -test("animate duration 0", function() { - expect(11); +} ); +test( "animate duration 0", function() { + expect( 11 ); var $elem, - $elems = jQuery([{ a:0 },{ a:0 }]), + $elems = jQuery( [ { a:0 },{ a:0 } ] ), counter = 0; equal( jQuery.timers.length, 0, "Make sure no animation was running from another test" ); - $elems.eq(0).animate( {a:1}, 0, function(){ + $elems.eq( 0 ).animate( { a:1 }, 0, function() { ok( true, "Animate a simple property." ); counter++; - }); + } ); // Failed until [6115] equal( jQuery.timers.length, 0, "Make sure synchronic animations are not left on jQuery.timers" ); equal( counter, 1, "One synchronic animations" ); - $elems.animate( { a:2 }, 0, function(){ + $elems.animate( { a:2 }, 0, function() { ok( true, "Animate a second simple property." ); counter++; - }); + } ); equal( counter, 3, "Multiple synchronic animations" ); - $elems.eq(0).animate( {a:3}, 0, function(){ + $elems.eq( 0 ).animate( { a:3 }, 0, function() { ok( true, "Animate a third simple property." ); counter++; - }); - $elems.eq(1).animate( {a:3}, 200, function(){ + } ); + $elems.eq( 1 ).animate( { a:3 }, 200, function() { counter++; + // Failed until [6115] equal( counter, 5, "One synchronic and one asynchronic" ); - }); + } ); this.clock.tick( 200 ); - $elem = jQuery("<div />"); - $elem.show(0, function(){ - ok(true, "Show callback with no duration"); - }); - $elem.hide(0, function(){ - ok(true, "Hide callback with no duration"); - }); + $elem = jQuery( "<div />" ); + $elem.show( 0, function() { + ok( true, "Show callback with no duration" ); + } ); + $elem.hide( 0, function() { + ok( true, "Hide callback with no duration" ); + } ); // manually clean up detached elements $elem.remove(); -}); +} ); -test("animate hyphenated properties", function() { - expect(1); +test( "animate hyphenated properties", function() { + expect( 1 ); - jQuery("#foo") - .css("font-size", 10) - .animate({"font-size": 20}, 200, function() { + jQuery( "#foo" ) + .css( "font-size", 10 ) + .animate( { "font-size": 20 }, 200, function() { equal( this.style.fontSize, "20px", "The font-size property was animated." ); - }); + } ); + // FIXME why is this double only when run with other tests this.clock.tick( 400 ); -}); +} ); -test("animate non-element", function() { - expect(1); +test( "animate non-element", function() { + expect( 1 ); var obj = { test: 0 }; - jQuery(obj).animate({test: 200}, 200, function(){ + jQuery( obj ).animate( { test: 200 }, 200, function() { equal( obj.test, 200, "The custom property should be modified." ); - }); + } ); this.clock.tick( 200 ); -}); +} ); -test("stop()", function() { +test( "stop()", function() { expect( 4 ); var $one, $two, - $foo = jQuery("#foo"), + $foo = jQuery( "#foo" ), w = 0, nw; @@ -633,34 +632,35 @@ test("stop()", function() { .animate( { "width": "show" }, 1500 ); this.clock.tick( 100 ); - nw = $foo.css("width"); + nw = $foo.css( "width" ); notEqual( parseFloat( nw ), w, "An animation occurred " + nw + " " + w + "px" ); $foo.stop(); - nw = $foo.css("width"); + nw = $foo.css( "width" ); notEqual( parseFloat( nw ), w, "Stop didn't reset the animation " + nw + " " + w + "px" ); this.clock.tick( 100 ); $foo.removeData(); - $foo.removeData(undefined, true); - equal( nw, $foo.css("width"), "The animation didn't continue" ); + $foo.removeData( undefined, true ); + equal( nw, $foo.css( "width" ), "The animation didn't continue" ); - $one = jQuery("#fadein"); - $two = jQuery("#show"); - $one.fadeTo(100, 0, function() { + $one = jQuery( "#fadein" ); + $two = jQuery( "#show" ); + $one.fadeTo( 100, 0, function() { $one.stop(); - }); + } ); this.clock.tick( 100 ); - $two.fadeTo(100, 0, function() { - equal( $two.css("opacity"), "0", "Stop does not interfere with animations on other elements (#6641)" ); + $two.fadeTo( 100, 0, function() { + equal( $two.css( "opacity" ), "0", "Stop does not interfere with animations on other elements (#6641)" ); + // Reset styles - $one.add( $two ).css("opacity", ""); - }); + $one.add( $two ).css( "opacity", "" ); + } ); this.clock.tick( 100 ); -}); +} ); -test("stop() - several in queue", function() { +test( "stop() - several in queue", function() { expect( 5 ); var nw, $foo = jQuery( "#foo" ); @@ -668,9 +668,9 @@ test("stop() - several in queue", function() { // default duration is 400ms, so 800px ensures we aren't 0 or 1 after 1ms $foo.hide().css( "width", 800 ); - $foo.animate({ "width": "show" }, 400, "linear"); - $foo.animate({ "width": "hide" }); - $foo.animate({ "width": "show" }); + $foo.animate( { "width": "show" }, 400, "linear" ); + $foo.animate( { "width": "hide" } ); + $foo.animate( { "width": "show" } ); this.clock.tick( 1 ); @@ -688,119 +688,121 @@ test("stop() - several in queue", function() { $foo.stop( true ); equal( $foo.queue().length, 0, "0 in the queue" ); -}); +} ); -test("stop(clearQueue)", function() { - expect(4); +test( "stop(clearQueue)", function() { + expect( 4 ); - var $foo = jQuery("#foo"), + var $foo = jQuery( "#foo" ), w = 0, nw; - $foo.hide().css( "width", 200 ).css("width"); + $foo.hide().css( "width", 200 ).css( "width" ); - $foo.animate({ "width": "show" }, 1000); - $foo.animate({ "width": "hide" }, 1000); - $foo.animate({ "width": "show" }, 1000); + $foo.animate( { "width": "show" }, 1000 ); + $foo.animate( { "width": "hide" }, 1000 ); + $foo.animate( { "width": "show" }, 1000 ); this.clock.tick( 100 ); - nw = $foo.css("width"); - ok( parseFloat( nw ) !== w, "An animation occurred " + nw + " " + w + "px"); - $foo.stop(true); + nw = $foo.css( "width" ); + ok( parseFloat( nw ) !== w, "An animation occurred " + nw + " " + w + "px" ); + $foo.stop( true ); - nw = $foo.css("width"); - ok( parseFloat( nw ) !== w, "Stop didn't reset the animation " + nw + " " + w + "px"); + nw = $foo.css( "width" ); + ok( parseFloat( nw ) !== w, "Stop didn't reset the animation " + nw + " " + w + "px" ); equal( $foo.queue().length, 0, "The animation queue was cleared" ); this.clock.tick( 100 ); - equal( nw, $foo.css("width"), "The animation didn't continue" ); -}); + equal( nw, $foo.css( "width" ), "The animation didn't continue" ); +} ); -test("stop(clearQueue, gotoEnd)", function() { - expect(1); +test( "stop(clearQueue, gotoEnd)", function() { + expect( 1 ); - var $foo = jQuery("#foo"), + var $foo = jQuery( "#foo" ), w = 0, nw; - $foo.hide().css( "width", 200 ).css("width"); + $foo.hide().css( "width", 200 ).css( "width" ); - $foo.animate({ width: "show" }, 1000); - $foo.animate({ width: "hide" }, 1000); - $foo.animate({ width: "show" }, 1000); - $foo.animate({ width: "hide" }, 1000); + $foo.animate( { width: "show" }, 1000 ); + $foo.animate( { width: "hide" }, 1000 ); + $foo.animate( { width: "show" }, 1000 ); + $foo.animate( { width: "hide" }, 1000 ); this.clock.tick( 100 ); - nw = $foo.css("width"); - ok( parseFloat( nw ) !== w, "An animation occurred " + nw + " " + w + "px"); - $foo.stop(false, true); + nw = $foo.css( "width" ); + ok( parseFloat( nw ) !== w, "An animation occurred " + nw + " " + w + "px" ); + $foo.stop( false, true ); + + nw = $foo.css( "width" ); - nw = $foo.css("width"); // Disabled, being flaky //equal( nw, 1, "Stop() reset the animation" ); this.clock.tick( 100 ); + // Disabled, being flaky //equal( $foo.queue().length, 2, "The next animation continued" ); - $foo.stop(true); -}); + $foo.stop( true ); +} ); test( "stop( queue, ..., ... ) - Stop single queues", function() { expect( 3 ); var saved, - foo = jQuery("#foo").css({ width: 200, height: 200 }); + foo = jQuery( "#foo" ).css( { width: 200, height: 200 } ); - foo.animate({ + foo.animate( { width: 400 - },{ + }, { duration: 500, complete: function() { - equal( parseFloat( foo.css("width") ), 400, "Animation completed for standard queue" ); - equal( parseFloat( foo.css("height") ), saved, "Height was not changed after the second stop"); + equal( parseFloat( foo.css( "width" ) ), 400, "Animation completed for standard queue" ); + equal( parseFloat( foo.css( "height" ) ), saved, "Height was not changed after the second stop" ); } - }); + } ); - foo.animate({ + foo.animate( { height: 400 - },{ + }, { duration: 1000, queue: "height" - }).dequeue("height").stop( "height", false, true ); + } ).dequeue( "height" ).stop( "height", false, true ); - equal( parseFloat( foo.css("height") ), 400, "Height was stopped with gotoEnd" ); + equal( parseFloat( foo.css( "height" ) ), 400, "Height was stopped with gotoEnd" ); - foo.animate({ + foo.animate( { height: 200 - },{ + }, { duration: 1000, queue: "height" - }).dequeue( "height" ).stop( "height", false, false ); - saved = parseFloat( foo.css("height") ); + } ).dequeue( "height" ).stop( "height", false, false ); + saved = parseFloat( foo.css( "height" ) ); this.clock.tick( 500 ); -}); +} ); -test("toggle()", function() { - expect(6); - var x = jQuery("#foo"); - ok( x.is(":visible"), "is visible" ); +test( "toggle()", function() { + expect( 6 ); + var x = jQuery( "#foo" ); + ok( x.is( ":visible" ), "is visible" ); x.toggle(); - ok( x.is(":hidden"), "is hidden" ); + ok( x.is( ":hidden" ), "is hidden" ); x.toggle(); - ok( x.is(":visible"), "is visible again" ); - - x.toggle(true); - ok( x.is(":visible"), "is visible" ); - x.toggle(false); - ok( x.is(":hidden"), "is hidden" ); - x.toggle(true); - ok( x.is(":visible"), "is visible again" ); -}); + ok( x.is( ":visible" ), "is visible again" ); + + x.toggle( true ); + ok( x.is( ":visible" ), "is visible" ); + x.toggle( false ); + ok( x.is( ":hidden" ), "is hidden" ); + x.toggle( true ); + ok( x.is( ":visible" ), "is visible again" ); +} ); test( "jQuery.fx.prototype.cur() - <1.8 Back Compat", function() { expect( 7 ); - var div = jQuery( "<div></div>" ).appendTo( "#qunit-fixture" ).css({ + var div = jQuery( "<div></div>" ).appendTo( "#qunit-fixture" ).css( { color: "#ABC", border: "5px solid black", left: "auto", marginBottom: "-11000px" - })[0]; + } )[ 0 ]; equal( ( new jQuery.fx( div, {}, "color" ) ).cur(), @@ -846,31 +848,31 @@ test( "jQuery.fx.prototype.cur() - <1.8 Back Compat", function() { ); jQuery( div ).remove(); -}); +} ); -test("Overflow and Display", function() { - expect(4); +test( "Overflow and Display", function() { + expect( 4 ); var - testClass = jQuery.makeTest("Overflow and Display") - .addClass("overflow inline"), - testStyle = jQuery.makeTest("Overflow and Display (inline style)") - .css({ overflow: "visible", display: "inline" }), + testClass = jQuery.makeTest( "Overflow and Display" ) + .addClass( "overflow inline" ), + testStyle = jQuery.makeTest( "Overflow and Display (inline style)" ) + .css( { overflow: "visible", display: "inline" } ), done = function() { equal( jQuery.css( this, "overflow" ), "visible", "Overflow should be 'visible'" ); equal( jQuery.css( this, "display" ), "inline", "Display should be 'inline'" ); }; testClass.add( testStyle ) - .addClass("widewidth") - .text("Some sample text.") - .before("text before") - .after("text after") - .animate({ opacity: 0.5 }, "slow", done ); + .addClass( "widewidth" ) + .text( "Some sample text." ) + .before( "text before" ) + .after( "text after" ) + .animate( { opacity: 0.5 }, "slow", done ); this.clock.tick( 600 ); -}); +} ); -jQuery.each({ +jQuery.each( { "CSS Auto": function( elem, prop ) { jQuery( elem ).addClass( "auto" + prop ) .text( "This is a long string of text." ); @@ -906,7 +908,7 @@ jQuery.each({ return 0; } }, function( fn, f ) { - jQuery.each({ + jQuery.each( { "show": function( elem, prop ) { jQuery( elem ).hide().addClass( "wide" + prop ); return "show"; @@ -927,7 +929,7 @@ jQuery.each({ return 0; } }, function( tn, t ) { - test(fn + " to " + tn, function() { + test( fn + " to " + tn, function() { var num, anim, elem = jQuery.makeTest( fn + " to " + tn ), t_w = t( elem, "width" ), @@ -942,6 +944,7 @@ jQuery.each({ } num = 0; + // TODO: uncrowd this if ( t_h === "show" ) { num++; } if ( t_w === "show" ) { num++; } @@ -957,9 +960,9 @@ jQuery.each({ anim = { width: t_w, height: t_h, opacity: t_o }; - elem.animate(anim, 50); + elem.animate( anim, 50 ); - jQuery.when( elem ).done(function( $elem ) { + jQuery.when( elem ).done( function( $elem ) { var cur_o, cur_w, cur_h, old_h, elem = $elem[ 0 ]; @@ -976,9 +979,9 @@ jQuery.each({ ok( f_h === "" ? elem.style.height === f_h : elem.style.height.indexOf( f_h ) === 0, "Height must be reset to " + f_h + ": " + elem.style.height ); } - cur_o = jQuery.style(elem, "opacity"); + cur_o = jQuery.style( elem, "opacity" ); - if ( f_o !== jQuery.css(elem, "opacity") ) { + if ( f_o !== jQuery.css( elem, "opacity" ) ) { f_o = f( elem, "opacity" ); } @@ -987,6 +990,7 @@ jQuery.each({ if ( f_o === "" ) { f_o = 1; } + // See above if ( cur_o === "" ) { cur_o = 1; @@ -1003,13 +1007,13 @@ jQuery.each({ if ( t_o.constructor === Number ) { equal( cur_o, t_o, "Final opacity should be " + t_o + ": " + cur_o ); - ok( jQuery.css(elem, "opacity") !== "" || cur_o === t_o, "Opacity should be explicitly set to " + t_o + ", is instead: " + cur_o ); + ok( jQuery.css( elem, "opacity" ) !== "" || cur_o === t_o, "Opacity should be explicitly set to " + t_o + ", is instead: " + cur_o ); } if ( t_w.constructor === Number ) { equal( elem.style.width, t_w + "px", "Final width should be " + t_w + ": " + elem.style.width ); - cur_w = jQuery.css( elem,"width" ); + cur_w = jQuery.css( elem, "width" ); ok( elem.style.width !== "" || cur_w === t_w, "Width should be explicitly set to " + t_w + ", is instead: " + cur_w ); } @@ -1017,14 +1021,14 @@ jQuery.each({ if ( t_h.constructor === Number ) { equal( elem.style.height, t_h + "px", "Final height should be " + t_h + ": " + elem.style.height ); - cur_h = jQuery.css( elem,"height" ); + cur_h = jQuery.css( elem, "height" ); ok( elem.style.height !== "" || cur_h === t_h, "Height should be explicitly set to " + t_h + ", is instead: " + cur_h ); } if ( t_h === "show" ) { old_h = jQuery.css( elem, "height" ); - jQuery( elem ).append("<br/>Some more text<br/>and some more..."); + jQuery( elem ).append( "<br/>Some more text<br/>and some more..." ); if ( /Auto/.test( fn ) ) { notEqual( jQuery.css( elem, "height" ), old_h, "Make sure height is auto." ); @@ -1036,18 +1040,18 @@ jQuery.each({ // manually remove generated element jQuery( elem ).remove(); - }); + } ); this.clock.tick( 50 ); - }); - }); -}); + } ); + } ); +} ); -test("Effects chaining", function() { +test( "Effects chaining", function() { var remaining = 16, props = [ "opacity", "height", "width", "display", "overflow" ], setup = function( name, selector ) { var $el = jQuery( selector ); - return $el.data( getProps( $el[0] ) ).data( "name", name ); + return $el.data( getProps( $el[ 0 ] ) ).data( "name", name ); }, assert = function() { var data = jQuery.data( this ), @@ -1062,39 +1066,39 @@ test("Effects chaining", function() { var obj = {}; jQuery.each( props, function( i, prop ) { obj[ prop ] = prop === "overflow" && hiddenOverflow ? "hidden" : el.style[ prop ] || jQuery.css( el, prop ); - }); + } ); return obj; }; expect( remaining ); - setup( ".fadeOut().fadeIn()", "#fadein div" ).fadeOut("fast").fadeIn( "fast", assert ); - setup( ".fadeIn().fadeOut()", "#fadeout div" ).fadeIn("fast").fadeOut( "fast", assert ); - setup( ".hide().show()", "#show div" ).hide("fast").show( "fast", assert ); - setup( ".show().hide()", "#hide div" ).show("fast").hide( "fast", assert ); - setup( ".show().hide(easing)", "#easehide div" ).show("fast").hide( "fast", "linear", assert ); - setup( ".toggle().toggle() - in", "#togglein div" ).toggle("fast").toggle( "fast", assert ); - setup( ".toggle().toggle() - out", "#toggleout div" ).toggle("fast").toggle( "fast", assert ); - setup( ".toggle().toggle(easing) - out", "#easetoggleout div" ).toggle("fast").toggle( "fast", "linear", assert ); - setup( ".slideDown().slideUp()", "#slidedown div" ).slideDown("fast").slideUp( "fast", assert ); - setup( ".slideUp().slideDown()", "#slideup div" ).slideUp("fast").slideDown( "fast", assert ); - setup( ".slideUp().slideDown(easing)", "#easeslideup div" ).slideUp("fast").slideDown( "fast", "linear", assert ); - setup( ".slideToggle().slideToggle() - in", "#slidetogglein div" ).slideToggle("fast").slideToggle( "fast", assert ); - setup( ".slideToggle().slideToggle() - out", "#slidetoggleout div" ).slideToggle("fast").slideToggle( "fast", assert ); - setup( ".fadeToggle().fadeToggle() - in", "#fadetogglein div" ).fadeToggle("fast").fadeToggle( "fast", assert ); - setup( ".fadeToggle().fadeToggle() - out", "#fadetoggleout div" ).fadeToggle("fast").fadeToggle( "fast", assert ); + setup( ".fadeOut().fadeIn()", "#fadein div" ).fadeOut( "fast" ).fadeIn( "fast", assert ); + setup( ".fadeIn().fadeOut()", "#fadeout div" ).fadeIn( "fast" ).fadeOut( "fast", assert ); + setup( ".hide().show()", "#show div" ).hide( "fast" ).show( "fast", assert ); + setup( ".show().hide()", "#hide div" ).show( "fast" ).hide( "fast", assert ); + setup( ".show().hide(easing)", "#easehide div" ).show( "fast" ).hide( "fast", "linear", assert ); + setup( ".toggle().toggle() - in", "#togglein div" ).toggle( "fast" ).toggle( "fast", assert ); + setup( ".toggle().toggle() - out", "#toggleout div" ).toggle( "fast" ).toggle( "fast", assert ); + setup( ".toggle().toggle(easing) - out", "#easetoggleout div" ).toggle( "fast" ).toggle( "fast", "linear", assert ); + setup( ".slideDown().slideUp()", "#slidedown div" ).slideDown( "fast" ).slideUp( "fast", assert ); + setup( ".slideUp().slideDown()", "#slideup div" ).slideUp( "fast" ).slideDown( "fast", assert ); + setup( ".slideUp().slideDown(easing)", "#easeslideup div" ).slideUp( "fast" ).slideDown( "fast", "linear", assert ); + setup( ".slideToggle().slideToggle() - in", "#slidetogglein div" ).slideToggle( "fast" ).slideToggle( "fast", assert ); + setup( ".slideToggle().slideToggle() - out", "#slidetoggleout div" ).slideToggle( "fast" ).slideToggle( "fast", assert ); + setup( ".fadeToggle().fadeToggle() - in", "#fadetogglein div" ).fadeToggle( "fast" ).fadeToggle( "fast", assert ); + setup( ".fadeToggle().fadeToggle() - out", "#fadetoggleout div" ).fadeToggle( "fast" ).fadeToggle( "fast", assert ); setup( ".fadeTo(0.5).fadeTo(1.0, easing)", "#fadeto div" ).fadeTo( "fast", 0.5 ).fadeTo( "fast", 1.0, "linear", assert ); this.clock.tick( 400 ); -}); +} ); -jQuery.makeTest = function( text ){ - var elem = jQuery("<div></div>") +jQuery.makeTest = function( text ) { + var elem = jQuery( "<div></div>" ) .attr( "id", "test" + jQuery.makeTest.id++ ) - .addClass("box"); + .addClass( "box" ); - jQuery("<h4></h4>") + jQuery( "<h4></h4>" ) .text( text ) - .appendTo("#fx-tests") + .appendTo( "#fx-tests" ) .after( elem ); return elem; @@ -1102,18 +1106,18 @@ jQuery.makeTest = function( text ){ jQuery.makeTest.id = 1; -test("jQuery.show('fast') doesn't clear radio buttons (bug #1095)", function () { - expect(4); +test( "jQuery.show('fast') doesn't clear radio buttons (bug #1095)", function() { + expect( 4 ); - var $checkedtest = jQuery("#checkedtest"); - $checkedtest.hide().show("fast", function() { - ok( jQuery("input[type='radio']", $checkedtest).first().attr("checked"), "Check first radio still checked." ); - ok( !jQuery("input[type='radio']", $checkedtest).last().attr("checked"), "Check last radio still NOT checked." ); - ok( jQuery("input[type='checkbox']", $checkedtest).first().attr("checked"), "Check first checkbox still checked." ); - ok( !jQuery("input[type='checkbox']", $checkedtest).last().attr("checked"), "Check last checkbox still NOT checked." ); - }); + var $checkedtest = jQuery( "#checkedtest" ); + $checkedtest.hide().show( "fast", function() { + ok( jQuery( "input[type='radio']", $checkedtest ).first().attr( "checked" ), "Check first radio still checked." ); + ok( !jQuery( "input[type='radio']", $checkedtest ).last().attr( "checked" ), "Check last radio still NOT checked." ); + ok( jQuery( "input[type='checkbox']", $checkedtest ).first().attr( "checked" ), "Check first checkbox still checked." ); + ok( !jQuery( "input[type='checkbox']", $checkedtest ).last().attr( "checked" ), "Check last checkbox still NOT checked." ); + } ); this.clock.tick( 200 ); -}); +} ); test( "interrupt toggle", function() { expect( 24 ); @@ -1122,13 +1126,14 @@ test( "interrupt toggle", function() { longDuration = 2000, shortDuration = 500, remaining = 0, - $elems = jQuery(".chain-test"), + $elems = jQuery( ".chain-test" ), clock = this.clock, finish = function() { }; jQuery.each( { slideToggle: "height", fadeToggle: "opacity", toggle: "width" }, function( method, prop ) { - var $methodElems = $elems.filter( "[id^='" + method.toLowerCase() + "']" ).each(function() { + var $methodElems = $elems.filter( "[id^='" + method.toLowerCase() + "']" ).each( function() { + // Don't end test until we're done with this element remaining++; @@ -1137,28 +1142,28 @@ test( "interrupt toggle", function() { // Expect display data from our .hide() call below QUnit.expectJqData( env, this, "display" ); - }); + } ); // Interrupt a hiding toggle $methodElems[ method ]( longDuration ); - setTimeout(function() { - $methodElems.stop().each(function() { + setTimeout( function() { + $methodElems.stop().each( function() { notEqual( jQuery( this ).css( prop ), jQuery.data( this, "startVal" ), ".stop() before completion of hiding ." + method + "() - #" + this.id ); - }); + } ); // Restore $methodElems[ method ]( shortDuration, function() { var id = this.id, $elem = jQuery( this ), - startVal = $elem.data("startVal"); + startVal = $elem.data( "startVal" ); - $elem.removeData("startVal"); + $elem.removeData( "startVal" ); equal( $elem.css( prop ), startVal, "original value restored by ." + method + "() - #" + id ); // Interrupt a showing toggle $elem.hide()[ method ]( longDuration ); - setTimeout(function() { + setTimeout( function() { $elem.stop(); notEqual( $elem.css( prop ), startVal, ".stop() before completion of showing ." + method + "() - #" + id ); @@ -1166,15 +1171,15 @@ test( "interrupt toggle", function() { $elem[ method ]( shortDuration, function() { equal( $elem.css( prop ), startVal, "original value restored by ." + method + "() - #" + id ); finish(); - }); + } ); }, shortDuration ); - }); + } ); }, shortDuration ); - }); + } ); clock.tick( longDuration ); // FIXME untangle the set timeouts -}); +} ); test( "animate with per-property easing", function() { @@ -1211,34 +1216,34 @@ test( "animate with per-property easing", function() { ok( defaultTestCalled, "Easing function (_default) called" ); equal( props.a[ 1 ], "_test1", "animate does not change original props (per-property easing would be lost)" ); equal( props.b[ 1 ], "_test2", "animate does not change original props (per-property easing would be lost)" ); - }); + } ); this.clock.tick( 400 ); -}); +} ); -test("animate with CSS shorthand properties", function(){ - expect(11); +test( "animate with CSS shorthand properties", function() { + expect( 11 ); var easeAnimation_count = 0, easeProperty_count = 0, propsBasic = { "padding": "10 20 30" }, propsSpecial = { "padding": [ "1 2 3", "propertyScope" ] }; - jQuery.easing.animationScope = function(p) { + jQuery.easing.animationScope = function( p ) { if ( p >= 1 ) { easeAnimation_count++; } return p; }; - jQuery.easing.propertyScope = function(p) { + jQuery.easing.propertyScope = function( p ) { if ( p >= 1 ) { easeProperty_count++; } return p; }; - jQuery("#foo") + jQuery( "#foo" ) .animate( propsBasic, 200, "animationScope", function() { equal( this.style.paddingTop, "10px", "padding-top was animated" ); equal( this.style.paddingLeft, "20px", "padding-left was animated" ); @@ -1246,7 +1251,7 @@ test("animate with CSS shorthand properties", function(){ equal( this.style.paddingBottom, "30px", "padding-bottom was animated" ); equal( easeAnimation_count, 4, "per-animation default easing called for each property" ); easeAnimation_count = 0; - }) + } ) .animate( propsSpecial, 200, "animationScope", function() { equal( this.style.paddingTop, "1px", "padding-top was animated again" ); equal( this.style.paddingLeft, "2px", "padding-left was animated again" ); @@ -1255,38 +1260,37 @@ test("animate with CSS shorthand properties", function(){ equal( easeAnimation_count, 0, "per-animation default easing not called" ); equal( easeProperty_count, 4, "special easing called for each property" ); - jQuery(this).css("padding", "0"); + jQuery( this ).css( "padding", "0" ); delete jQuery.easing.animationScope; delete jQuery.easing.propertyScope; - }); + } ); this.clock.tick( 400 ); -}); - -test("hide hidden elements, with animation (bug #7141)", function() { - expect(3); +} ); +test( "hide hidden elements, with animation (bug #7141)", function() { + expect( 3 ); - var div = jQuery("<div style='display:none'></div>").appendTo("#qunit-fixture"); - equal( div.css("display"), "none", "Element is hidden by default" ); - div.hide(1, function () { - ok( !jQuery._data(div, "display"), "display data is undefined after hiding an already-hidden element" ); - div.show(1, function () { - equal( div.css("display"), "block", "Show a double-hidden element" ); - }); - }); + var div = jQuery( "<div style='display:none'></div>" ).appendTo( "#qunit-fixture" ); + equal( div.css( "display" ), "none", "Element is hidden by default" ); + div.hide( 1, function() { + ok( !jQuery._data( div, "display" ), "display data is undefined after hiding an already-hidden element" ); + div.show( 1, function() { + equal( div.css( "display" ), "block", "Show a double-hidden element" ); + } ); + } ); this.clock.tick( 10 ); -}); +} ); -test("animate unit-less properties (#4966)", function() { +test( "animate unit-less properties (#4966)", function() { expect( 2 ); var div = jQuery( "<div style='z-index: 0; position: absolute;'></div>" ).appendTo( "#qunit-fixture" ); equal( div.css( "z-index" ), "0", "z-index is 0" ); - div.animate({ zIndex: 2 }, function() { + div.animate( { zIndex: 2 }, function() { equal( div.css( "z-index" ), "2", "z-index is 2" ); - }); + } ); this.clock.tick( 400 ); -}); +} ); test( "animate properties missing px w/ opacity as last (#9074)", function() { expect( 2 ); @@ -1300,11 +1304,11 @@ test( "animate properties missing px w/ opacity as last (#9074)", function() { } equal( cssInt( "marginLeft" ), 0, "Margin left is 0" ); equal( cssInt( "left" ), 0, "Left is 0" ); - div.animate({ + div.animate( { left: 200, marginLeft: 200, opacity: 0 - }, 2000); + }, 2000 ); this.clock.tick( 500 ); @@ -1315,26 +1319,27 @@ test( "animate properties missing px w/ opacity as last (#9074)", function() { notEqual( l, 0, "Left is not 0 after partial animate" ); notEqual( l, 200, "Left is not 200 after partial animate" ); div.stop().remove(); -}); +} ); -test("callbacks should fire in correct order (#9100)", function() { +test( "callbacks should fire in correct order (#9100)", function() { expect( 1 ); var a = 1, cb = 0; - jQuery("<p data-operation='*2'></p><p data-operation='^2'></p>") - .appendTo("#qunit-fixture") + jQuery( "<p data-operation='*2'></p><p data-operation='^2'></p>" ) + .appendTo( "#qunit-fixture" ) + // The test will always pass if no properties are animated or if the duration is 0 - .animate({ fontSize: 12 }, 13, function() { - a *= jQuery(this).data("operation") === "*2" ? 2 : a; + .animate( { fontSize: 12 }, 13, function() { + a *= jQuery( this ).data( "operation" ) === "*2" ? 2 : a; cb++; if ( cb === 2 ) { - equal( a, 4, "test value has been *2 and _then_ ^2"); + equal( a, 4, "test value has been *2 and _then_ ^2" ); } - }); + } ); this.clock.tick( 20 ); -}); +} ); test( "callbacks that throw exceptions will be removed (#5684)", function() { expect( 2 ); @@ -1344,9 +1349,9 @@ test( "callbacks that throw exceptions will be removed (#5684)", function() { function TestException() { } - foo.animate({ height: 1 }, 1, function() { + foo.animate( { height: 1 }, 1, function() { throw new TestException(); - }); + } ); // this test thoroughly abuses undocumented methods - please feel free to update // with any changes internally to these functions. @@ -1362,39 +1367,40 @@ test( "callbacks that throw exceptions will be removed (#5684)", function() { ok( true, "Test completed without throwing a second exception" ); -}); +} ); -test("animate will scale margin properties individually", function() { +test( "animate will scale margin properties individually", function() { expect( 2 ); - var foo = jQuery( "#foo" ).css({ + var foo = jQuery( "#foo" ).css( { "margin": 0, "marginLeft": 100 - }); + } ); ok( foo.css( "marginLeft" ) !== foo.css( "marginRight" ), "Sanity Check" ); - foo.animate({ + foo.animate( { "margin": 200 - }).stop(); + } ).stop(); - ok( foo.css( "marginLeft") !== foo.css( "marginRight" ), "The margin properties are different"); + ok( foo.css( "marginLeft" ) !== foo.css( "marginRight" ), "The margin properties are different" ); // clean up for next test - foo.css({ + foo.css( { "marginLeft": "", "marginRight": "", "marginTop": "", "marginBottom": "" - }); -}); + } ); +} ); -test("Do not append px to 'fill-opacity' #9548", function() { +test( "Do not append px to 'fill-opacity' #9548", function() { expect( 1 ); - var $div = jQuery("<div>").appendTo("#qunit-fixture"); + var $div = jQuery( "<div>" ).appendTo( "#qunit-fixture" ); + + $div.css( "fill-opacity", 0 ).animate( { "fill-opacity": 1.0 }, 0, function() { - $div.css("fill-opacity", 0).animate({ "fill-opacity": 1.0 }, 0, function () { // Support: Android 2.3 (no support for fill-opacity) if ( jQuery( this ).css( "fill-opacity" ) ) { equal( jQuery( this ).css( "fill-opacity" ), 1, "Do not append px to 'fill-opacity'" ); @@ -1402,10 +1408,10 @@ test("Do not append px to 'fill-opacity' #9548", function() { ok( true, "No support for fill-opacity CSS property" ); } $div.remove(); - }); -}); + } ); +} ); -test("line-height animates correctly (#13855)", function() { +test( "line-height animates correctly (#13855)", function() { expect( 12 ); var t0, @@ -1417,22 +1423,22 @@ test("line-height animates correctly (#13855)", function() { "<p style='line-height: 5000px;'>px</p>" + "<p style='line-height: 5000%;'>percent</p>" + "<p style='line-height: 100em;'>em</p>" - ).appendTo("#qunit-fixture"), + ).appendTo( "#qunit-fixture" ), initialHeight = jQuery.map( animated, function( el ) { return jQuery( el ).height(); - }), + } ), tolerance = 1.5; // Delay start to improve test stability - setTimeout(function() { + setTimeout( function() { - t0 = +(new Date()); + t0 = +( new Date() ); animated.animate( { "line-height": "hide" }, longDuration, "linear" ); - setTimeout(function() { - var progress = ( (new Date()) - t0 ) / longDuration; + setTimeout( function() { + var progress = ( ( new Date() ) - t0 ) / longDuration; - animated.each(function( i ) { + animated.each( function( i ) { var label = jQuery.text( this ), initial = initialHeight[ i ], height = jQuery( this ).height(), @@ -1441,32 +1447,32 @@ test("line-height animates correctly (#13855)", function() { height + " < " + initial + " @ " + ( progress * 100 ) + "%" ); ok( height > lower, "hide " + label + ": lower bound; " + height + " > " + lower + " @ " + ( progress * 100 ) + "%" ); - }); + } ); - t0 = +(new Date()); + t0 = +( new Date() ); animated.stop( true, true ).hide() .animate( { "line-height": "show" }, longDuration, "linear" ); - setTimeout(function() { - var progress = ( (new Date()) - t0 ) / longDuration; + setTimeout( function() { + var progress = ( ( new Date() ) - t0 ) / longDuration; - animated.each(function( i ) { + animated.each( function( i ) { var label = jQuery.text( this ), initial = initialHeight[ i ], height = jQuery( this ).height(), upper = initial * progress * tolerance; ok( height < upper, "show " + label + ": upper bound; " + height + " < " + upper + " @ " + ( progress * 100 ) + "%" ); - }); + } ); animated.stop( true, true ); }, shortDuration ); -clock.tick(shortDuration); +clock.tick( shortDuration ); }, shortDuration ); -clock.tick(shortDuration); +clock.tick( shortDuration ); }, 50 ); clock.tick( 50 ); -}); +} ); // Start 1.8 Animation tests test( "jQuery.Animation( object, props, opts )", function() { @@ -1484,23 +1490,23 @@ test( "jQuery.Animation( object, props, opts )", function() { "width": 200 }; - animation = jQuery.Animation( testObject, testDest, { "duration": 1 }); - animation.done(function() { + animation = jQuery.Animation( testObject, testDest, { "duration": 1 } ); + animation.done( function() { for ( var prop in testDest ) { equal( testObject[ prop ], testDest[ prop ], "Animated: " + prop ); } - animation.done(function() { + animation.done( function() { deepEqual( testObject, testDest, "No unexpected properties" ); - }); - }); + } ); + } ); this.clock.tick( 10 ); -}); +} ); test( "Animate Option: step: function( percent, tween )", function() { expect( 1 ); var counter = {}; - jQuery( "#foo" ).animate({ + jQuery( "#foo" ).animate( { prop1: 1, prop2: 2, prop3: 3 @@ -1508,37 +1514,38 @@ test( "Animate Option: step: function( percent, tween )", function() { duration: 1, step: function( value, tween ) { var calls = counter[ tween.prop ] = counter[ tween.prop ] || []; + // in case this is called multiple times for either, lets store it in // 0 or 1 in the array calls[ value === 0 ? 0 : 1 ] = value; } - }).queue( function( next ) { + } ).queue( function( next ) { deepEqual( counter, { - prop1: [0, 1], - prop2: [0, 2], - prop3: [0, 3] - }, "Step function was called once at 0% and once at 100% for each property"); + prop1: [ 0, 1 ], + prop2: [ 0, 2 ], + prop3: [ 0, 3 ] + }, "Step function was called once at 0% and once at 100% for each property" ); next(); - }); + } ); this.clock.tick( 10 ); -}); +} ); test( "Animate callbacks have correct context", function() { expect( 2 ); var foo = jQuery( "#foo" ); - foo.animate({ + foo.animate( { height: 10 }, 10, function() { equal( foo[ 0 ], this, "Complete callback after stop(true) `this` is element" ); - }).stop( true, true ); - foo.animate({ + } ).stop( true, true ); + foo.animate( { height: 100 }, 10, function() { equal( foo[ 0 ], this, "Complete callback `this` is element" ); - }); + } ); this.clock.tick( 10 ); -}); +} ); test( "User supplied callback called after show when fx off (#8892)", function() { expect( 2 ); @@ -1551,10 +1558,10 @@ test( "User supplied callback called after show when fx off (#8892)", function() foo.fadeOut( 500, function() { ok( jQuery( this ).is( ":hidden" ), "Element is hidden in callback" ); jQuery.fx.off = false; - }); - }); + } ); + } ); this.clock.tick( 1000 ); -}); +} ); test( "animate should set display for disconnected nodes", function() { expect( 20 ); @@ -1566,18 +1573,18 @@ test( "animate should set display for disconnected nodes", function() { fadeTo: [ "fast", 0.5 ], slideDown: [ "fast" ], show: [ 1 ], - animate: [{ width: "show" }] + animate: [ { width: "show" } ] }, - $divEmpty = jQuery("<div/>"), - $divTest = jQuery("<div>test</div>"), - $divNone = jQuery("<div style='display: none;'/>"), - $divInline = jQuery("<div style='display: inline;'/>"), - nullParentDisplay = $divEmpty.css("display"), - underFragmentDisplay = $divTest.css("display"), + $divEmpty = jQuery( "<div/>" ), + $divTest = jQuery( "<div>test</div>" ), + $divNone = jQuery( "<div style='display: none;'/>" ), + $divInline = jQuery( "<div style='display: inline;'/>" ), + nullParentDisplay = $divEmpty.css( "display" ), + underFragmentDisplay = $divTest.css( "display" ), clock = this.clock; strictEqual( $divEmpty[ 0 ].parentNode, null, "Setup: element with null parentNode" ); - strictEqual( ($divTest[ 0 ].parentNode || {}).nodeType, 11, "Setup: element under fragment" ); + strictEqual( ( $divTest[ 0 ].parentNode || {} ).nodeType, 11, "Setup: element under fragment" ); strictEqual( $divEmpty.show()[ 0 ].style.display, "", "set display with show() for element with null parentNode" ); @@ -1589,54 +1596,54 @@ test( "animate should set display for disconnected nodes", function() { "show() should not change display if it already set" ); jQuery.each( methods, function( name, opt ) { - jQuery.fn[ name ].apply( jQuery("<div/>"), opt.concat( [ function() { + jQuery.fn[ name ].apply( jQuery( "<div/>" ), opt.concat( [ function() { strictEqual( jQuery( this ).css( "display" ), nullParentDisplay, "." + name + " block with null parentNode" ); } ] ) ); - jQuery.fn[ name ].apply( jQuery("<div>test</div>"), opt.concat( [ function() { + jQuery.fn[ name ].apply( jQuery( "<div>test</div>" ), opt.concat( [ function() { strictEqual( jQuery( this ).css( "display" ), underFragmentDisplay, "." + name + " block under fragment" ); } ] ) ); - }); + } ); clock.tick( 400 ); -}); +} ); -test("Animation callback should not show animated element as :animated (#7157)", function() { +test( "Animation callback should not show animated element as :animated (#7157)", function() { expect( 1 ); var foo = jQuery( "#foo" ); - foo.animate({ + foo.animate( { opacity: 0 }, 100, function() { - ok( !foo.is(":animated"), "The element is not animated" ); - }); + ok( !foo.is( ":animated" ), "The element is not animated" ); + } ); this.clock.tick( 100 ); -}); +} ); -test("Initial step callback should show element as :animated (#14623)", function() { +test( "Initial step callback should show element as :animated (#14623)", function() { expect( 1 ); var foo = jQuery( "#foo" ); - foo.animate({ + foo.animate( { opacity: 0 }, { duration: 100, step: function() { - ok( foo.is(":animated"), "The element matches :animated inside step function" ); + ok( foo.is( ":animated" ), "The element matches :animated inside step function" ); } - }); + } ); this.clock.tick( 1 ); foo.stop(); -}); +} ); test( "hide called on element within hidden parent should set display to none (#10045)", function() { expect( 3 ); - var hidden = jQuery(".hidden"), - elems = jQuery("<div>hide</div><div>hide0</div><div>hide1</div>"); + var hidden = jQuery( ".hidden" ), + elems = jQuery( "<div>hide</div><div>hide0</div><div>hide1</div>" ); hidden.append( elems ); @@ -1644,25 +1651,25 @@ test( "hide called on element within hidden parent should set display to none (# elems.eq( 0 ).hide(), elems.eq( 1 ).hide( 0 ), elems.eq( 2 ).hide( 1 ) - ).done(function() { + ).done( function() { strictEqual( elems.get( 0 ).style.display, "none", "hide() called on element within hidden parent should set display to none" ); strictEqual( elems.get( 1 ).style.display, "none", "hide( 0 ) called on element within hidden parent should set display to none" ); strictEqual( elems.get( 2 ).style.display, "none", "hide( 1 ) called on element within hidden parent should set display to none" ); elems.remove(); - }); + } ); this.clock.tick( 10 ); -}); +} ); test( "hide, fadeOut and slideUp called on element width height and width = 0 should set display to none", function() { expect( 5 ); - var foo = jQuery("#foo"), + var foo = jQuery( "#foo" ), i = 0, elems = jQuery(); for ( ; i < 5; i++ ) { - elems = elems.add("<div style='width:0;height:0;'></div>"); + elems = elems.add( "<div style='width:0;height:0;'></div>" ); } foo.append( elems ); @@ -1673,7 +1680,7 @@ test( "hide, fadeOut and slideUp called on element width height and width = 0 sh elems.eq( 2 ).hide( 1 ), elems.eq( 3 ).fadeOut(), elems.eq( 4 ).slideUp() - ).done(function() { + ).done( function() { strictEqual( elems.get( 0 ).style.display, "none", "hide() called on element width height and width = 0 should set display to none" ); strictEqual( elems.get( 1 ).style.display, "none", "hide( jQuery.noop ) called on element width height and width = 0 should set display to none" ); @@ -1681,24 +1688,24 @@ test( "hide, fadeOut and slideUp called on element width height and width = 0 sh strictEqual( elems.get( 3 ).style.display, "none", "fadeOut() called on element width height and width = 0 should set display to none" ); strictEqual( elems.get( 4 ).style.display, "none", "slideUp() called on element width height and width = 0 should set display to none" ); - }); + } ); this.clock.tick( 400 ); -}); +} ); test( "hide should not leave hidden inline elements visible (#14848)", function() { expect( 2 ); - var el = jQuery("#simon1"); + var el = jQuery( "#simon1" ); el.hide( 1, function() { equal( el.css( "display" ), "none", "hidden" ); el.hide( 1, function() { equal( el.css( "display" ), "none", "still hidden" ); - }); - }); + } ); + } ); this.clock.tick( 100 ); -}); +} ); test( "Handle queue:false promises", function() { expect( 10 ); @@ -1706,7 +1713,7 @@ test( "Handle queue:false promises", function() { var foo = jQuery( "#foo" ).clone().addBack(), step = 1; - foo.animate({ + foo.animate( { top: 1 }, { duration: 10, @@ -1714,7 +1721,7 @@ test( "Handle queue:false promises", function() { complete: function() { ok( step++ <= 2, "Step one or two" ); } - }).animate({ + } ).animate( { bottom: 1 }, { duration: 10, @@ -1722,13 +1729,13 @@ test( "Handle queue:false promises", function() { ok( step > 2 && step < 5, "Step three or four" ); step++; } - }); + } ); this.clock.tick( 10 ); foo.promise().done( function() { equal( step++, 5, "steps 1-5: queue:false then queue:fx done" ); - foo.animate({ + foo.animate( { top: 10 }, { duration: 10, @@ -1736,7 +1743,7 @@ test( "Handle queue:false promises", function() { ok( step > 5 && step < 8, "Step six or seven" ); step++; } - }).animate({ + } ).animate( { bottom: 10 }, { duration: 10, @@ -1745,20 +1752,20 @@ test( "Handle queue:false promises", function() { ok( step > 7 && step < 10, "Step eight or nine" ); step++; } - }).promise().done( function() { + } ).promise().done( function() { equal( step++, 10, "steps 6-10: queue:fx then queue:false" ); - }); + } ); - }); + } ); this.clock.tick( 10 ); -}); +} ); test( "multiple unqueued and promise", function() { expect( 4 ); var foo = jQuery( "#foo" ), step = 1; - foo.animate({ + foo.animate( { marginLeft: 300 }, { duration: 500, @@ -1766,7 +1773,7 @@ test( "multiple unqueued and promise", function() { complete: function() { strictEqual( step++, 2, "Step 2" ); } - }).animate({ + } ).animate( { top: 100 }, { duration: 1000, @@ -1774,54 +1781,55 @@ test( "multiple unqueued and promise", function() { complete: function() { strictEqual( step++, 3, "Step 3" ); } - }).animate({}, { + } ).animate( {}, { duration: 2000, queue: false, complete: function() { + // no properties is a non-op and finishes immediately strictEqual( step++, 1, "Step 1" ); } - }).promise().done( function() { + } ).promise().done( function() { strictEqual( step++, 4, "Step 4" ); - }); + } ); this.clock.tick( 1000 ); -}); +} ); test( "animate does not change start value for non-px animation (#7109)", function() { expect( 1 ); - var parent = jQuery( "<div><div></div></div>" ).css({ width: 284, height: 1 }).appendTo( "#qunit-fixture" ), - child = parent.children().css({ fontSize: "98.6in", width: "0.01em", height: 1 }), + var parent = jQuery( "<div><div></div></div>" ).css( { width: 284, height: 1 } ).appendTo( "#qunit-fixture" ), + child = parent.children().css( { fontSize: "98.6in", width: "0.01em", height: 1 } ), actual = parseFloat( child.css( "width" ) ), computed = []; - child.animate({ width: "0%" }, { + child.animate( { width: "0%" }, { duration: 1, step: function() { computed.push( parseFloat( child.css( "width" ) ) ); } - }).queue( function( next ) { + } ).queue( function( next ) { var ratio = computed[ 0 ] / actual; - ok( ratio > 0.9 && ratio < 1.1 , "Starting width was close enough" ); + ok( ratio > 0.9 && ratio < 1.1, "Starting width was close enough" ); next(); parent.remove(); - }); + } ); this.clock.tick( 10 ); -}); +} ); test( "non-px animation handles non-numeric start (#11971)", function() { expect( 2 ); - var foo = jQuery("#foo"), - initial = foo.css("backgroundPositionX"); + var foo = jQuery( "#foo" ), + initial = foo.css( "backgroundPositionX" ); if ( !initial ) { - expect(1); + expect( 1 ); ok( true, "Style property not understood" ); return; } - foo.animate({ backgroundPositionX: "42%" }, { + foo.animate( { backgroundPositionX: "42%" }, { duration: 1, progress: function( anim, percent ) { if ( percent ) { @@ -1837,14 +1845,14 @@ test( "non-px animation handles non-numeric start (#11971)", function() { done: function() { equal( jQuery.style( this, "backgroundPositionX" ), "42%", "End reached" ); } - }); + } ); this.clock.tick( 10 ); -}); +} ); -test("Animation callbacks (#11797)", function() { +test( "Animation callbacks (#11797)", function() { expect( 15 ); - var targets = jQuery("#foo").children(), + var targets = jQuery( "#foo" ).children(), done = false, expectedProgress = 0; @@ -1866,12 +1874,12 @@ test("Animation callbacks (#11797)", function() { ok( true, "empty: always" ); done = true; } - }); + } ); ok( done, "empty: done immediately" ); done = false; - targets.eq( 1 ).animate({ + targets.eq( 1 ).animate( { opacity: 0 }, { duration: 1, @@ -1891,11 +1899,11 @@ test("Animation callbacks (#11797)", function() { ok( true, "stopped: always" ); done = true; } - }).stop(); + } ).stop(); ok( done, "stopped: stopped immediately" ); - targets.eq( 2 ).animate({ + targets.eq( 2 ).animate( { opacity: 0 }, { duration: 1, @@ -1903,11 +1911,13 @@ test("Animation callbacks (#11797)", function() { ok( true, "async: start" ); }, progress: function( anim, percent ) { + // occasionally the progress handler is called twice in first frame.... *shrug* if ( percent === 0 && expectedProgress === 1 ) { return; } equal( percent, expectedProgress, "async: progress " + expectedProgress ); + // once at 0, once at 1 expectedProgress++; }, @@ -1920,16 +1930,16 @@ test("Animation callbacks (#11797)", function() { always: function() { ok( true, "async: always" ); } - }); + } ); this.clock.tick( 10 ); -}); +} ); test( "Animate properly sets overflow hidden when animating width/height (#12117)", function() { expect( 8 ); jQuery.each( [ "height", "width" ], function( _, prop ) { jQuery.each( [ 100, 0 ], function( _, value ) { - var div = jQuery("<div>").css( "overflow", "auto" ), + var div = jQuery( "<div>" ).css( "overflow", "auto" ), props = {}; props[ prop ] = value; div.animate( props, 1 ); @@ -1938,24 +1948,24 @@ test( "Animate properly sets overflow hidden when animating width/height (#12117 div.stop(); equal( div.css( "overflow" ), "auto", "overflow: auto restored after animating " + prop + " to " + value ); - }); - }); -}); + } ); + } ); +} ); test( "Each tick of the timer loop uses a fresh time (#12837)", function() { var lastVal, - tmp = jQuery({ + tmp = jQuery( { test: 0 - }); + } ); expect( 3 ); - tmp.animate({ + tmp.animate( { test: 100 }, { step: function( p, fx ) { ok( fx.now !== lastVal, "Current value is not the last value: " + lastVal + " - " + fx.now ); lastVal = fx.now; } - }); + } ); this.clock.tick( 1 ); // now that we have a new time, run another tick @@ -1965,7 +1975,7 @@ test( "Each tick of the timer loop uses a fresh time (#12837)", function() { jQuery.fx.tick(); tmp.stop(); -}); +} ); test( "Animations with 0 duration don't ease (#12273)", function() { expect( 1 ); @@ -1974,7 +1984,7 @@ test( "Animations with 0 duration don't ease (#12273)", function() { ok( false, "Called easing" ); }; - jQuery( "#foo" ).animate({ + jQuery( "#foo" ).animate( { height: 100 }, { duration: 0, @@ -1982,12 +1992,13 @@ test( "Animations with 0 duration don't ease (#12273)", function() { complete: function() { equal( jQuery( this ).height(), 100, "Height is 100" ); } - }); + } ); delete jQuery.easing.test; -}); +} ); + +jQuery.map( [ "toggle", "slideToggle", "fadeToggle" ], function( method ) { -jQuery.map([ "toggle", "slideToggle", "fadeToggle" ], function ( method ) { // this test would look a lot better if we were using something to override // the default timers var duration = 1500; @@ -1995,7 +2006,7 @@ jQuery.map([ "toggle", "slideToggle", "fadeToggle" ], function ( method ) { function secondToggle() { var stopped = parseFloat( element.css( check ) ); tested = false; - element[ method ]({ + element[ method ]( { duration: duration, step: function( p, fx ) { if ( fx.pos > 0.1 && fx.prop === check && !tested ) { @@ -2005,17 +2016,17 @@ jQuery.map([ "toggle", "slideToggle", "fadeToggle" ], function ( method ) { element.stop(); } } - }); + } ); } var tested, original, check = method === "slideToggle" ? "height" : "opacity", - element = jQuery("#foo").height( 200 ); + element = jQuery( "#foo" ).height( 200 ); expect( 4 ); - element[ method ]({ + element[ method ]( { duration: duration, easing: "linear", step: function( p, fx ) { @@ -2028,16 +2039,17 @@ jQuery.map([ "toggle", "slideToggle", "fadeToggle" ], function ( method ) { } }, always: secondToggle - }); + } ); + //FIXME figure out why 470 this.clock.tick( 470 ); - }); -}); + } ); +} ); test( "jQuery.fx.start & jQuery.fx.stop hook points", function() { var oldStart = jQuery.fx.start, oldStop = jQuery.fx.stop, - foo = jQuery({ foo: 0 }); + foo = jQuery( { foo: 0 } ); expect( 3 ); @@ -2049,17 +2061,19 @@ test( "jQuery.fx.start & jQuery.fx.stop hook points", function() { }; // calls start - foo.animate({ foo: 1 }, { queue: false }); + foo.animate( { foo: 1 }, { queue: false } ); + // calls start - foo.animate({ foo: 2 }, { queue: false }); + foo.animate( { foo: 2 }, { queue: false } ); foo.stop(); + // calls stop jQuery.fx.tick(); // cleanup jQuery.fx.start = oldStart; jQuery.fx.stop = oldStop; -}); +} ); test( ".finish() completes all queued animations", function() { var animations = { @@ -2068,31 +2082,33 @@ test( ".finish() completes all queued animations", function() { height: 100, width: 100 }, - div = jQuery("<div>"); + div = jQuery( "<div>" ); expect( 11 ); jQuery.each( animations, function( prop, value ) { var anim = {}; anim[ prop ] = value; + // the delay shouldn't matter at all! div.css( prop, 1 ).animate( anim, function() { ok( true, "Called animation callback for " + prop ); - }).delay( 100 ); - }); + } ).delay( 100 ); + } ); equal( div.queue().length, 8, "8 animations in the queue" ); div.finish(); jQuery.each( animations, function( prop, value ) { equal( parseFloat( div.css( prop ) ), value, prop + " finished at correct value" ); - }); + } ); equal( div.queue().length, 0, "empty queue when done" ); - equal( div.is(":animated"), false, ":animated doesn't match" ); + equal( div.is( ":animated" ), false, ":animated doesn't match" ); // cleanup div.remove(); + // leaves a "shadow timer" which does nothing around, need to force a tick jQuery.fx.tick(); -}); +} ); test( ".finish( false ) - unqueued animations", function() { var animations = { @@ -2101,7 +2117,7 @@ test( ".finish( false ) - unqueued animations", function() { height: 100, width: 100 }, - div = jQuery("<div>"); + div = jQuery( "<div>" ); expect( 10 ); @@ -2113,20 +2129,21 @@ test( ".finish( false ) - unqueued animations", function() { complete: function() { ok( true, "Called animation callback for " + prop ); } - }); - }); + } ); + } ); equal( div.queue().length, 0, "0 animations in the queue" ); div.finish( false ); jQuery.each( animations, function( prop, value ) { equal( parseFloat( div.css( prop ) ), value, prop + " finished at correct value" ); - }); - equal( div.is(":animated"), false, ":animated doesn't match" ); + } ); + equal( div.is( ":animated" ), false, ":animated doesn't match" ); // cleanup div.remove(); + // leaves a "shadow timer" which does nothing around, need to force a tick jQuery.fx.tick(); -}); +} ); test( ".finish( \"custom\" ) - custom queue animations", function() { var animations = { @@ -2135,7 +2152,7 @@ test( ".finish( \"custom\" ) - custom queue animations", function() { height: 100, width: 100 }, - div = jQuery("<div>"); + div = jQuery( "<div>" ); expect( 11 ); @@ -2147,30 +2164,32 @@ test( ".finish( \"custom\" ) - custom queue animations", function() { complete: function() { ok( true, "Called animation callback for " + prop ); } - }); - }); + } ); + } ); equal( div.queue( "custom" ).length, 4, "4 animations in the queue" ); + // start the first animation div.dequeue( "custom" ); - equal( div.is(":animated"), true, ":animated matches" ); + equal( div.is( ":animated" ), true, ":animated matches" ); div.finish( "custom" ); jQuery.each( animations, function( prop, value ) { equal( parseFloat( div.css( prop ) ), value, prop + " finished at correct value" ); - }); - equal( div.is(":animated"), false, ":animated doesn't match" ); + } ); + equal( div.is( ":animated" ), false, ":animated doesn't match" ); // cleanup div.remove(); + // leaves a "shadow timer" which does nothing around, need to force a tick jQuery.fx.tick(); -}); +} ); test( ".finish() calls finish of custom queue functions", function() { function queueTester( next, hooks ) { hooks.stop = function( gotoEnd ) { inside++; - equal( this, div[0] ); - ok( gotoEnd, "hooks.stop(true) called"); + equal( this, div[ 0 ] ); + ok( gotoEnd, "hooks.stop(true) called" ); }; } var div = jQuery( "<div>" ), @@ -2189,15 +2208,15 @@ test( ".finish() calls finish of custom queue functions", function() { equal( outside, 2, "2 finish callbacks" ); div.remove(); -}); +} ); test( ".finish() is applied correctly when multiple elements were animated (#13937)", function() { expect( 3 ); - var elems = jQuery("<a>0</a><a>1</a><a>2</a>"); + var elems = jQuery( "<a>0</a><a>1</a><a>2</a>" ); elems.animate( { opacity: 0 }, 1500 ).animate( { opacity: 1 }, 1500 ); - setTimeout(function() { + setTimeout( function() { elems.eq( 1 ).finish(); ok( !elems.eq( 1 ).queue().length, "empty queue for .finish()ed element" ); ok( elems.eq( 0 ).queue().length, "non-empty queue for preceding element" ); @@ -2206,13 +2225,13 @@ test( ".finish() is applied correctly when multiple elements were animated (#139 }, 100 ); this.clock.tick( 1500 ); -}); +} ); test( "slideDown() after stop() (#13483)", function() { expect( 2 ); var ul = jQuery( "<ul style='height: 100px; display: block;'></ul>" ) - .appendTo("#qunit-fixture"), + .appendTo( "#qunit-fixture" ), origHeight = ul.height(), clock = this.clock; @@ -2236,10 +2255,10 @@ test( "slideDown() after stop() (#13483)", function() { ul.remove(); clock.tick( 10 ); - }); + } ); clock.tick( 10 ); -}); +} ); test( "Respect display value on inline elements (#14824)", function() { expect( 2 ); @@ -2250,22 +2269,22 @@ test( "Respect display value on inline elements (#14824)", function() { jQuery( "#qunit-fixture" ).append( fromStyleSheet, fromStyleAttr ); - fromStyleSheet.slideUp(function() { + fromStyleSheet.slideUp( function() { jQuery( this ).slideDown( function() { equal( jQuery( this ).css( "display" ), "block", "Respect previous display value (from stylesheet) on span element" ); - }); - }); + } ); + } ); fromStyleAttr.slideUp( function() { jQuery( this ).slideDown( function() { equal( jQuery( this ).css( "display" ), "block", "Respect previous display value (from style attribute) on span element" ); - }); - }); + } ); + } ); clock.tick( 800 ); -}); +} ); test( "jQuery.easing._default (gh-2218)", function() { expect( 2 ); @@ -2277,7 +2296,7 @@ test( "jQuery.easing._default (gh-2218)", function() { equal( anim.opts.easing, jQuery.easing._default, "anim.opts.easing should be equal to jQuery.easing._default when the easing argument is not given" ); } - }) + } ) .animate( { height: "5px" }, { duration: 5, easing: "linear", @@ -2285,11 +2304,11 @@ test( "jQuery.easing._default (gh-2218)", function() { equal( anim.opts.easing, "linear", "anim.opts.easing should be equal to the easing argument" ); } - }) + } ) .stop(); this.clock.tick( 25 ); -}); +} ); test( "jQuery.easing._default in Animation (gh-2218", function() { expect( 3 ); @@ -2314,10 +2333,10 @@ test( "jQuery.easing._default in Animation (gh-2218", function() { "Animation used custom jQuery.easing._default" ); jQuery.easing._default = defaultEasing; delete jQuery.easing.custom; - }); + } ); this.clock.tick( 10 ); -}); +} ); test( "jQuery.easing._default in Tween (gh-2218)", function() { expect( 3 ); @@ -2341,33 +2360,33 @@ test( "jQuery.easing._default in Tween (gh-2218)", function() { "Animation used custom jQuery.easing._default" ); jQuery.easing._default = defaultEasing; delete jQuery.easing.custom; -}); +} ); test( "Display value is correct for disconnected nodes (trac-13310)", function() { expect( 3 ); - var div = jQuery("<div/>"); + var div = jQuery( "<div/>" ); - equal( div.css( "display", "inline" ).hide().show().appendTo("body").css( "display" ), "inline", "Initialized display value has returned" ); + equal( div.css( "display", "inline" ).hide().show().appendTo( "body" ).css( "display" ), "inline", "Initialized display value has returned" ); div.remove(); div.css( "display", "none" ).hide(); equal( jQuery._data( div[ 0 ], "display" ), undefined, "display data is undefined after hiding a detached and hidden element" ); div.remove(); - div.css( "display", "inline-block" ).hide().appendTo("body").fadeIn(function() { + div.css( "display", "inline-block" ).hide().appendTo( "body" ).fadeIn( function() { equal( div.css( "display" ), "inline-block", "Initialized display value has returned" ); div.remove(); - }); + } ); this.clock.tick( 1000 ); -}); +} ); test( "Show/hide/toggle and display: inline", function() { expect( 40 ); var clock = this.clock; - jQuery( "<span/><div style='display:inline' title='inline div'/>" ).each(function() { + jQuery( "<span/><div style='display:inline' title='inline div'/>" ).each( function() { var completed, interrupted, N = 100, fixture = jQuery( "#qunit-fixture" ), @@ -2376,59 +2395,59 @@ test( "Show/hide/toggle and display: inline", function() { // Animations allowed to complete completed = jQuery.map( [ - $el.clone().data({ call: "hide", done: "none" }).appendTo( fixture ).hide( N ), - $el.clone().data({ call: "toggle", done: "none" }).appendTo( fixture ).toggle( N ), - $el.clone().data({ call: "hide+show", done: "inline" }).appendTo( fixture ) + $el.clone().data( { call: "hide", done: "none" } ).appendTo( fixture ).hide( N ), + $el.clone().data( { call: "toggle", done: "none" } ).appendTo( fixture ).toggle( N ), + $el.clone().data( { call: "hide+show", done: "inline" } ).appendTo( fixture ) .hide().show( N ), - $el.clone().data({ call: "hide+toggle", done: "inline" }).appendTo( fixture ) + $el.clone().data( { call: "hide+toggle", done: "inline" } ).appendTo( fixture ) .hide().toggle( N ) ], function( $clone ) { return $clone[ 0 ]; } ); // Animations not allowed to complete interrupted = jQuery.map( [ - $el.clone().data({ call: "hide+stop" }).appendTo( fixture ).hide( N ), - $el.clone().data({ call: "toggle+stop" }).appendTo( fixture ).toggle( N ), - $el.clone().data({ call: "hide+show+stop" }).appendTo( fixture ).hide().show( N ), - $el.clone().data({ call: "hide+toggle+stop" }).appendTo( fixture ).hide().toggle( N ) + $el.clone().data( { call: "hide+stop" } ).appendTo( fixture ).hide( N ), + $el.clone().data( { call: "toggle+stop" } ).appendTo( fixture ).toggle( N ), + $el.clone().data( { call: "hide+show+stop" } ).appendTo( fixture ).hide().show( N ), + $el.clone().data( { call: "hide+toggle+stop" } ).appendTo( fixture ).hide().toggle( N ) ], function( $clone ) { return $clone[ 0 ]; } ); // All elements should be inline-block during the animation clock.tick( N / 2 ); - jQuery( completed ).each(function() { + jQuery( completed ).each( function() { var $el = jQuery( this ), call = $el.data( "call" ); strictEqual( $el.css( "display" ), "inline-block", kind + " display during " + call ); - }); + } ); // Interrupted elements should remain inline-block jQuery( interrupted ).stop(); clock.tick( N / 2 ); - jQuery( interrupted ).each(function() { + jQuery( interrupted ).each( function() { var $el = jQuery( this ), call = $el.data( "call" ); strictEqual( $el.css( "display" ), "inline-block", kind + " display after " + call ); - }); + } ); // Completed elements should not remain inline-block clock.tick( N / 2 ); - jQuery( completed ).each(function() { + jQuery( completed ).each( function() { var $el = jQuery( this ), call = $el.data( "call" ), display = $el.data( "done" ); strictEqual( $el.css( "display" ), display, kind + " display after " + call ); - }); + } ); // A post-animation toggle should not make any element inline-block completed = jQuery( completed.concat( interrupted ) ); completed.toggle( N / 2 ); clock.tick( N ); - completed.each(function() { + completed.each( function() { var $el = jQuery( this ), call = $el.data( "call" ); ok( $el.css( "display" ) !== "inline-block", kind + " display is not inline-block after " + call + "+toggle" ); - }); - }); -}); + } ); + } ); +} ); -})(); +} )(); diff --git a/test/unit/event.js b/test/unit/event.js index d27db447c..91ab5e08b 100644 --- a/test/unit/event.js +++ b/test/unit/event.js @@ -3,28 +3,28 @@ module( "event", { document.body.focus(); }, teardown: moduleTeardown -}); +} ); -test("on() with non-null,defined data", function() { +test( "on() with non-null,defined data", function() { - expect(2); + expect( 2 ); var handler = function( event, data ) { equal( data, 0, "non-null, defined data (zero) is correctly passed" ); }; - jQuery("#foo").on("foo.on", handler); - jQuery("div").on("foo.delegate", "#foo", handler); + jQuery( "#foo" ).on( "foo.on", handler ); + jQuery( "div" ).on( "foo.delegate", "#foo", handler ); - jQuery("#foo").trigger("foo", 0); + jQuery( "#foo" ).trigger( "foo", 0 ); - jQuery("#foo").off("foo.on", handler); - jQuery("div").off("foo.delegate", "#foo"); + jQuery( "#foo" ).off( "foo.on", handler ); + jQuery( "div" ).off( "foo.delegate", "#foo" ); -}); +} ); -test("Handler changes and .trigger() order", function() { - expect(1); +test( "Handler changes and .trigger() order", function() { + expect( 1 ); var markup = jQuery( "<div><div><p><span><b class=\"a\">b</b></span></p></div></div>" @@ -34,154 +34,154 @@ test("Handler changes and .trigger() order", function() { markup .find( "*" ).addBack().on( "click", function() { path += this.nodeName.toLowerCase() + " "; - }) + } ) .filter( "b" ).on( "click", function( e ) { + // Removing span should not stop propagation to original parents if ( e.target === this ) { - jQuery(this).parent().remove(); + jQuery( this ).parent().remove(); } - }); + } ); markup.find( "b" ).trigger( "click" ); equal( path, "b p div div ", "Delivered all events" ); markup.remove(); -}); +} ); -test("on(), with data", function() { - expect(4); +test( "on(), with data", function() { + expect( 4 ); var test, handler, handler2; - handler = function(event) { + handler = function( event ) { ok( event.data, "on() with data, check passed data exists" ); - equal( event.data["foo"], "bar", "on() with data, Check value of passed data" ); + equal( event.data[ "foo" ], "bar", "on() with data, Check value of passed data" ); }; - jQuery("#firstp").on("click", {"foo": "bar"}, handler).trigger("click").off("click", handler); + jQuery( "#firstp" ).on( "click", { "foo": "bar" }, handler ).trigger( "click" ).off( "click", handler ); - ok( !jQuery._data(jQuery("#firstp")[0], "events"), "Event handler unbound when using data." ); + ok( !jQuery._data( jQuery( "#firstp" )[ 0 ], "events" ), "Event handler unbound when using data." ); - test = function(){}; - handler2 = function(event) { + test = function() {}; + handler2 = function( event ) { equal( event.data, test, "on() with function data, Check value of passed data" ); }; - jQuery("#firstp").on("click", test, handler2).trigger("click").off("click", handler2); -}); + jQuery( "#firstp" ).on( "click", test, handler2 ).trigger( "click" ).off( "click", handler2 ); +} ); -test("click(), with data", function() { - expect(3); - var handler = function(event) { +test( "click(), with data", function() { + expect( 3 ); + var handler = function( event ) { ok( event.data, "on() with data, check passed data exists" ); - equal( event.data["foo"], "bar", "on() with data, Check value of passed data" ); + equal( event.data[ "foo" ], "bar", "on() with data, Check value of passed data" ); }; - jQuery("#firstp").on( "click", {"foo": "bar"}, handler).trigger("click").off("click", handler); + jQuery( "#firstp" ).on( "click", { "foo": "bar" }, handler ).trigger( "click" ).off( "click", handler ); - ok( !jQuery._data(jQuery("#firstp")[0], "events"), "Event handler unbound when using data." ); -}); + ok( !jQuery._data( jQuery( "#firstp" )[ 0 ], "events" ), "Event handler unbound when using data." ); +} ); -test("on(), with data, trigger with data", function() { - expect(4); - var handler = function(event, data) { +test( "on(), with data, trigger with data", function() { + expect( 4 ); + var handler = function( event, data ) { ok( event.data, "check passed data exists" ); equal( event.data.foo, "bar", "Check value of passed data" ); ok( data, "Check trigger data" ); equal( data.bar, "foo", "Check value of trigger data" ); }; - jQuery("#firstp").on("click", {foo: "bar"}, handler).trigger("click", [{bar: "foo"}]).off("click", handler); -}); + jQuery( "#firstp" ).on( "click", { foo: "bar" }, handler ).trigger( "click", [ { bar: "foo" } ] ).off( "click", handler ); +} ); -test("on(), multiple events at once", function() { - expect(2); +test( "on(), multiple events at once", function() { + expect( 2 ); var handler, clickCounter = 0, mouseoverCounter = 0; - handler = function(event) { - if (event.type === "click") { + handler = function( event ) { + if ( event.type === "click" ) { clickCounter += 1; - } - else if (event.type === "mouseover") { + } else if ( event.type === "mouseover" ) { mouseoverCounter += 1; } }; - jQuery("#firstp").on("click mouseover", handler).trigger("click").trigger("mouseover"); + jQuery( "#firstp" ).on( "click mouseover", handler ).trigger( "click" ).trigger( "mouseover" ); equal( clickCounter, 1, "on() with multiple events at once" ); equal( mouseoverCounter, 1, "on() with multiple events at once" ); -}); +} ); -test("on(), five events at once", function() { - expect(1); +test( "on(), five events at once", function() { + expect( 1 ); var count = 0, handler = function() { count++; }; - jQuery("#firstp").on("click mouseover foo bar baz", handler) - .trigger("click").trigger("mouseover") - .trigger("foo").trigger("bar") - .trigger("baz"); + jQuery( "#firstp" ).on( "click mouseover foo bar baz", handler ) + .trigger( "click" ).trigger( "mouseover" ) + .trigger( "foo" ).trigger( "bar" ) + .trigger( "baz" ); equal( count, 5, "on() five events at once" ); -}); +} ); -test("on(), multiple events at once and namespaces", function() { - expect(7); +test( "on(), multiple events at once and namespaces", function() { + expect( 7 ); var cur, div, obj = {}; - div = jQuery("<div/>").on("focusin.a", function(e) { + div = jQuery( "<div/>" ).on( "focusin.a", function( e ) { equal( e.type, cur, "Verify right single event was fired." ); - }); + } ); cur = "focusin"; - div.trigger("focusin.a"); + div.trigger( "focusin.a" ); // manually clean up detached elements div.remove(); - div = jQuery("<div/>").on("click mouseover", obj, function(e) { + div = jQuery( "<div/>" ).on( "click mouseover", obj, function( e ) { equal( e.type, cur, "Verify right multi event was fired." ); equal( e.data, obj, "Make sure the data came in correctly." ); - }); + } ); cur = "click"; - div.trigger("click"); + div.trigger( "click" ); cur = "mouseover"; - div.trigger("mouseover"); + div.trigger( "mouseover" ); // manually clean up detached elements div.remove(); - div = jQuery("<div/>").on("focusin.a focusout.b", function(e) { + div = jQuery( "<div/>" ).on( "focusin.a focusout.b", function( e ) { equal( e.type, cur, "Verify right multi event was fired." ); - }); + } ); cur = "focusin"; - div.trigger("focusin.a"); + div.trigger( "focusin.a" ); cur = "focusout"; - div.trigger("focusout.b"); + div.trigger( "focusout.b" ); // manually clean up detached elements div.remove(); -}); +} ); -test("on(), namespace with special add", function() { - expect(27); +test( "on(), namespace with special add", function() { + expect( 27 ); var i = 0, - div = jQuery("<div/>").appendTo("#qunit-fixture").on( "test", function() { + div = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ).on( "test", function() { ok( true, "Test event fired." ); - }); + } ); - jQuery.event.special["test"] = { + jQuery.event.special[ "test" ] = { _default: function( e, data ) { equal( e.type, "test", "Make sure we're dealing with a test event." ); ok( data, "And that trigger data was passed." ); - strictEqual( e.target, div[0], "And that the target is correct." ); + strictEqual( e.target, div[ 0 ], "And that the target is correct." ); equal( this, window, "And that the context is correct." ); }, setup: function() {}, @@ -202,13 +202,13 @@ test("on(), namespace with special add", function() { div.on( "test.a", { x: 1 }, function( e ) { ok( !!e.xyz, "Make sure that the data is getting passed through." ); - equal( e.data["x"], 1, "Make sure data is attached properly." ); - }); + equal( e.data[ "x" ], 1, "Make sure data is attached properly." ); + } ); div.on( "test.b", { x: 2 }, function( e ) { ok( !!e.xyz, "Make sure that the data is getting passed through." ); - equal( e.data["x"], 2, "Make sure data is attached properly." ); - }); + equal( e.data[ "x" ], 2, "Make sure data is attached properly." ); + } ); // Should trigger 5 div.trigger( "test", 33.33 ); @@ -220,61 +220,63 @@ test("on(), namespace with special add", function() { div.trigger( "test.b", { year: 1982 } ); // Should trigger 4 - div.off("test"); + div.off( "test" ); - div = jQuery("<div/>").on( "test", function() { + div = jQuery( "<div/>" ).on( "test", function() { ok( true, "Test event fired." ); - }); + } ); // Should trigger 2 - div.appendTo("#qunit-fixture").remove(); + div.appendTo( "#qunit-fixture" ).remove(); - delete jQuery.event.special["test"]; -}); + delete jQuery.event.special[ "test" ]; +} ); -test("on(), no data", function() { - expect(1); - var handler = function(event) { +test( "on(), no data", function() { + expect( 1 ); + var handler = function( event ) { ok ( !event.data, "Check that no data is added to the event object" ); }; - jQuery("#firstp").on("click", handler).trigger("click"); -}); + jQuery( "#firstp" ).on( "click", handler ).trigger( "click" ); +} ); -test("on/one/off(Object)", function(){ - expect(6); +test( "on/one/off(Object)", function() { + expect( 6 ); var $elem, clickCounter = 0, mouseoverCounter = 0; - function handler(event) { - if (event.type === "click") { + function handler( event ) { + if ( event.type === "click" ) { clickCounter++; - } else if (event.type === "mouseover") { + } else if ( event.type === "mouseover" ) { mouseoverCounter++; } } - function handlerWithData(event) { - if (event.type === "click") { + function handlerWithData( event ) { + if ( event.type === "click" ) { clickCounter += event.data; - } else if (event.type === "mouseover") { + } else if ( event.type === "mouseover" ) { mouseoverCounter += event.data; } } - function trigger(){ - $elem.trigger("click").trigger("mouseover"); + function trigger() { + $elem.trigger( "click" ).trigger( "mouseover" ); } - $elem = jQuery("#firstp") + $elem = jQuery( "#firstp" ) + // Regular bind - .on({ + .on( { "click":handler, "mouseover":handler - }) + } ) + // Bind with data - .one({ + .one( { "click":handlerWithData, "mouseover":handlerWithData }, 2 ); @@ -288,24 +290,24 @@ test("on/one/off(Object)", function(){ equal( clickCounter, 4, "on(Object)" ); equal( mouseoverCounter, 4, "on(Object)" ); - jQuery("#firstp").off({ + jQuery( "#firstp" ).off( { "click":handler, "mouseover":handler - }); + } ); trigger(); equal( clickCounter, 4, "on(Object)" ); equal( mouseoverCounter, 4, "on(Object)" ); -}); +} ); -test("on/off(Object), on/off(Object, String)", function() { - expect(6); +test( "on/off(Object), on/off(Object, String)", function() { + expect( 6 ); var events, clickCounter = 0, mouseoverCounter = 0, - $p = jQuery("#firstp"), - $a = $p.find("a").eq(0); + $p = jQuery( "#firstp" ), + $a = $p.find( "a" ).eq( 0 ); events = { "click": function( event ) { @@ -317,7 +319,7 @@ test("on/off(Object), on/off(Object, String)", function() { }; function trigger() { - $a.trigger("click").trigger("mouseover"); + $a.trigger( "click" ).trigger( "mouseover" ); } jQuery( document ).on( events, "#firstp a" ); @@ -338,73 +340,74 @@ test("on/off(Object), on/off(Object, String)", function() { trigger(); equal( clickCounter, 4, "off" ); equal( mouseoverCounter, 4, "off" ); -}); +} ); -test("on immediate propagation", function() { - expect(2); +test( "on immediate propagation", function() { + expect( 2 ); var lastClick, - $p = jQuery("#firstp"), - $a = $p.find("a").eq(0); + $p = jQuery( "#firstp" ), + $a = $p.find( "a" ).eq( 0 ); lastClick = ""; - jQuery( document ).on( "click", "#firstp a", function(e) { + jQuery( document ).on( "click", "#firstp a", function( e ) { lastClick = "click1"; e.stopImmediatePropagation(); - }); + } ); jQuery( document ).on( "click", "#firstp a", function() { lastClick = "click2"; - }); + } ); $a.trigger( "click" ); equal( lastClick, "click1", "on stopImmediatePropagation" ); jQuery( document ).off( "click", "#firstp a" ); lastClick = ""; - $p.on( "click", "a", function(e) { + $p.on( "click", "a", function( e ) { lastClick = "click1"; e.stopImmediatePropagation(); - }); + } ); $p.on( "click", "a", function() { lastClick = "click2"; - }); + } ); $a.trigger( "click" ); equal( lastClick, "click1", "on stopImmediatePropagation" ); $p.off( "click", "**" ); -}); +} ); -test("on bubbling, isDefaultPrevented, stopImmediatePropagation", function() { +test( "on bubbling, isDefaultPrevented, stopImmediatePropagation", function() { expect( 3 ); var $anchor2 = jQuery( "#anchor2" ), $main = jQuery( "#qunit-fixture" ), neverCallMe = function() { ok( false, "immediate propagation should have been stopped" ); }, - fakeClick = function($jq) { + fakeClick = function( $jq ) { + // Use a native click so we don't get jQuery simulated bubbling if ( document.createEvent ) { var e = document.createEvent( "MouseEvents" ); e.initEvent( "click", true, true ); - $jq[0].dispatchEvent(e); - } - else if ( $jq[0].click ) { - $jq[0].click(); // IE + $jq[ 0 ].dispatchEvent( e ); + } else if ( $jq[ 0 ].click ) { + $jq[ 0 ].click(); // IE } }; - $anchor2.on( "click", function(e) { + $anchor2.on( "click", function( e ) { e.preventDefault(); - }); - $main.on("click", "#foo", function(e) { + } ); + $main.on( "click", "#foo", function( e ) { equal( e.isDefaultPrevented(), true, "isDefaultPrevented true passed to bubbled event" ); - }); + } ); fakeClick( $anchor2 ); $anchor2.off( "click" ); $main.off( "click", "**" ); $anchor2.on( "click", function() { + // Let the default action occur - }); - $main.on("click", "#foo", function(e) { + } ); + $main.on( "click", "#foo", function( e ) { equal( e.isDefaultPrevented(), false, "isDefaultPrevented false passed to bubbled event" ); - }); + } ); fakeClick( $anchor2 ); $anchor2.off( "click" ); $main.off( "click", "**" ); @@ -418,91 +421,91 @@ test("on bubbling, isDefaultPrevented, stopImmediatePropagation", function() { $anchor2.on( "click", function( e ) { e.stopImmediatePropagation(); ok( true, "anchor was clicked and prop stopped" ); - }); - $anchor2[0].addEventListener( "click", neverCallMe, false ); + } ); + $anchor2[ 0 ].addEventListener( "click", neverCallMe, false ); fakeClick( $anchor2 ); - $anchor2[0].removeEventListener( "click", neverCallMe ); + $anchor2[ 0 ].removeEventListener( "click", neverCallMe ); } -}); +} ); -test("on(), iframes", function() { +test( "on(), iframes", function() { expect( 1 ); // events don't work with iframes, see #939 - this test fails in IE because of contentDocument - var doc = jQuery("#loadediframe").contents(); + var doc = jQuery( "#loadediframe" ).contents(); - jQuery("div", doc).on("click", function() { + jQuery( "div", doc ).on( "click", function() { ok( true, "Binding to element inside iframe" ); - }).trigger("click").off("click"); -}); + } ).trigger( "click" ).off( "click" ); +} ); -test("on(), trigger change on select", function() { - expect(5); +test( "on(), trigger change on select", function() { + expect( 5 ); var counter = 0; - function selectOnChange(event) { + function selectOnChange( event ) { equal( event.data, counter++, "Event.data is not a global event object" ); } - jQuery("#form select").each(function(i){ - jQuery(this).on("change", i, selectOnChange); - }).trigger("change"); -}); + jQuery( "#form select" ).each( function( i ) { + jQuery( this ).on( "change", i, selectOnChange ); + } ).trigger( "change" ); +} ); -test("on(), namespaced events, cloned events", function() { +test( "on(), namespaced events, cloned events", function() { expect( 18 ); var firstp = jQuery( "#firstp" ); - firstp.on("custom.test",function(){ - ok(false, "Custom event triggered"); - }); + firstp.on( "custom.test", function() { + ok( false, "Custom event triggered" ); + } ); - firstp.on("click",function(e){ - ok(true, "Normal click triggered"); + firstp.on( "click", function( e ) { + ok( true, "Normal click triggered" ); equal( e.type + e.namespace, "click", "Check that only click events trigger this fn" ); - }); + } ); - firstp.on("click.test",function(e){ + firstp.on( "click.test", function( e ) { var check = "click"; ok( true, "Namespaced click triggered" ); if ( e.namespace ) { check += "test"; } equal( e.type + e.namespace, check, "Check that only click/click.test events trigger this fn" ); - }); + } ); //clone(true) element to verify events are cloned correctly firstp = firstp.add( firstp.clone( true ).attr( "id", "firstp2" ).insertBefore( firstp ) ); // Trigger both bound fn (8) - firstp.trigger("click"); + firstp.trigger( "click" ); // Trigger one bound fn (4) - firstp.trigger("click.test"); + firstp.trigger( "click.test" ); // Remove only the one fn - firstp.off("click.test"); + firstp.off( "click.test" ); // Trigger the remaining fn (4) - firstp.trigger("click"); + firstp.trigger( "click" ); // Remove the remaining namespaced fn - firstp.off(".test"); + firstp.off( ".test" ); // Try triggering the custom event (0) - firstp.trigger("custom"); + firstp.trigger( "custom" ); // using contents will get comments regular, text, and comment nodes - jQuery("#nonnodes").contents().on("tester", function () { - equal(this.nodeType, 1, "Check node,textnode,comment on just does real nodes" ); - }).trigger("tester"); + jQuery( "#nonnodes" ).contents().on( "tester", function() { + equal( this.nodeType, 1, "Check node,textnode,comment on just does real nodes" ); + } ).trigger( "tester" ); // Make sure events stick with appendTo'd elements (which are cloned) #2027 - jQuery("<a href='#fail' class='test'>test</a>").on( "click", function(){ return false; }).appendTo("#qunit-fixture"); - ok( jQuery("a.test").eq(0).triggerHandler("click") === false, "Handler is bound to appendTo'd elements" ); -}); + jQuery( "<a href='#fail' class='test'>test</a>" ).on( "click", function() { return false; } ).appendTo( "#qunit-fixture" ); + ok( jQuery( "a.test" ).eq( 0 ).triggerHandler( "click" ) === false, "Handler is bound to appendTo'd elements" ); +} ); -test("on(), multi-namespaced events", function() { - expect(6); +test( "on(), multi-namespaced events", function() { + expect( 6 ); var order = [ "click.test.abc", @@ -513,120 +516,120 @@ test("on(), multi-namespaced events", function() { "custom.test2" ]; - function check(name, msg){ + function check( name, msg ) { deepEqual( name, order.shift(), msg ); } - jQuery("#firstp").on("custom.test",function() { - check("custom.test", "Custom event triggered"); - }); + jQuery( "#firstp" ).on( "custom.test", function() { + check( "custom.test", "Custom event triggered" ); + } ); - jQuery("#firstp").on("custom.test2",function() { - check("custom.test2", "Custom event triggered"); - }); + jQuery( "#firstp" ).on( "custom.test2", function() { + check( "custom.test2", "Custom event triggered" ); + } ); - jQuery("#firstp").on("click.test",function() { - check("click.test", "Normal click triggered"); - }); + jQuery( "#firstp" ).on( "click.test", function() { + check( "click.test", "Normal click triggered" ); + } ); - jQuery("#firstp").on("click.test.abc",function() { - check("click.test.abc", "Namespaced click triggered"); - }); + jQuery( "#firstp" ).on( "click.test.abc", function() { + check( "click.test.abc", "Namespaced click triggered" ); + } ); // Those would not trigger/off (#5303) - jQuery("#firstp").trigger("click.a.test"); - jQuery("#firstp").off("click.a.test"); + jQuery( "#firstp" ).trigger( "click.a.test" ); + jQuery( "#firstp" ).off( "click.a.test" ); // Trigger both bound fn (1) - jQuery("#firstp").trigger("click.test.abc"); + jQuery( "#firstp" ).trigger( "click.test.abc" ); // Trigger one bound fn (1) - jQuery("#firstp").trigger("click.abc"); + jQuery( "#firstp" ).trigger( "click.abc" ); // Trigger two bound fn (2) - jQuery("#firstp").trigger("click.test"); + jQuery( "#firstp" ).trigger( "click.test" ); // Remove only the one fn - jQuery("#firstp").off("click.abc"); + jQuery( "#firstp" ).off( "click.abc" ); // Trigger the remaining fn (1) - jQuery("#firstp").trigger("click"); + jQuery( "#firstp" ).trigger( "click" ); // Remove the remaining fn - jQuery("#firstp").off(".test"); + jQuery( "#firstp" ).off( ".test" ); // Trigger the remaining fn (1) - jQuery("#firstp").trigger("custom"); -}); + jQuery( "#firstp" ).trigger( "custom" ); +} ); -test("namespace-only event binding is a no-op", function(){ - expect(2); +test( "namespace-only event binding is a no-op", function() { + expect( 2 ); - jQuery("#firstp") + jQuery( "#firstp" ) .on( ".whoops", function() { ok( false, "called a namespace-only event" ); - }) + } ) .on( "whoops", function() { ok( true, "called whoops" ); - }) - .trigger("whoops") // 1 - .off(".whoops") - .trigger("whoops") // 2 - .off("whoops"); -}); - -test("Empty namespace is ignored", function(){ + } ) + .trigger( "whoops" ) // 1 + .off( ".whoops" ) + .trigger( "whoops" ) // 2 + .off( "whoops" ); +} ); + +test( "Empty namespace is ignored", function() { expect( 1 ); - jQuery("#firstp") + jQuery( "#firstp" ) .on( "meow.", function( e ) { equal( e.namespace, "", "triggered a namespace-less meow event" ); - }) - .trigger("meow.") - .off("meow."); -}); + } ) + .trigger( "meow." ) + .off( "meow." ); +} ); -test("on(), with same function", function() { - expect(2); +test( "on(), with same function", function() { + expect( 2 ); - var count = 0, func = function(){ + var count = 0, func = function() { count++; }; - jQuery("#liveHandlerOrder").on("foo.bar", func).on("foo.zar", func); - jQuery("#liveHandlerOrder").trigger("foo.bar"); + jQuery( "#liveHandlerOrder" ).on( "foo.bar", func ).on( "foo.zar", func ); + jQuery( "#liveHandlerOrder" ).trigger( "foo.bar" ); - equal(count, 1, "Verify binding function with multiple namespaces." ); + equal( count, 1, "Verify binding function with multiple namespaces." ); - jQuery("#liveHandlerOrder").off("foo.bar", func).off("foo.zar", func); - jQuery("#liveHandlerOrder").trigger("foo.bar"); + jQuery( "#liveHandlerOrder" ).off( "foo.bar", func ).off( "foo.zar", func ); + jQuery( "#liveHandlerOrder" ).trigger( "foo.bar" ); - equal(count, 1, "Verify that removing events still work." ); -}); + equal( count, 1, "Verify that removing events still work." ); +} ); -test("on(), make sure order is maintained", function() { - expect(1); +test( "on(), make sure order is maintained", function() { + expect( 1 ); - var elem = jQuery("#firstp"), log = [], check = []; + var elem = jQuery( "#firstp" ), log = [], check = []; - jQuery.each( new Array(100), function( i ) { - elem.on( "click", function(){ + jQuery.each( new Array( 100 ), function( i ) { + elem.on( "click", function() { log.push( i ); - }); + } ); check.push( i ); - }); + } ); - elem.trigger("click"); + elem.trigger( "click" ); - equal( log.join(","), check.join(","), "Make sure order was maintained." ); + equal( log.join( "," ), check.join( "," ), "Make sure order was maintained." ); - elem.off("click"); -}); + elem.off( "click" ); +} ); -test("on(), with different this object", function() { - expect(4); +test( "on(), with different this object", function() { + expect( 4 ); var thisObject = { myThis: true }, data = { myData: true }, handler1 = function() { @@ -637,367 +640,369 @@ test("on(), with different this object", function() { equal( event.data, data, "on() with different this object and data" ); }; - jQuery("#firstp") - .on("click", jQuery.proxy(handler1, thisObject)).trigger("click").off("click", handler1) - .on("click", data, jQuery.proxy(handler2, thisObject)).trigger("click").off("click", handler2); + jQuery( "#firstp" ) + .on( "click", jQuery.proxy( handler1, thisObject ) ).trigger( "click" ).off( "click", handler1 ) + .on( "click", data, jQuery.proxy( handler2, thisObject ) ).trigger( "click" ).off( "click", handler2 ); - ok( !jQuery._data(jQuery("#firstp")[0], "events"), "Event handler unbound when using different this object and data." ); -}); + ok( !jQuery._data( jQuery( "#firstp" )[ 0 ], "events" ), "Event handler unbound when using different this object and data." ); +} ); -test("on(name, false), off(name, false)", function() { - expect(3); +test( "on(name, false), off(name, false)", function() { + expect( 3 ); var main = 0; - jQuery("#qunit-fixture").on("click", function(){ main++; }); - jQuery("#ap").trigger("click"); + jQuery( "#qunit-fixture" ).on( "click", function() { main++; } ); + jQuery( "#ap" ).trigger( "click" ); equal( main, 1, "Verify that the trigger happened correctly." ); main = 0; - jQuery("#ap").on("click", false); - jQuery("#ap").trigger("click"); + jQuery( "#ap" ).on( "click", false ); + jQuery( "#ap" ).trigger( "click" ); equal( main, 0, "Verify that no bubble happened." ); main = 0; - jQuery("#ap").off("click", false); - jQuery("#ap").trigger("click"); + jQuery( "#ap" ).off( "click", false ); + jQuery( "#ap" ).trigger( "click" ); equal( main, 1, "Verify that the trigger happened correctly." ); // manually clean up events from elements outside the fixture - jQuery("#qunit-fixture").off("click"); -}); + jQuery( "#qunit-fixture" ).off( "click" ); +} ); -test("on(name, selector, false), off(name, selector, false)", function() { - expect(3); +test( "on(name, selector, false), off(name, selector, false)", function() { + expect( 3 ); var main = 0; - jQuery("#qunit-fixture").on("click", "#ap", function(){ main++; }); - jQuery("#ap").trigger("click"); + jQuery( "#qunit-fixture" ).on( "click", "#ap", function() { main++; } ); + jQuery( "#ap" ).trigger( "click" ); equal( main, 1, "Verify that the trigger happened correctly." ); main = 0; - jQuery("#ap").on("click", "#groups", false); - jQuery("#groups").trigger("click"); + jQuery( "#ap" ).on( "click", "#groups", false ); + jQuery( "#groups" ).trigger( "click" ); equal( main, 0, "Verify that no bubble happened." ); main = 0; - jQuery("#ap").off("click", "#groups", false); - jQuery("#groups").trigger("click"); + jQuery( "#ap" ).off( "click", "#groups", false ); + jQuery( "#groups" ).trigger( "click" ); equal( main, 1, "Verify that the trigger happened correctly." ); - jQuery("#qunit-fixture").off("click", "#ap"); -}); + jQuery( "#qunit-fixture" ).off( "click", "#ap" ); +} ); -test("on()/trigger()/off() on plain object", function() { +test( "on()/trigger()/off() on plain object", function() { expect( 7 ); var events, obj = {}; // Make sure it doesn't complain when no events are found - jQuery(obj).trigger("test"); + jQuery( obj ).trigger( "test" ); // Make sure it doesn't complain when no events are found - jQuery(obj).off("test"); + jQuery( obj ).off( "test" ); - jQuery(obj).on({ + jQuery( obj ).on( { "test": function() { ok( true, "Custom event run." ); }, "submit": function() { ok( true, "Custom submit event run." ); } - }); + } ); - events = jQuery._data(obj, "events"); + events = jQuery._data( obj, "events" ); ok( events, "Object has events bound." ); - equal( obj["events"], undefined, "Events object on plain objects is not events" ); - equal( obj["test"], undefined, "Make sure that test event is not on the plain object." ); - equal( obj["handle"], undefined, "Make sure that the event handler is not on the plain object." ); + equal( obj[ "events" ], undefined, "Events object on plain objects is not events" ); + equal( obj[ "test" ], undefined, "Make sure that test event is not on the plain object." ); + equal( obj[ "handle" ], undefined, "Make sure that the event handler is not on the plain object." ); // Should trigger 1 - jQuery(obj).trigger("test"); - jQuery(obj).trigger("submit"); + jQuery( obj ).trigger( "test" ); + jQuery( obj ).trigger( "submit" ); - jQuery(obj).off("test"); - jQuery(obj).off("submit"); + jQuery( obj ).off( "test" ); + jQuery( obj ).off( "submit" ); // Should trigger 0 - jQuery(obj).trigger("test"); + jQuery( obj ).trigger( "test" ); // Make sure it doesn't complain when no events are found - jQuery(obj).off("test"); + jQuery( obj ).off( "test" ); equal( obj && obj[ jQuery.expando ] && obj[ jQuery.expando ][ jQuery.expando ] && - obj[ jQuery.expando ][ jQuery.expando ]["events"], undefined, "Make sure events object is removed" ); -}); + obj[ jQuery.expando ][ jQuery.expando ][ "events" ], undefined, "Make sure events object is removed" ); +} ); -test("off(type)", function() { +test( "off(type)", function() { expect( 1 ); var message, func, - $elem = jQuery("#firstp"); + $elem = jQuery( "#firstp" ); - function error(){ + function error() { ok( false, message ); } message = "unbind passing function"; - $elem.on("error1", error).off("error1", error).triggerHandler("error1"); + $elem.on( "error1", error ).off( "error1", error ).triggerHandler( "error1" ); message = "unbind all from event"; - $elem.on("error1", error).off("error1").triggerHandler("error1"); + $elem.on( "error1", error ).off( "error1" ).triggerHandler( "error1" ); message = "unbind all"; - $elem.on("error1", error).off().triggerHandler("error1"); + $elem.on( "error1", error ).off().triggerHandler( "error1" ); message = "unbind many with function"; - $elem.on("error1 error2",error) - .off("error1 error2", error ) - .trigger("error1").triggerHandler("error2"); + $elem.on( "error1 error2", error ) + .off( "error1 error2", error ) + .trigger( "error1" ).triggerHandler( "error2" ); message = "unbind many"; // #3538 - $elem.on("error1 error2", error) - .off("error1 error2") - .trigger("error1").triggerHandler("error2"); + $elem.on( "error1 error2", error ) + .off( "error1 error2" ) + .trigger( "error1" ).triggerHandler( "error2" ); message = "unbind without a type or handler"; - $elem.on("error1 error2.test",error) + $elem.on( "error1 error2.test", error ) .off() - .trigger("error1").triggerHandler("error2"); + .trigger( "error1" ).triggerHandler( "error2" ); // Should only unbind the specified function - jQuery( document ).on( "click", function(){ - ok( true, "called handler after selective removal"); - }); + jQuery( document ).on( "click", function() { + ok( true, "called handler after selective removal" ); + } ); func = function() {}; jQuery( document ) .on( "click", func ) .off( "click", func ) - .trigger("click") + .trigger( "click" ) .off( "click" ); -}); +} ); -test("off(eventObject)", function() { - expect(4); +test( "off(eventObject)", function() { + expect( 4 ); - var $elem = jQuery("#firstp"), + var $elem = jQuery( "#firstp" ), num; - function assert( expected ){ + function assert( expected ) { num = 0; - $elem.trigger("foo").triggerHandler("bar"); + $elem.trigger( "foo" ).triggerHandler( "bar" ); equal( num, expected, "Check the right handlers are triggered" ); } $elem + // This handler shouldn't be unbound - .on("foo", function(){ + .on( "foo", function() { num += 1; - }) - .on("foo", function(e){ + } ) + .on( "foo", function( e ) { $elem.off( e ); num += 2; - }) + } ) + // Neither this one - .on("bar", function(){ + .on( "bar", function() { num += 4; - }); + } ); assert( 7 ); assert( 5 ); - $elem.off("bar"); + $elem.off( "bar" ); assert( 1 ); $elem.off(); assert( 0 ); -}); +} ); if ( jQuery.fn.hover ) { - test("hover() mouseenter mouseleave", function() { - expect(1); + test( "hover() mouseenter mouseleave", function() { + expect( 1 ); var times = 0, handler1 = function() { ++times; }, handler2 = function() { ++times; }; - jQuery("#firstp") - .hover(handler1, handler2) + jQuery( "#firstp" ) + .hover( handler1, handler2 ) .mouseenter().mouseleave() - .off("mouseenter", handler1) - .off("mouseleave", handler2) - .hover(handler1) + .off( "mouseenter", handler1 ) + .off( "mouseleave", handler2 ) + .hover( handler1 ) .mouseenter().mouseleave() - .off("mouseenter mouseleave", handler1) + .off( "mouseenter mouseleave", handler1 ) .mouseenter().mouseleave(); equal( times, 4, "hover handlers fired" ); - }); + } ); } -test("mouseover triggers mouseenter", function() { - expect(1); +test( "mouseover triggers mouseenter", function() { + expect( 1 ); var count = 0, - elem = jQuery("<a />"); - elem.on( "mouseenter", function () { + elem = jQuery( "<a />" ); + elem.on( "mouseenter", function() { count++; - }); - elem.trigger("mouseover"); - equal(count, 1, "make sure mouseover triggers a mouseenter" ); + } ); + elem.trigger( "mouseover" ); + equal( count, 1, "make sure mouseover triggers a mouseenter" ); elem.remove(); -}); +} ); -test("pointerover triggers pointerenter", function() { - expect(1); +test( "pointerover triggers pointerenter", function() { + expect( 1 ); var count = 0, - elem = jQuery("<a />"); - elem.on( "pointerenter", function () { + elem = jQuery( "<a />" ); + elem.on( "pointerenter", function() { count++; - }); - elem.trigger("pointerover"); - equal(count, 1, "make sure pointerover triggers a pointerenter" ); + } ); + elem.trigger( "pointerover" ); + equal( count, 1, "make sure pointerover triggers a pointerenter" ); elem.remove(); -}); +} ); -test("withinElement implemented with jQuery.contains()", function() { +test( "withinElement implemented with jQuery.contains()", function() { - expect(1); + expect( 1 ); - jQuery("#qunit-fixture").append("<div id='jc-outer'><div id='jc-inner'></div></div>"); + jQuery( "#qunit-fixture" ).append( "<div id='jc-outer'><div id='jc-inner'></div></div>" ); - jQuery("#jc-outer").on("mouseenter mouseleave", function( event ) { + jQuery( "#jc-outer" ).on( "mouseenter mouseleave", function( event ) { equal( this.id, "jc-outer", this.id + " " + event.type ); - }).trigger("mouseenter"); + } ).trigger( "mouseenter" ); - jQuery("#jc-inner").trigger("mousenter"); + jQuery( "#jc-inner" ).trigger( "mousenter" ); - jQuery("#jc-outer").off("mouseenter mouseleave").remove(); - jQuery("#jc-inner").remove(); + jQuery( "#jc-outer" ).off( "mouseenter mouseleave" ).remove(); + jQuery( "#jc-inner" ).remove(); -}); +} ); -test("mouseenter, mouseleave don't catch exceptions", function() { - expect(2); +test( "mouseenter, mouseleave don't catch exceptions", function() { + expect( 2 ); - var elem = jQuery("#firstp").on( "mouseenter mouseleave", function() { + var elem = jQuery( "#firstp" ).on( "mouseenter mouseleave", function() { throw "an Exception"; - }); + } ); try { - elem.trigger("mouseenter"); - } catch (e) { + elem.trigger( "mouseenter" ); + } catch ( e ) { equal( e, "an Exception", "mouseenter doesn't catch exceptions" ); } try { - elem.trigger("mouseleave"); - } catch (e) { + elem.trigger( "mouseleave" ); + } catch ( e ) { equal( e, "an Exception", "mouseleave doesn't catch exceptions" ); } -}); +} ); if ( jQuery.fn.click ) { - test("trigger() shortcuts", function() { - expect(5); + test( "trigger() shortcuts", function() { + expect( 5 ); var counter, clickCounter, - elem = jQuery("<li><a href='#'>Change location</a></li>").prependTo("#firstUL"); - elem.find("a").on("click", function() { - var close = jQuery("spanx", this); // same with jQuery(this).find("span"); + elem = jQuery( "<li><a href='#'>Change location</a></li>" ).prependTo( "#firstUL" ); + elem.find( "a" ).on( "click", function() { + var close = jQuery( "spanx", this ); // same with jQuery(this).find("span"); equal( close.length, 0, "Context element does not exist, length must be zero" ); - ok( !close[0], "Context element does not exist, direct access to element must return undefined" ); + ok( !close[ 0 ], "Context element does not exist, direct access to element must return undefined" ); return false; - }).click(); + } ).click(); // manually clean up detached elements elem.remove(); - jQuery("#check1").click(function() { + jQuery( "#check1" ).click( function() { ok( true, "click event handler for checkbox gets fired twice, see #815" ); - }).click(); + } ).click(); counter = 0; - jQuery("#firstp")[0].onclick = function() { + jQuery( "#firstp" )[ 0 ].onclick = function() { counter++; }; - jQuery("#firstp").click(); + jQuery( "#firstp" ).click(); equal( counter, 1, "Check that click, triggers onclick event handler also" ); clickCounter = 0; - jQuery("#simon1")[0].onclick = function() { + jQuery( "#simon1" )[ 0 ].onclick = function() { clickCounter++; }; - jQuery("#simon1").click(); + jQuery( "#simon1" ).click(); equal( clickCounter, 1, "Check that click, triggers onclick event handler on an a tag also" ); // test that special handlers do not blow up with VML elements (#7071) - jQuery("<xml:namespace ns='urn:schemas-microsoft-com:vml' prefix='v' />").appendTo("head"); - jQuery("<v:oval id='oval' style='width:100pt;height:75pt;' fillcolor='red'> </v:oval>").appendTo("#form"); - jQuery("#oval").click().keydown(); - }); + jQuery( "<xml:namespace ns='urn:schemas-microsoft-com:vml' prefix='v' />" ).appendTo( "head" ); + jQuery( "<v:oval id='oval' style='width:100pt;height:75pt;' fillcolor='red'> </v:oval>" ).appendTo( "#form" ); + jQuery( "#oval" ).click().keydown(); + } ); } -test("trigger() bubbling", function() { - expect(18); +test( "trigger() bubbling", function() { + expect( 18 ); var win = 0, doc = 0, html = 0, body = 0, main = 0, ap = 0; - jQuery(window).on("click", function(){ win++; }); - jQuery(document).on("click", function( e ){ if ( e.target !== document) { doc++; } }); - jQuery("html").on("click", function(){ html++; }); - jQuery("body").on("click", function(){ body++; }); - jQuery("#qunit-fixture").on("click", function(){ main++; }); - jQuery("#ap").on("click", function(){ ap++; return false; }); + jQuery( window ).on( "click", function() { win++; } ); + jQuery( document ).on( "click", function( e ) { if ( e.target !== document ) { doc++; } } ); + jQuery( "html" ).on( "click", function() { html++; } ); + jQuery( "body" ).on( "click", function() { body++; } ); + jQuery( "#qunit-fixture" ).on( "click", function() { main++; } ); + jQuery( "#ap" ).on( "click", function() { ap++; return false; } ); - jQuery("html").trigger("click"); + jQuery( "html" ).trigger( "click" ); equal( win, 1, "HTML bubble" ); equal( doc, 1, "HTML bubble" ); equal( html, 1, "HTML bubble" ); - jQuery("body").trigger("click"); + jQuery( "body" ).trigger( "click" ); equal( win, 2, "Body bubble" ); equal( doc, 2, "Body bubble" ); equal( html, 2, "Body bubble" ); equal( body, 1, "Body bubble" ); - jQuery("#qunit-fixture").trigger("click"); + jQuery( "#qunit-fixture" ).trigger( "click" ); equal( win, 3, "Main bubble" ); equal( doc, 3, "Main bubble" ); equal( html, 3, "Main bubble" ); equal( body, 2, "Main bubble" ); equal( main, 1, "Main bubble" ); - jQuery("#ap").trigger("click"); + jQuery( "#ap" ).trigger( "click" ); equal( doc, 3, "ap bubble" ); equal( html, 3, "ap bubble" ); equal( body, 2, "ap bubble" ); equal( main, 1, "ap bubble" ); equal( ap, 1, "ap bubble" ); - jQuery( document ).trigger("click"); + jQuery( document ).trigger( "click" ); equal( win, 4, "doc bubble" ); // manually clean up events from elements outside the fixture - jQuery(window).off("click"); - jQuery(document).off("click"); - jQuery("html, body, #qunit-fixture").off("click"); -}); + jQuery( window ).off( "click" ); + jQuery( document ).off( "click" ); + jQuery( "html, body, #qunit-fixture" ).off( "click" ); +} ); -test("trigger(type, [data], [fn])", function() { - expect(16); +test( "trigger(type, [data], [fn])", function() { + expect( 16 ); var $elem, pass, form, elem2, - handler = function(event, a, b, c) { + handler = function( event, a, b, c ) { equal( event.type, "click", "check passed data" ); equal( a, 1, "check passed data" ); equal( b, "2", "check passed data" ); @@ -1005,92 +1010,91 @@ test("trigger(type, [data], [fn])", function() { return "test"; }; - $elem = jQuery("#firstp"); + $elem = jQuery( "#firstp" ); // Simulate a "native" click - $elem[0].click = function(){ + $elem[ 0 ].click = function() { ok( true, "Native call was triggered" ); }; - - jQuery( document ).on("mouseenter", "#firstp", function(){ + jQuery( document ).on( "mouseenter", "#firstp", function() { ok( true, "Trigger mouseenter bound by on" ); - }); + } ); - jQuery( document ).on("mouseleave", "#firstp", function(){ + jQuery( document ).on( "mouseleave", "#firstp", function() { ok( true, "Trigger mouseleave bound by on" ); - }); + } ); - $elem.trigger("mouseenter"); + $elem.trigger( "mouseenter" ); - $elem.trigger("mouseleave"); + $elem.trigger( "mouseleave" ); - jQuery( document ).off( "mouseenter mouseleave", "#firstp"); + jQuery( document ).off( "mouseenter mouseleave", "#firstp" ); // Triggers handlers and native // Trigger 5 - $elem.on("click", handler).trigger("click", [1, "2", "abc"]); + $elem.on( "click", handler ).trigger( "click", [ 1, "2", "abc" ] ); // Simulate a "native" click - $elem[0].click = function(){ + $elem[ 0 ].click = function() { ok( false, "Native call was triggered" ); }; // Trigger only the handlers (no native) // Triggers 5 - equal( $elem.triggerHandler("click", [1, "2", "abc"]), "test", "Verify handler response" ); + equal( $elem.triggerHandler( "click", [ 1, "2", "abc" ] ), "test", "Verify handler response" ); pass = true; try { - elem2 = jQuery("#form input").eq(0); - elem2.get(0).style.display = "none"; - elem2.trigger("focus"); - } catch( e ) { + elem2 = jQuery( "#form input" ).eq( 0 ); + elem2.get( 0 ).style.display = "none"; + elem2.trigger( "focus" ); + } catch ( e ) { pass = false; } ok( pass, "Trigger focus on hidden element" ); pass = true; try { - jQuery("#qunit-fixture table").eq(0).on("test:test", function(){}).trigger("test:test"); + jQuery( "#qunit-fixture table" ).eq( 0 ).on( "test:test", function() {} ).trigger( "test:test" ); } catch ( e ) { pass = false; } ok( pass, "Trigger on a table with a colon in the even type, see #3533" ); - form = jQuery("<form action=''></form>").appendTo("body"); + form = jQuery( "<form action=''></form>" ).appendTo( "body" ); // Make sure it can be prevented locally - form.on( "submit", function(){ + form.on( "submit", function() { ok( true, "Local `on` still works." ); return false; - }); + } ); // Trigger 1 - form.trigger("submit"); + form.trigger( "submit" ); - form.off("submit"); + form.off( "submit" ); - jQuery(document).on( "submit", function(){ + jQuery( document ).on( "submit", function() { ok( true, "Make sure bubble works up to document." ); return false; - }); + } ); // Trigger 1 - form.trigger("submit"); + form.trigger( "submit" ); - jQuery(document).off("submit"); + jQuery( document ).off( "submit" ); form.remove(); -}); +} ); test( "submit event bubbles on copied forms (#11649)", function() { expect( 3 ); var $formByClone, $formByHTML, - $testForm = jQuery("#testForm"), - $fixture = jQuery("#qunit-fixture"), - $wrapperDiv = jQuery("<div/>").appendTo( $fixture ); + $testForm = jQuery( "#testForm" ), + $fixture = jQuery( "#qunit-fixture" ), + $wrapperDiv = jQuery( "<div/>" ).appendTo( $fixture ); function noSubmit( e ) { e.preventDefault(); @@ -1104,29 +1108,29 @@ test( "submit event bubbles on copied forms (#11649)", function() { $fixture.on( "submit", "form", delegatedSubmit ); // Trigger form submission to introduce the _submit_attached property - $testForm.on( "submit", noSubmit ).find("input[name=sub1]").trigger("click"); + $testForm.on( "submit", noSubmit ).find( "input[name=sub1]" ).trigger( "click" ); // Copy the form via .clone() and .html() - $formByClone = $testForm.clone( true, true ).removeAttr("id"); - $formByHTML = jQuery( jQuery.parseHTML($fixture.html()) ).filter("#testForm").removeAttr("id"); + $formByClone = $testForm.clone( true, true ).removeAttr( "id" ); + $formByHTML = jQuery( jQuery.parseHTML( $fixture.html() ) ).filter( "#testForm" ).removeAttr( "id" ); $wrapperDiv.append( $formByClone, $formByHTML ); // Check submit bubbling on the copied forms - $wrapperDiv.find("form").on( "submit", noSubmit ).find("input[name=sub1]").trigger("click"); + $wrapperDiv.find( "form" ).on( "submit", noSubmit ).find( "input[name=sub1]" ).trigger( "click" ); // Clean up $wrapperDiv.remove(); $fixture.off( "submit", "form", delegatedSubmit ); $testForm.off( "submit", noSubmit ); -}); +} ); -test( "change event bubbles on copied forms (#11796)", function(){ +test( "change event bubbles on copied forms (#11796)", function() { expect( 3 ); var $formByClone, $formByHTML, - $form = jQuery("#form"), - $fixture = jQuery("#qunit-fixture"), - $wrapperDiv = jQuery("<div/>").appendTo( $fixture ); + $form = jQuery( "#form" ), + $fixture = jQuery( "#qunit-fixture" ), + $wrapperDiv = jQuery( "<div/>" ).appendTo( $fixture ); function delegatedChange() { ok( true, "Make sure change event bubbles up." ); @@ -1137,31 +1141,31 @@ test( "change event bubbles on copied forms (#11796)", function(){ $fixture.on( "change", "form", delegatedChange ); // Trigger change event to introduce the _change_attached property - $form.find("select[name=select1]").val("1").trigger("change"); + $form.find( "select[name=select1]" ).val( "1" ).trigger( "change" ); // Copy the form via .clone() and .html() - $formByClone = $form.clone( true, true ).removeAttr("id"); - $formByHTML = jQuery( jQuery.parseHTML($fixture.html()) ).filter("#form").removeAttr("id"); + $formByClone = $form.clone( true, true ).removeAttr( "id" ); + $formByHTML = jQuery( jQuery.parseHTML( $fixture.html() ) ).filter( "#form" ).removeAttr( "id" ); $wrapperDiv.append( $formByClone, $formByHTML ); // Check change bubbling on the copied forms - $wrapperDiv.find("form select[name=select1]").val("2").trigger("change"); + $wrapperDiv.find( "form select[name=select1]" ).val( "2" ).trigger( "change" ); // Clean up $wrapperDiv.remove(); $fixture.off( "change", "form", delegatedChange ); -}); +} ); -test("trigger(eventObject, [data], [fn])", function() { - expect(28); +test( "trigger(eventObject, [data], [fn])", function() { + expect( 28 ); var event, - $parent = jQuery("<div id='par' />").appendTo("body"), - $child = jQuery("<p id='child'>foo</p>").appendTo( $parent ); + $parent = jQuery( "<div id='par' />" ).appendTo( "body" ), + $child = jQuery( "<p id='child'>foo</p>" ).appendTo( $parent ); $parent.get( 0 ).style.display = "none"; - event = jQuery.Event("noNew"); + event = jQuery.Event( "noNew" ); ok( event !== window, "Instantiate jQuery.Event without the 'new' keyword" ); equal( event.type, "noNew", "Verify its type" ); @@ -1174,40 +1178,41 @@ test("trigger(eventObject, [data], [fn])", function() { event.stopPropagation(); equal( event.isPropagationStopped(), true, "Verify isPropagationStopped" ); - event.isPropagationStopped = function(){ return false; }; + event.isPropagationStopped = function() { return false; }; event.stopImmediatePropagation(); equal( event.isPropagationStopped(), true, "Verify isPropagationStopped" ); equal( event.isImmediatePropagationStopped(), true, "Verify isPropagationStopped" ); - $parent.on("foo",function( e ) { + $parent.on( "foo", function( e ) { + // Tries bubbling equal( e.type, "foo", "Verify event type when passed passing an event object" ); equal( e.target.id, "child", "Verify event.target when passed passing an event object" ); equal( e.currentTarget.id, "par", "Verify event.currentTarget when passed passing an event object" ); equal( e.secret, "boo!", "Verify event object's custom attribute when passed passing an event object" ); - }); + } ); // test with an event object - event = new jQuery.Event("foo"); + event = new jQuery.Event( "foo" ); event.secret = "boo!"; - $child.trigger(event); + $child.trigger( event ); // test with a literal object - $child.trigger({"type": "foo", "secret": "boo!"}); + $child.trigger( { "type": "foo", "secret": "boo!" } ); $parent.off(); - function error(){ - ok( false, "This assertion shouldn't be reached"); + function error() { + ok( false, "This assertion shouldn't be reached" ); } - $parent.on("foo", error ); + $parent.on( "foo", error ); - $child.on("foo",function(e, a, b, c ){ - equal( arguments.length, 4, "Check arguments length"); - equal( a, 1, "Check first custom argument"); - equal( b, 2, "Check second custom argument"); - equal( c, 3, "Check third custom argument"); + $child.on( "foo", function( e, a, b, c ) { + equal( arguments.length, 4, "Check arguments length" ); + equal( a, 1, "Check first custom argument" ); + equal( b, 2, "Check second custom argument" ); + equal( c, 3, "Check third custom argument" ); equal( e.isDefaultPrevented(), false, "Verify isDefaultPrevented" ); equal( e.isPropagationStopped(), false, "Verify isPropagationStopped" ); @@ -1217,18 +1222,18 @@ test("trigger(eventObject, [data], [fn])", function() { e.stopImmediatePropagation(); return "result"; - }); + } ); // We should add this back in when we want to test the order // in which event handlers are iterated. //$child.on("foo", error ); - event = new jQuery.Event("foo"); - $child.trigger( event, [1,2,3] ).off(); - equal( event.result, "result", "Check event.result attribute"); + event = new jQuery.Event( "foo" ); + $child.trigger( event, [ 1,2,3 ] ).off(); + equal( event.result, "result", "Check event.result attribute" ); // Will error if it bubbles - $child.triggerHandler("foo"); + $child.triggerHandler( "foo" ); $child.off(); $parent.off().remove(); @@ -1239,55 +1244,55 @@ test("trigger(eventObject, [data], [fn])", function() { equal( event.type, "zowie", "Verify its type" ); equal( event.isPropagationStopped(), false, "propagation not stopped" ); equal( event.isDefaultPrevented(), false, "default not prevented" ); -}); +} ); // Explicitly introduce global variable for oldIE so QUnit doesn't complain if checking globals window.onclick = undefined; -test(".trigger() bubbling on disconnected elements (#10489)", function() { - expect(2); +test( ".trigger() bubbling on disconnected elements (#10489)", function() { + expect( 2 ); - jQuery( window ).on( "click", function(){ + jQuery( window ).on( "click", function() { ok( false, "click fired on window" ); - }); + } ); jQuery( "<div><p>hi</p></div>" ) .on( "click", function() { ok( true, "click fired on div" ); - }) + } ) .find( "p" ) .on( "click", function() { ok( true, "click fired on p" ); - }) - .trigger("click") + } ) + .trigger( "click" ) .off( "click" ) .end() .off( "click" ) .remove(); jQuery( window ).off( "click" ); -}); +} ); -test(".trigger() doesn't bubble load event (#10717)", function() { - expect(1); +test( ".trigger() doesn't bubble load event (#10717)", function() { + expect( 1 ); - jQuery( window ).on( "load", function(){ + jQuery( window ).on( "load", function() { ok( false, "load fired on window" ); - }); + } ); // It's not an image, but as long as it fires load... - jQuery("<img src='index.html' />") + jQuery( "<img src='index.html' />" ) .appendTo( "body" ) .on( "load", function() { ok( true, "load fired on img" ); - }) + } ) .trigger( "load" ) .remove(); jQuery( window ).off( "load" ); -}); +} ); -test("Delegated events in SVG (#10791; #13180)", function() { - expect(2); +test( "Delegated events in SVG (#10791; #13180)", function() { + expect( 2 ); var useElem, e, svg = jQuery( @@ -1299,32 +1304,32 @@ test("Delegated events in SVG (#10791; #13180)", function() { "</svg>" ); - jQuery("#qunit-fixture") + jQuery( "#qunit-fixture" ) .append( svg ) .on( "click", "#svg-by-id", function() { ok( true, "delegated id selector" ); - }) + } ) .on( "click", "[class~='svg-by-class']", function() { ok( true, "delegated class selector" ); - }) + } ) .find( "#svg-by-id, [class~='svg-by-class']" ) - .trigger("click") + .trigger( "click" ) .end(); // Fire a native click on an SVGElementInstance (the instance tree of an SVG <use>) // to confirm that it doesn't break our event delegation handling (#13180) - useElem = svg.find("#use")[0]; + useElem = svg.find( "#use" )[ 0 ]; if ( document.createEvent && useElem && useElem.instanceRoot ) { - e = document.createEvent("MouseEvents"); + e = document.createEvent( "MouseEvents" ); e.initEvent( "click", true, true ); useElem.instanceRoot.dispatchEvent( e ); } - jQuery("#qunit-fixture").off("click"); -}); + jQuery( "#qunit-fixture" ).off( "click" ); +} ); -test("Delegated events in forms (#10844; #11145; #8165; #11382, #11764)", function() { - expect(5); +test( "Delegated events in forms (#10844; #11145; #8165; #11382, #11764)", function() { + expect( 5 ); // Alias names like "id" cause havoc var form = jQuery( @@ -1334,36 +1339,36 @@ test("Delegated events in forms (#10844; #11145; #8165; #11382, #11764)", functi ) .on( "submit", function( event ) { event.preventDefault(); - }) - .appendTo("body"); + } ) + .appendTo( "body" ); - jQuery("body") + jQuery( "body" ) .on( "submit", "#myform", function() { ok( true, "delegated id selector with aliased id" ); - }) - .find("#myform") - .trigger("submit") + } ) + .find( "#myform" ) + .trigger( "submit" ) .end() - .off("submit"); + .off( "submit" ); - form.append("<input type='text' name='disabled' value='differently abled' />"); - jQuery("body") + form.append( "<input type='text' name='disabled' value='differently abled' />" ); + jQuery( "body" ) .on( "submit", "#myform", function() { ok( true, "delegated id selector with aliased disabled" ); - }) - .find("#myform") - .trigger("submit") + } ) + .find( "#myform" ) + .trigger( "submit" ) .end() - .off("submit"); + .off( "submit" ); form .append( "<button id='nestyDisabledBtn'><span>Zing</span></button>" ) .on( "click", "#nestyDisabledBtn", function() { ok( true, "click on enabled/disabled button with nesty elements" ); - }) + } ) .on( "mouseover", "#nestyDisabledBtn", function() { ok( true, "mouse on enabled/disabled button with nesty elements" ); - }) + } ) .find( "span" ) .trigger( "click" ) // yep .trigger( "mouseover" ) // yep @@ -1376,10 +1381,10 @@ test("Delegated events in forms (#10844; #11145; #8165; #11382, #11764)", functi .off( "click" ); form.remove(); -}); +} ); -test("Submit event can be stopped (#11049)", function() { - expect(1); +test( "Submit event can be stopped (#11049)", function() { + expect( 1 ); // Since we manually bubble in IE, make sure inner handlers get a chance to cancel var form = jQuery( @@ -1388,33 +1393,33 @@ test("Submit event can be stopped (#11049)", function() { "<input type='submit' />" + "</form>" ) - .appendTo("body"); + .appendTo( "body" ); jQuery( "body" ) .on( "submit", function() { ok( true, "submit bubbled on first handler" ); return false; - }) + } ) .find( "#myform input[type=submit]" ) - .each( function(){ this.click(); } ) + .each( function() { this.click(); } ) .end() .on( "submit", function() { ok( false, "submit bubbled on second handler" ); return false; - }) + } ) .find( "#myform input[type=submit]" ) - .each( function(){ + .each( function() { jQuery( this.form ).on( "submit", function( e ) { e.preventDefault(); e.stopPropagation(); - }); + } ); this.click(); - }) + } ) .end() .off( "submit" ); form.remove(); -}); +} ); // Test beforeunload event only if it supported. // Support: iOS 7+, Android<4.0 @@ -1422,56 +1427,56 @@ test("Submit event can be stopped (#11049)", function() { // handler making it impossible to feature-detect the support. if ( window.onbeforeunload === null && !/(ipad|iphone|ipod|android 2\.3)/i.test( navigator.userAgent ) ) { - asyncTest("on(beforeunload)", 4, function() { + asyncTest( "on(beforeunload)", 4, function() { var win, fired = false, - iframe = jQuery("<iframe src='data/iframe.html' />"); + iframe = jQuery( "<iframe src='data/iframe.html' />" ); - iframe.appendTo("#qunit-fixture").one( "load", function() { + iframe.appendTo( "#qunit-fixture" ).one( "load", function() { win = this.contentWindow || this.contentDocument; jQuery( win ).on( "beforeunload", function() { fired = true; ok( true, "beforeunload event is fired" ); - }); + } ); strictEqual( win.onbeforeunload, null, "onbeforeunload property on window object still equals null" ); win.onbeforeunload = function() { ok( true, "window.onbeforeunload handler is called" ); - iframe = jQuery("<iframe src='data/iframe.html' />"); + iframe = jQuery( "<iframe src='data/iframe.html' />" ); - iframe.appendTo("#qunit-fixture").one( "load", function() { + iframe.appendTo( "#qunit-fixture" ).one( "load", function() { win = iframe[ 0 ].contentWindow || iframe[ 0 ].contentDocument; jQuery( win ).on( "beforeunload", function() { strictEqual( win.onbeforeunload, null, "Event handler is fired, even when onbeforeunload property on window is nulled" ); start(); - }); + } ); jQuery( win ).on( "unload", function() { if ( !fired ) { - jQuery( win ).trigger("beforeunload"); + jQuery( win ).trigger( "beforeunload" ); } - }); + } ); win.onbeforeunload = null; win.location.reload(); - }); + } ); }; win.location.reload(); - }); - }); + } ); + } ); } -test("jQuery.Event( type, props )", function() { +test( "jQuery.Event( type, props )", function() { - expect(6); + expect( 6 ); - var event = jQuery.Event( "keydown", { keyCode: 64 }), + var event = jQuery.Event( "keydown", { keyCode: 64 } ), handler = function( event ) { ok( "keyCode" in event, "Special property 'keyCode' exists" ); equal( event.keyCode, 64, "event.keyCode has explicit value '64'" ); @@ -1481,24 +1486,24 @@ test("jQuery.Event( type, props )", function() { equal( event.type, "keydown", "Verify type" ); // ensure "type" in props won't clobber the one set by constructor - equal( jQuery.inArray("type", jQuery.event.props), -1, "'type' property not in props (#10375)" ); + equal( jQuery.inArray( "type", jQuery.event.props ), -1, "'type' property not in props (#10375)" ); ok( "keyCode" in event, "Special 'keyCode' property exists" ); strictEqual( jQuery.isPlainObject( event ), false, "Instances of $.Event should not be identified as a plain object." ); - jQuery("body").on( "keydown", handler ).trigger( event ); + jQuery( "body" ).on( "keydown", handler ).trigger( event ); - jQuery("body").off( "keydown" ); + jQuery( "body" ).off( "keydown" ); -}); +} ); -test("jQuery.Event properties", function(){ - expect(12); +test( "jQuery.Event properties", function() { + expect( 12 ); var handler, event, - $structure = jQuery("<div id='ancestor'><p id='delegate'><span id='target'>shiny</span></p></div>"), - $target = $structure.find("#target"); + $structure = jQuery( "<div id='ancestor'><p id='delegate'><span id='target'>shiny</span></p></div>" ), + $target = $structure.find( "#target" ); handler = function( e ) { strictEqual( e.currentTarget, this, "currentTarget at " + this.id ); @@ -1507,50 +1512,50 @@ test("jQuery.Event properties", function(){ $structure.one( "click", handler ); $structure.one( "click", "p", handler ); $target.one( "click", handler ); - $target[0].onclick = function( e ) { + $target[ 0 ].onclick = function( e ) { strictEqual( e.currentTarget, this, "currentTarget at target (native handler)" ); equal( e.isTrigger, 3, "trigger at target (native handler)" ); }; - $target.trigger("click"); + $target.trigger( "click" ); $target.one( "click", function( e ) { equal( e.isTrigger, 2, "triggerHandler at target" ); - }); - $target[0].onclick = function( e ) { + } ); + $target[ 0 ].onclick = function( e ) { equal( e.isTrigger, 2, "triggerHandler at target (native handler)" ); }; - $target.triggerHandler("click"); + $target.triggerHandler( "click" ); handler = function( e ) { strictEqual( e.isTrigger, undefined, "native event at " + this.id ); event = e; }; $target.one( "click", handler ); - $target[0].onclick = function( e ) { + $target[ 0 ].onclick = function( e ) { strictEqual( e.isTrigger, undefined, "native event at target (native handler)" ); - $target[0].onclick = null; + $target[ 0 ].onclick = null; }; - fireNative( $target[0], "click" ); + fireNative( $target[ 0 ], "click" ); // Make sure that even oldIE executes the inline handler - if ( $target[0].onclick ) { - $target[0].onclick( event ); + if ( $target[ 0 ].onclick ) { + $target[ 0 ].onclick( event ); } -}); +} ); -test(".on()/.off()", function() { - expect(65); +test( ".on()/.off()", function() { + expect( 65 ); var event, clicked, hash, called, livec, lived, livee, submit = 0, div = 0, livea = 0, liveb = 0; - jQuery("#body").on("submit", "#qunit-fixture div", function(){ submit++; return false; }); - jQuery("#body").on("click", "#qunit-fixture div", function(){ div++; }); - jQuery("#body").on("click", "div#nothiddendiv", function(){ livea++; }); - jQuery("#body").on("click", "div#nothiddendivchild", function(){ liveb++; }); + jQuery( "#body" ).on( "submit", "#qunit-fixture div", function() { submit++; return false; } ); + jQuery( "#body" ).on( "click", "#qunit-fixture div", function() { div++; } ); + jQuery( "#body" ).on( "click", "div#nothiddendiv", function() { livea++; } ); + jQuery( "#body" ).on( "click", "div#nothiddendivchild", function() { liveb++; } ); // Nothing should trigger on the body - jQuery("body").trigger("click"); + jQuery( "body" ).trigger( "click" ); equal( submit, 0, "Click on body" ); equal( div, 0, "Click on body" ); equal( livea, 0, "Click on body" ); @@ -1558,7 +1563,7 @@ test(".on()/.off()", function() { // This should trigger two events submit = 0; div = 0; livea = 0; liveb = 0; - jQuery("div#nothiddendiv").trigger("click"); + jQuery( "div#nothiddendiv" ).trigger( "click" ); equal( submit, 0, "Click on div" ); equal( div, 1, "Click on div" ); equal( livea, 1, "Click on div" ); @@ -1566,7 +1571,7 @@ test(".on()/.off()", function() { // This should trigger three events (w/ bubbling) submit = 0; div = 0; livea = 0; liveb = 0; - jQuery("div#nothiddendivchild").trigger("click"); + jQuery( "div#nothiddendivchild" ).trigger( "click" ); equal( submit, 0, "Click on inner div" ); equal( div, 2, "Click on inner div" ); equal( livea, 1, "Click on inner div" ); @@ -1574,7 +1579,7 @@ test(".on()/.off()", function() { // This should trigger one submit submit = 0; div = 0; livea = 0; liveb = 0; - jQuery("div#nothiddendivchild").trigger("submit"); + jQuery( "div#nothiddendivchild" ).trigger( "submit" ); equal( submit, 1, "Submit on div" ); equal( div, 0, "Submit on div" ); equal( livea, 0, "Submit on div" ); @@ -1582,7 +1587,7 @@ test(".on()/.off()", function() { // Make sure no other events were removed in the process submit = 0; div = 0; livea = 0; liveb = 0; - jQuery("div#nothiddendivchild").trigger("click"); + jQuery( "div#nothiddendivchild" ).trigger( "click" ); equal( submit, 0, "off Click on inner div" ); equal( div, 2, "off Click on inner div" ); equal( livea, 1, "off Click on inner div" ); @@ -1590,8 +1595,8 @@ test(".on()/.off()", function() { // Now make sure that the removal works submit = 0; div = 0; livea = 0; liveb = 0; - jQuery("#body").off("click", "div#nothiddendivchild"); - jQuery("div#nothiddendivchild").trigger("click"); + jQuery( "#body" ).off( "click", "div#nothiddendivchild" ); + jQuery( "div#nothiddendivchild" ).trigger( "click" ); equal( submit, 0, "off Click on inner div" ); equal( div, 2, "off Click on inner div" ); equal( livea, 1, "off Click on inner div" ); @@ -1599,7 +1604,7 @@ test(".on()/.off()", function() { // Make sure that the click wasn't removed too early submit = 0; div = 0; livea = 0; liveb = 0; - jQuery("div#nothiddendiv").trigger("click"); + jQuery( "div#nothiddendiv" ).trigger( "click" ); equal( submit, 0, "off Click on inner div" ); equal( div, 1, "off Click on inner div" ); equal( livea, 1, "off Click on inner div" ); @@ -1607,8 +1612,8 @@ test(".on()/.off()", function() { // Make sure that stopPropagation doesn't stop live events submit = 0; div = 0; livea = 0; liveb = 0; - jQuery("#body").on("click", "div#nothiddendivchild", function( e ){ liveb++; e.stopPropagation(); }); - jQuery("div#nothiddendivchild").trigger("click"); + jQuery( "#body" ).on( "click", "div#nothiddendivchild", function( e ) { liveb++; e.stopPropagation(); } ); + jQuery( "div#nothiddendivchild" ).trigger( "click" ); equal( submit, 0, "stopPropagation Click on inner div" ); equal( div, 1, "stopPropagation Click on inner div" ); equal( livea, 0, "stopPropagation Click on inner div" ); @@ -1616,126 +1621,126 @@ test(".on()/.off()", function() { // Make sure click events only fire with primary click submit = 0; div = 0; livea = 0; liveb = 0; - event = jQuery.Event("click"); + event = jQuery.Event( "click" ); event.button = 1; - jQuery("div#nothiddendiv").trigger(event); + jQuery( "div#nothiddendiv" ).trigger( event ); equal( livea, 0, "on secondary click" ); - jQuery("#body").off("click", "div#nothiddendivchild"); - jQuery("#body").off("click", "div#nothiddendiv"); - jQuery("#body").off("click", "#qunit-fixture div"); - jQuery("#body").off("submit", "#qunit-fixture div"); + jQuery( "#body" ).off( "click", "div#nothiddendivchild" ); + jQuery( "#body" ).off( "click", "div#nothiddendiv" ); + jQuery( "#body" ).off( "click", "#qunit-fixture div" ); + jQuery( "#body" ).off( "submit", "#qunit-fixture div" ); // Test binding with a different context clicked = 0; - jQuery("#qunit-fixture").on("click", "#foo", function(){ clicked++; }); - jQuery("#qunit-fixture div").trigger("click"); - jQuery("#foo").trigger("click"); - jQuery("#qunit-fixture").trigger("click"); - jQuery("body").trigger("click"); + jQuery( "#qunit-fixture" ).on( "click", "#foo", function() { clicked++; } ); + jQuery( "#qunit-fixture div" ).trigger( "click" ); + jQuery( "#foo" ).trigger( "click" ); + jQuery( "#qunit-fixture" ).trigger( "click" ); + jQuery( "body" ).trigger( "click" ); equal( clicked, 2, "on with a context" ); // Test unbinding with a different context - jQuery("#qunit-fixture").off("click", "#foo"); - jQuery("#foo").trigger("click"); - equal( clicked, 2, "off with a context"); + jQuery( "#qunit-fixture" ).off( "click", "#foo" ); + jQuery( "#foo" ).trigger( "click" ); + equal( clicked, 2, "off with a context" ); // Test binding with event data - jQuery("#body").on("click", "#foo", true, function( e ){ equal( e.data, true, "on with event data" ); }); - jQuery("#foo").trigger("click"); - jQuery("#body").off("click", "#foo"); + jQuery( "#body" ).on( "click", "#foo", true, function( e ) { equal( e.data, true, "on with event data" ); } ); + jQuery( "#foo" ).trigger( "click" ); + jQuery( "#body" ).off( "click", "#foo" ); // Test binding with trigger data - jQuery("#body").on("click", "#foo", function(e, data){ equal( data, true, "on with trigger data" ); }); - jQuery("#foo").trigger("click", true); - jQuery("#body").off("click", "#foo"); + jQuery( "#body" ).on( "click", "#foo", function( e, data ) { equal( data, true, "on with trigger data" ); } ); + jQuery( "#foo" ).trigger( "click", true ); + jQuery( "#body" ).off( "click", "#foo" ); // Test binding with different this object - jQuery("#body").on("click", "#foo", jQuery.proxy(function(){ equal( this["foo"], "bar", "on with event scope" ); }, { "foo": "bar" })); - jQuery("#foo").trigger("click"); - jQuery("#body").off("click", "#foo"); + jQuery( "#body" ).on( "click", "#foo", jQuery.proxy( function() { equal( this[ "foo" ], "bar", "on with event scope" ); }, { "foo": "bar" } ) ); + jQuery( "#foo" ).trigger( "click" ); + jQuery( "#body" ).off( "click", "#foo" ); // Test binding with different this object, event data, and trigger data - jQuery("#body").on("click", "#foo", true, jQuery.proxy(function(e, data){ + jQuery( "#body" ).on( "click", "#foo", true, jQuery.proxy( function( e, data ) { equal( e.data, true, "on with with different this object, event data, and trigger data" ); equal( this.foo, "bar", "on with with different this object, event data, and trigger data" ); - equal( data, true, "on with with different this object, event data, and trigger data"); - }, { "foo": "bar" })); - jQuery("#foo").trigger("click", true); - jQuery("#body").off("click", "#foo"); + equal( data, true, "on with with different this object, event data, and trigger data" ); + }, { "foo": "bar" } ) ); + jQuery( "#foo" ).trigger( "click", true ); + jQuery( "#body" ).off( "click", "#foo" ); // Verify that return false prevents default action - jQuery("#body").on("click", "#anchor2", function(){ return false; }); + jQuery( "#body" ).on( "click", "#anchor2", function() { return false; } ); hash = window.location.hash; - jQuery("#anchor2").trigger("click"); + jQuery( "#anchor2" ).trigger( "click" ); equal( window.location.hash, hash, "return false worked" ); - jQuery("#body").off("click", "#anchor2"); + jQuery( "#body" ).off( "click", "#anchor2" ); // Verify that .preventDefault() prevents default action - jQuery("#body").on("click", "#anchor2", function(e){ e.preventDefault(); }); + jQuery( "#body" ).on( "click", "#anchor2", function( e ) { e.preventDefault(); } ); hash = window.location.hash; - jQuery("#anchor2").trigger("click"); + jQuery( "#anchor2" ).trigger( "click" ); equal( window.location.hash, hash, "e.preventDefault() worked" ); - jQuery("#body").off("click", "#anchor2"); + jQuery( "#body" ).off( "click", "#anchor2" ); // Test binding the same handler to multiple points called = 0; - function callback(){ called++; return false; } + function callback() { called++; return false; } - jQuery("#body").on("click", "#nothiddendiv", callback); - jQuery("#body").on("click", "#anchor2", callback); + jQuery( "#body" ).on( "click", "#nothiddendiv", callback ); + jQuery( "#body" ).on( "click", "#anchor2", callback ); - jQuery("#nothiddendiv").trigger("click"); + jQuery( "#nothiddendiv" ).trigger( "click" ); equal( called, 1, "Verify that only one click occurred." ); called = 0; - jQuery("#anchor2").trigger("click"); + jQuery( "#anchor2" ).trigger( "click" ); equal( called, 1, "Verify that only one click occurred." ); // Make sure that only one callback is removed - jQuery("#body").off("click", "#anchor2", callback); + jQuery( "#body" ).off( "click", "#anchor2", callback ); called = 0; - jQuery("#nothiddendiv").trigger("click"); + jQuery( "#nothiddendiv" ).trigger( "click" ); equal( called, 1, "Verify that only one click occurred." ); called = 0; - jQuery("#anchor2").trigger("click"); + jQuery( "#anchor2" ).trigger( "click" ); equal( called, 0, "Verify that no click occurred." ); // Make sure that it still works if the selector is the same, // but the event type is different - jQuery("#body").on("foo", "#nothiddendiv", callback); + jQuery( "#body" ).on( "foo", "#nothiddendiv", callback ); // Cleanup - jQuery("#body").off("click", "#nothiddendiv", callback); + jQuery( "#body" ).off( "click", "#nothiddendiv", callback ); called = 0; - jQuery("#nothiddendiv").trigger("click"); + jQuery( "#nothiddendiv" ).trigger( "click" ); equal( called, 0, "Verify that no click occurred." ); called = 0; - jQuery("#nothiddendiv").trigger("foo"); + jQuery( "#nothiddendiv" ).trigger( "foo" ); equal( called, 1, "Verify that one foo occurred." ); // Cleanup - jQuery("#body").off("foo", "#nothiddendiv", callback); + jQuery( "#body" ).off( "foo", "#nothiddendiv", callback ); // Make sure we don't loose the target by DOM modifications // after the bubble already reached the liveHandler livec = 0; - jQuery("#nothiddendivchild").html("<span></span>"); + jQuery( "#nothiddendivchild" ).html( "<span></span>" ); - jQuery("#body").on("click", "#nothiddendivchild", function(){ jQuery("#nothiddendivchild").html(""); }); - jQuery("#body").on("click", "#nothiddendivchild", function(e){ if(e.target) {livec++;} }); + jQuery( "#body" ).on( "click", "#nothiddendivchild", function() { jQuery( "#nothiddendivchild" ).html( "" ); } ); + jQuery( "#body" ).on( "click", "#nothiddendivchild", function( e ) { if ( e.target ) {livec++;} } ); - jQuery("#nothiddendiv span").trigger("click"); - equal( jQuery("#nothiddendiv span").length, 0, "Verify that first handler occurred and modified the DOM." ); + jQuery( "#nothiddendiv span" ).trigger( "click" ); + equal( jQuery( "#nothiddendiv span" ).length, 0, "Verify that first handler occurred and modified the DOM." ); equal( livec, 1, "Verify that second handler occurred even with nuked target." ); // Cleanup - jQuery("#body").off("click", "#nothiddendivchild"); + jQuery( "#body" ).off( "click", "#nothiddendivchild" ); // Verify that .live() occurs and cancel bubble in the same order as // we would expect .on() and .click() without delegation @@ -1743,204 +1748,204 @@ test(".on()/.off()", function() { livee = 0; // bind one pair in one order - jQuery("#body").on("click", "span#liveSpan1 a", function(){ lived++; return false; }); - jQuery("#body").on("click", "span#liveSpan1", function(){ livee++; }); + jQuery( "#body" ).on( "click", "span#liveSpan1 a", function() { lived++; return false; } ); + jQuery( "#body" ).on( "click", "span#liveSpan1", function() { livee++; } ); - jQuery("span#liveSpan1 a").trigger("click"); + jQuery( "span#liveSpan1 a" ).trigger( "click" ); equal( lived, 1, "Verify that only one first handler occurred." ); equal( livee, 0, "Verify that second handler doesn't." ); // and one pair in inverse - jQuery("#body").on("click", "span#liveSpan2", function(){ livee++; }); - jQuery("#body").on("click", "span#liveSpan2 a", function(){ lived++; return false; }); + jQuery( "#body" ).on( "click", "span#liveSpan2", function() { livee++; } ); + jQuery( "#body" ).on( "click", "span#liveSpan2 a", function() { lived++; return false; } ); lived = 0; livee = 0; - jQuery("span#liveSpan2 a").trigger("click"); + jQuery( "span#liveSpan2 a" ).trigger( "click" ); equal( lived, 1, "Verify that only one first handler occurred." ); equal( livee, 0, "Verify that second handler doesn't." ); // Cleanup - jQuery("#body").off("click", "**"); + jQuery( "#body" ).off( "click", "**" ); // Test this, target and currentTarget are correct - jQuery("#body").on("click", "span#liveSpan1", function( e ) { + jQuery( "#body" ).on( "click", "span#liveSpan1", function( e ) { equal( this.id, "liveSpan1", "Check the this within a on handler" ); equal( e.currentTarget.id, "liveSpan1", "Check the event.currentTarget within a on handler" ); equal( e.delegateTarget, document.body, "Check the event.delegateTarget within a on handler" ); equal( e.target.nodeName.toUpperCase(), "A", "Check the event.target within a on handler" ); - }); + } ); - jQuery("span#liveSpan1 a").trigger("click"); + jQuery( "span#liveSpan1 a" ).trigger( "click" ); - jQuery("#body").off("click", "span#liveSpan1"); + jQuery( "#body" ).off( "click", "span#liveSpan1" ); // Work with deep selectors livee = 0; function clickB() { livee++; } - jQuery("#body").on("click", "#nothiddendiv div", function(){ livee++; }); - jQuery("#body").on("click", "#nothiddendiv div", clickB); - jQuery("#body").on("mouseover", "#nothiddendiv div", function(){ livee++; }); + jQuery( "#body" ).on( "click", "#nothiddendiv div", function() { livee++; } ); + jQuery( "#body" ).on( "click", "#nothiddendiv div", clickB ); + jQuery( "#body" ).on( "mouseover", "#nothiddendiv div", function() { livee++; } ); equal( livee, 0, "No clicks, deep selector." ); livee = 0; - jQuery("#nothiddendivchild").trigger("click"); + jQuery( "#nothiddendivchild" ).trigger( "click" ); equal( livee, 2, "Click, deep selector." ); livee = 0; - jQuery("#nothiddendivchild").trigger("mouseover"); + jQuery( "#nothiddendivchild" ).trigger( "mouseover" ); equal( livee, 1, "Mouseover, deep selector." ); - jQuery("#body").off("mouseover", "#nothiddendiv div"); + jQuery( "#body" ).off( "mouseover", "#nothiddendiv div" ); livee = 0; - jQuery("#nothiddendivchild").trigger("click"); + jQuery( "#nothiddendivchild" ).trigger( "click" ); equal( livee, 2, "Click, deep selector." ); livee = 0; - jQuery("#nothiddendivchild").trigger("mouseover"); + jQuery( "#nothiddendivchild" ).trigger( "mouseover" ); equal( livee, 0, "Mouseover, deep selector." ); - jQuery("#body").off("click", "#nothiddendiv div", clickB); + jQuery( "#body" ).off( "click", "#nothiddendiv div", clickB ); livee = 0; - jQuery("#nothiddendivchild").trigger("click"); + jQuery( "#nothiddendivchild" ).trigger( "click" ); equal( livee, 1, "Click, deep selector." ); - jQuery("#body").off("click", "#nothiddendiv div"); -}); + jQuery( "#body" ).off( "click", "#nothiddendiv div" ); +} ); -test("jQuery.off using dispatched jQuery.Event", function() { - expect(1); +test( "jQuery.off using dispatched jQuery.Event", function() { + expect( 1 ); - var markup = jQuery("<p><a href='#'>target</a></p>"), + var markup = jQuery( "<p><a href='#'>target</a></p>" ), count = 0; markup .on( "click.name", "a", function( event ) { equal( ++count, 1, "event called once before removal" ); jQuery().off( event ); - }) - .find("a").trigger("click").trigger("click").end() + } ) + .find( "a" ).trigger( "click" ).trigger( "click" ).end() .remove(); -}); +} ); test( "delegated event with delegateTarget-relative selector", function() { - expect(3); - var markup = jQuery("<div><ul><li><a id=\"a0\"></a><ul id=\"ul0\"><li class=test><a id=\"a0_0\"></a></li><li><a id=\"a0_1\"></a></li></ul></li></ul></div>").appendTo("#qunit-fixture"); + expect( 3 ); + var markup = jQuery( "<div><ul><li><a id=\"a0\"></a><ul id=\"ul0\"><li class=test><a id=\"a0_0\"></a></li><li><a id=\"a0_1\"></a></li></ul></li></ul></div>" ).appendTo( "#qunit-fixture" ); // Non-positional selector (#12383) - markup.find("#ul0") + markup.find( "#ul0" ) .on( "click", "div li a", function() { ok( false, "div is ABOVE the delegation point!" ); - }) + } ) .on( "click", "ul a", function() { ok( false, "ul IS the delegation point!" ); - }) + } ) .on( "click", "li.test a", function() { ok( true, "li.test is below the delegation point." ); - }) - .find("#a0_0").trigger("click").end() - .off("click"); + } ) + .find( "#a0_0" ).trigger( "click" ).end() + .off( "click" ); // Positional selector (#11315) - markup.find("ul").eq(0) + markup.find( "ul" ).eq( 0 ) .on( "click", ">li>a", function() { ok( this.id === "a0", "child li was clicked" ); - }) - .find("#ul0") + } ) + .find( "#ul0" ) .on( "click", "li:first>a", function() { - ok( this.id === "a0_0" , "first li under #u10 was clicked" ); - }) + ok( this.id === "a0_0", "first li under #u10 was clicked" ); + } ) .end() - .find("a").trigger("click").end() - .find("#ul0").off(); + .find( "a" ).trigger( "click" ).end() + .find( "#ul0" ).off(); markup.remove(); -}); +} ); test( "delegated event with selector matching Object.prototype property (#13203)", function() { - expect(1); + expect( 1 ); var matched = 0; - jQuery("#foo").on( "click", "toString", function() { + jQuery( "#foo" ).on( "click", "toString", function() { matched++; - }); + } ); - jQuery("#anchor2").trigger("click"); + jQuery( "#anchor2" ).trigger( "click" ); equal( matched, 0, "Nothing matched 'toString'" ); -}); +} ); test( "delegated event with intermediate DOM manipulation (#13208)", function() { - expect(1); + expect( 1 ); - jQuery("#foo").on( "click", "[id=sap]", function() {}); - jQuery("#sap").on( "click", "[id=anchor2]", function() { + jQuery( "#foo" ).on( "click", "[id=sap]", function() {} ); + jQuery( "#sap" ).on( "click", "[id=anchor2]", function() { document.createDocumentFragment().appendChild( this.parentNode ); ok( true, "Element removed" ); - }); - jQuery("#anchor2").trigger("click"); -}); + } ); + jQuery( "#anchor2" ).trigger( "click" ); +} ); -test("stopPropagation() stops directly-bound events on delegated target", function() { - expect(1); +test( "stopPropagation() stops directly-bound events on delegated target", function() { + expect( 1 ); - var markup = jQuery("<div><p><a href=\"#\">target</a></p></div>"); + var markup = jQuery( "<div><p><a href=\"#\">target</a></p></div>" ); markup .on( "click", function() { ok( false, "directly-bound event on delegate target was called" ); - }) + } ) .on( "click", "a", function( e ) { e.stopPropagation(); ok( true, "delegated handler was called" ); - }) - .find("a").trigger("click").end() + } ) + .find( "a" ).trigger( "click" ).end() .remove(); -}); +} ); -test("off all bound delegated events", function(){ - expect(2); +test( "off all bound delegated events", function() { + expect( 2 ); var count = 0, clicks = 0, - div = jQuery("#body"); + div = jQuery( "#body" ); - div.on( "click submit", "div#nothiddendivchild", function(){ count++; } ); - div.on( "click", function(){ clicks++; } ); + div.on( "click submit", "div#nothiddendivchild", function() { count++; } ); + div.on( "click", function() { clicks++; } ); div.off( undefined, "**" ); - jQuery("div#nothiddendivchild").trigger("click"); - jQuery("div#nothiddendivchild").trigger("submit"); + jQuery( "div#nothiddendivchild" ).trigger( "click" ); + jQuery( "div#nothiddendivchild" ).trigger( "submit" ); equal( count, 0, "Make sure no events were triggered." ); - div.trigger("click"); + div.trigger( "click" ); equal( clicks, 2, "Make sure delegated and directly bound event occurred." ); - div.off("click"); -}); + div.off( "click" ); +} ); -test("on with multiple delegated events", function(){ - expect(1); +test( "on with multiple delegated events", function() { + expect( 1 ); var count = 0, - div = jQuery("#body"); + div = jQuery( "#body" ); - div.on("click submit", "div#nothiddendivchild", function(){ count++; }); + div.on( "click submit", "div#nothiddendivchild", function() { count++; } ); - jQuery("div#nothiddendivchild").trigger("click"); - jQuery("div#nothiddendivchild").trigger("submit"); + jQuery( "div#nothiddendivchild" ).trigger( "click" ); + jQuery( "div#nothiddendivchild" ).trigger( "submit" ); equal( count, 2, "Make sure both the click and submit were triggered." ); - jQuery("#body").off( undefined, "**" ); -}); + jQuery( "#body" ).off( undefined, "**" ); +} ); -test("delegated on with change", function(){ - expect(8); +test( "delegated on with change", function() { + expect( 8 ); var select, checkbox, checkboxFunction, text, textChange, oldTextVal, @@ -1948,182 +1953,182 @@ test("delegated on with change", function(){ selectChange = 0, checkboxChange = 0; - select = jQuery("select[name='S1']"); - jQuery("#body").on("change", "select[name='S1']", function() { + select = jQuery( "select[name='S1']" ); + jQuery( "#body" ).on( "change", "select[name='S1']", function() { selectChange++; - }); + } ); - checkbox = jQuery("#check2"); - checkboxFunction = function(){ + checkbox = jQuery( "#check2" ); + checkboxFunction = function() { checkboxChange++; }; - jQuery("#body").on("change", "#check2", checkboxFunction); + jQuery( "#body" ).on( "change", "#check2", checkboxFunction ); // test click on select // second click that changed it selectChange = 0; - select[0].selectedIndex = select[0].selectedIndex ? 0 : 1; - select.trigger("change"); + select[ 0 ].selectedIndex = select[ 0 ].selectedIndex ? 0 : 1; + select.trigger( "change" ); equal( selectChange, 1, "Change on click." ); // test keys on select selectChange = 0; - select[0].selectedIndex = select[0].selectedIndex ? 0 : 1; - select.trigger("change"); + select[ 0 ].selectedIndex = select[ 0 ].selectedIndex ? 0 : 1; + select.trigger( "change" ); equal( selectChange, 1, "Change on keyup." ); // test click on checkbox - checkbox.trigger("change"); + checkbox.trigger( "change" ); equal( checkboxChange, 1, "Change on checkbox." ); // test blur/focus on text - text = jQuery("#name"); + text = jQuery( "#name" ); textChange = 0; oldTextVal = text.val(); - jQuery("#body").on("change", "#name", function() { + jQuery( "#body" ).on( "change", "#name", function() { textChange++; - }); + } ); - text.val(oldTextVal+"foo"); - text.trigger("change"); + text.val( oldTextVal + "foo" ); + text.trigger( "change" ); equal( textChange, 1, "Change on text input." ); - text.val(oldTextVal); - jQuery("#body").off("change", "#name"); + text.val( oldTextVal ); + jQuery( "#body" ).off( "change", "#name" ); // test blur/focus on password - password = jQuery("#name"); + password = jQuery( "#name" ); passwordChange = 0; oldPasswordVal = password.val(); - jQuery("#body").on("change", "#name", function() { + jQuery( "#body" ).on( "change", "#name", function() { passwordChange++; - }); + } ); - password.val(oldPasswordVal + "foo"); - password.trigger("change"); + password.val( oldPasswordVal + "foo" ); + password.trigger( "change" ); equal( passwordChange, 1, "Change on password input." ); - password.val(oldPasswordVal); - jQuery("#body").off("change", "#name"); + password.val( oldPasswordVal ); + jQuery( "#body" ).off( "change", "#name" ); // make sure die works // die all changes selectChange = 0; - jQuery("#body").off("change", "select[name='S1']"); - select[0].selectedIndex = select[0].selectedIndex ? 0 : 1; - select.trigger("change"); + jQuery( "#body" ).off( "change", "select[name='S1']" ); + select[ 0 ].selectedIndex = select[ 0 ].selectedIndex ? 0 : 1; + select.trigger( "change" ); equal( selectChange, 0, "Die on click works." ); selectChange = 0; - select[0].selectedIndex = select[0].selectedIndex ? 0 : 1; - select.trigger("change"); + select[ 0 ].selectedIndex = select[ 0 ].selectedIndex ? 0 : 1; + select.trigger( "change" ); equal( selectChange, 0, "Die on keyup works." ); // die specific checkbox - jQuery("#body").off("change", "#check2", checkboxFunction); - checkbox.trigger("change"); + jQuery( "#body" ).off( "change", "#check2", checkboxFunction ); + checkbox.trigger( "change" ); equal( checkboxChange, 1, "Die on checkbox." ); -}); +} ); -test("delegated on with submit", function() { +test( "delegated on with submit", function() { expect( 2 ); var count1 = 0, count2 = 0; - jQuery("#body").on("submit", "#testForm", function(ev) { + jQuery( "#body" ).on( "submit", "#testForm", function( ev ) { count1++; ev.preventDefault(); - }); + } ); - jQuery(document).on("submit", "body", function(ev) { + jQuery( document ).on( "submit", "body", function( ev ) { count2++; ev.preventDefault(); - }); + } ); - jQuery("#testForm input[name=sub1]").trigger("submit"); + jQuery( "#testForm input[name=sub1]" ).trigger( "submit" ); equal( count1, 1, "Verify form submit." ); equal( count2, 1, "Verify body submit." ); - jQuery("#body").off( undefined, "**" ); - jQuery(document).off( undefined, "**" ); -}); + jQuery( "#body" ).off( undefined, "**" ); + jQuery( document ).off( undefined, "**" ); +} ); -test("delegated off() with only namespaces", function() { - expect(2); +test( "delegated off() with only namespaces", function() { + expect( 2 ); - var $delegate = jQuery("#liveHandlerOrder"), + var $delegate = jQuery( "#liveHandlerOrder" ), count = 0; - $delegate.on("click.ns", "a", function() { + $delegate.on( "click.ns", "a", function() { count++; - }); + } ); - jQuery("a", $delegate).eq(0).trigger("click.ns"); + jQuery( "a", $delegate ).eq( 0 ).trigger( "click.ns" ); - equal( count, 1, "delegated click.ns"); + equal( count, 1, "delegated click.ns" ); $delegate.off( ".ns", "**" ); - jQuery("a", $delegate).eq(1).trigger("click.ns"); + jQuery( "a", $delegate ).eq( 1 ).trigger( "click.ns" ); - equal( count, 1, "no more .ns after off"); -}); + equal( count, 1, "no more .ns after off" ); +} ); -test("Non DOM element events", function() { - expect(1); +test( "Non DOM element events", function() { + expect( 1 ); var o = {}; - jQuery(o).on("nonelementobj", function() { + jQuery( o ).on( "nonelementobj", function() { ok( true, "Event on non-DOM object triggered" ); - }); + } ); - jQuery(o).trigger("nonelementobj").off("nonelementobj"); -}); + jQuery( o ).trigger( "nonelementobj" ).off( "nonelementobj" ); +} ); -test("inline handler returning false stops default", function() { - expect(1); +test( "inline handler returning false stops default", function() { + expect( 1 ); - var markup = jQuery("<div><a href=\"#\" onclick=\"return false\">x</a></div>"); - markup.on( "click", function(e) { - ok( e.isDefaultPrevented(), "inline handler prevented default"); + var markup = jQuery( "<div><a href=\"#\" onclick=\"return false\">x</a></div>" ); + markup.on( "click", function( e ) { + ok( e.isDefaultPrevented(), "inline handler prevented default" ); return false; - }); - markup.find("a").trigger("click"); - markup.off("click"); -}); + } ); + markup.find( "a" ).trigger( "click" ); + markup.off( "click" ); +} ); -test("window resize", function() { - expect(2); +test( "window resize", function() { + expect( 2 ); - jQuery(window).off(); + jQuery( window ).off(); - jQuery(window).on( "resize", function(){ + jQuery( window ).on( "resize", function() { ok( true, "Resize event fired." ); - }).trigger("resize").off("resize"); + } ).trigger( "resize" ).off( "resize" ); - ok( !jQuery._data(window, "events"), "Make sure all the events are gone." ); -}); + ok( !jQuery._data( window, "events" ), "Make sure all the events are gone." ); +} ); -test("focusin bubbles", function() { - expect(2); +test( "focusin bubbles", function() { + expect( 2 ); var input = jQuery( "<input type='text' />" ).prependTo( "body" ), order = 0; // focus the element so DOM focus won't fire - input[0].focus(); + input[ 0 ].focus(); - jQuery( "body" ).on( "focusin.focusinBubblesTest", function(){ + jQuery( "body" ).on( "focusin.focusinBubblesTest", function() { equal( 1, order++, "focusin on the body second" ); - }); + } ); - input.on( "focusin.focusinBubblesTest", function(){ + input.on( "focusin.focusinBubblesTest", function() { equal( 0, order++, "focusin on the element first" ); - }); + } ); // Removed since DOM focus is unreliable on test swarm // DOM focus method @@ -2140,32 +2145,32 @@ test("focusin bubbles", function() { input.remove(); jQuery( "body" ).off( "focusin.focusinBubblesTest" ); -}); +} ); -test("custom events with colons (#3533, #8272)", function() { - expect(1); +test( "custom events with colons (#3533, #8272)", function() { + expect( 1 ); - var tab = jQuery("<table><tr><td>trigger</td></tr></table>").appendTo("body"); + var tab = jQuery( "<table><tr><td>trigger</td></tr></table>" ).appendTo( "body" ); try { - tab.trigger("back:forth"); + tab.trigger( "back:forth" ); ok( true, "colon events don't throw" ); } catch ( e ) { ok( false, "colon events die" ); } tab.remove(); -}); +} ); -test(".on and .off", function() { - expect(9); +test( ".on and .off", function() { + expect( 9 ); var counter, mixfn, data, - $onandoff = jQuery("<div id=\"onandoff\"><p>on<b>and</b>off</p><div>worked<em>or</em>borked?</div></div>").appendTo("body"); + $onandoff = jQuery( "<div id=\"onandoff\"><p>on<b>and</b>off</p><div>worked<em>or</em>borked?</div></div>" ).appendTo( "body" ); // Simple case jQuery( "#onandoff" ) .on( "whip", function() { ok( true, "whipped it good" ); - }) + } ) .trigger( "whip" ) .off(); @@ -2173,12 +2178,12 @@ test(".on and .off", function() { counter = 0; jQuery( "#onandoff b" ) .on( "click", 5, function( e, trig ) { - counter += e.data + (trig || 9); // twice, 5+9+5+17=36 - }) + counter += e.data + ( trig || 9 ); // twice, 5+9+5+17=36 + } ) .one( "click", 7, function( e, trig ) { - counter += e.data + (trig || 11); // once, 7+11=18 - }) - .trigger("click") + counter += e.data + ( trig || 11 ); // once, 7+11=18 + } ) + .trigger( "click" ) .trigger( "click", 17 ) .off( "click" ); equal( counter, 54, "direct event bindings with data" ); @@ -2187,23 +2192,22 @@ test(".on and .off", function() { counter = 0; jQuery( "#onandoff" ) .on( "click", "em", 5, function( e, trig ) { - counter += e.data + (trig || 9); // twice, 5+9+5+17=36 - }) + counter += e.data + ( trig || 9 ); // twice, 5+9+5+17=36 + } ) .one( "click", "em", 7, function( e, trig ) { - counter += e.data + (trig || 11); // once, 7+11=18 - }) - .find("em") - .trigger("click") + counter += e.data + ( trig || 11 ); // once, 7+11=18 + } ) + .find( "em" ) + .trigger( "click" ) .trigger( "click", 17 ) .end() .off( "click", "em" ); equal( counter, 54, "delegated event bindings with data" ); - // Mixed event bindings and types counter = 0; - mixfn = function(e, trig) { - counter += (e.data || 0) + (trig || 1); + mixfn = function( e, trig ) { + counter += ( e.data || 0 ) + ( trig || 1 ); }; jQuery( "#onandoff" ) .on( " click clack cluck ", "em", 2, mixfn ) @@ -2212,7 +2216,7 @@ test(".on and .off", function() { .trigger( "what!" ) .each( function() { equal( counter, 0, "nothing triggered yet" ); - }) + } ) .find( "em" ) .one( "cluck", 3, mixfn ) .trigger( "cluck", 8 ) // 3+8 2+8 + 0+8 = 29 @@ -2221,12 +2225,12 @@ test(".on and .off", function() { .end() .each( function() { equal( counter, 49, "after triggering em element" ); - }) - .off( "cluck", function(){} ) // shouldn't remove anything + } ) + .off( "cluck", function() {} ) // shouldn't remove anything .trigger( "cluck", 2 ) // 0+2 = 2 .each( function() { equal( counter, 51, "after triggering #onandoff cluck" ); - }) + } ) .find( "b" ) .on( "click", 95, mixfn ) .on( "clack", "p", 97, mixfn ) @@ -2236,7 +2240,7 @@ test(".on and .off", function() { .end() .each( function() { equal( counter, 51, "after triggering b" ); - }) + } ) .trigger( "cluck", 3 ) // 0+3 = 3 .off( "clack", "em", mixfn ) .find( "em" ) @@ -2244,20 +2248,20 @@ test(".on and .off", function() { .end() .each( function() { equal( counter, 54, "final triggers" ); - }) + } ) .off( "click cluck" ); // We should have removed all the event handlers ... kinda hacky way to check this - data = jQuery.data[ jQuery( "#onandoff" )[0].expando ] || {}; - equal( data["events"], undefined, "no events left" ); + data = jQuery.data[ jQuery( "#onandoff" )[ 0 ].expando ] || {}; + equal( data[ "events" ], undefined, "no events left" ); $onandoff.remove(); -}); +} ); -test("special on name mapping", function() { +test( "special on name mapping", function() { expect( 7 ); - jQuery.event.special["slap"] = { + jQuery.event.special[ "slap" ] = { bindType: "click", delegateType: "swing", handle: function( event ) { @@ -2269,7 +2273,7 @@ test("special on name mapping", function() { ok( true, "event " + event.type + " triggered" ); }; - jQuery("<div><button id=\"mammy\">Are We Not Men?</button></div>") + jQuery( "<div><button id=\"mammy\">Are We Not Men?</button></div>" ) .on( "slap", "button", jQuery.noop ) .on( "swing", "button", comeback ) .find( "button" ) @@ -2288,15 +2292,16 @@ test("special on name mapping", function() { .trigger( "swing" ) .end() .remove(); - delete jQuery.event.special["slap"]; + delete jQuery.event.special[ "slap" ]; - jQuery.event.special["gutfeeling"] = { + jQuery.event.special[ "gutfeeling" ] = { bindType: "click", delegateType: "click", handle: function( event ) { equal( event.handleObj.origType, "gutfeeling", "got a gutfeeling" ); + // Need to call the handler since .one() uses it to unbind - return event.handleObj.handler.call( this , event ); + return event.handleObj.handler.call( this, event ); } }; @@ -2322,11 +2327,11 @@ test("special on name mapping", function() { .trigger( "gutfeeling" ) // This one should not .remove(); - delete jQuery.event.special["gutfeeling"]; -}); + delete jQuery.event.special[ "gutfeeling" ]; +} ); -test(".on and .off, selective mixed removal (#10705)", function() { - expect(7); +test( ".on and .off, selective mixed removal (#10705)", function() { + expect( 7 ); var timingx = function( e ) { ok( true, "triggered " + e.type ); @@ -2345,13 +2350,13 @@ test(".on and .off, selective mixed removal (#10705)", function() { .trigger( "click" ) // 2 .off( "future click" ) .trigger( "click" ); // 0 -}); +} ); -test(".on( event-map, null-selector, data ) #11130", function() { +test( ".on( event-map, null-selector, data ) #11130", function() { expect( 1 ); - var $p = jQuery("<p>Strange Pursuit</p>"), + var $p = jQuery( "<p>Strange Pursuit</p>" ), data = "bar", map = { "foo": function( event ) { @@ -2360,15 +2365,15 @@ test(".on( event-map, null-selector, data ) #11130", function() { } }; - $p.on( map, null, data ).trigger("foo"); -}); + $p.on( map, null, data ).trigger( "foo" ); +} ); -test("clone() delegated events (#11076)", function() { - expect(3); +test( "clone() delegated events (#11076)", function() { + expect( 3 ); var counter = { "center": 0, "fold": 0, "centerfold": 0 }, clicked = function() { - counter[ jQuery(this).text().replace(/\s+/, "") ]++; + counter[ jQuery( this ).text().replace( /\s+/, "" ) ]++; }, table = jQuery( "<table><tr><td>center</td><td>fold</td></tr></table>" ) @@ -2377,27 +2382,27 @@ test("clone() delegated events (#11076)", function() { .on( "click", "td:last-child", clicked ), clone = table.clone( true ); - clone.find("td").trigger("click"); - equal( counter["center"], 1, "first child" ); - equal( counter["fold"], 1, "last child" ); - equal( counter["centerfold"], 2, "all children" ); + clone.find( "td" ).trigger( "click" ); + equal( counter[ "center" ], 1, "first child" ); + equal( counter[ "fold" ], 1, "last child" ); + equal( counter[ "centerfold" ], 2, "all children" ); table.remove(); clone.remove(); -}); +} ); -test("checkbox state (#3827)", function() { +test( "checkbox state (#3827)", function() { expect( 9 ); - var markup = jQuery("<div><input type=checkbox><div>").appendTo("#qunit-fixture"), - cb = markup.find("input")[0]; + var markup = jQuery( "<div><input type=checkbox><div>" ).appendTo( "#qunit-fixture" ), + cb = markup.find( "input" )[ 0 ]; - jQuery(cb).on( "click", function(){ + jQuery( cb ).on( "click", function() { equal( this.checked, false, "just-clicked checkbox is not checked" ); - }); - markup.on( "click", function(){ + } ); + markup.on( "click", function() { equal( cb.checked, false, "checkbox is not checked in bubbled event" ); - }); + } ); // Native click cb.checked = true; @@ -2408,25 +2413,25 @@ test("checkbox state (#3827)", function() { // jQuery click cb.checked = true; equal( cb.checked, true, "jQuery - checkbox is initially checked" ); - jQuery( cb ).trigger("click"); + jQuery( cb ).trigger( "click" ); equal( cb.checked, false, "jQuery - checkbox is no longer checked" ); // Handlers only; checkbox state remains false jQuery( cb ).triggerHandler( "click" ); -}); +} ); -test("hover event no longer special since 1.9", function() { +test( "hover event no longer special since 1.9", function() { expect( 1 ); - jQuery("<div>craft</div>") + jQuery( "<div>craft</div>" ) .on( "hover", function( e ) { equal( e.type, "hover", "I am hovering!" ); - }) - .trigger("hover") - .off("hover"); -}); + } ) + .trigger( "hover" ) + .off( "hover" ); +} ); -test("fixHooks extensions", function() { +test( "fixHooks extensions", function() { expect( 2 ); // IE requires focusable elements to be visible, so append to body @@ -2435,9 +2440,9 @@ test("fixHooks extensions", function() { // Ensure the property doesn't exist $fixture.on( "click", function( event ) { - ok( !("blurrinessLevel" in event), "event.blurrinessLevel does not exist" ); - }); - fireNative( $fixture[0], "click" ); + ok( !( "blurrinessLevel" in event ), "event.blurrinessLevel does not exist" ); + } ); + fireNative( $fixture[ 0 ], "click" ); $fixture.off( "click" ); jQuery.event.fixHooks.click = { @@ -2450,13 +2455,13 @@ test("fixHooks extensions", function() { // Trigger a native click and ensure the property is set $fixture.on( "click", function( event ) { equal( event.blurrinessLevel, 42, "event.blurrinessLevel was set" ); - }); - fireNative( $fixture[0], "click" ); + } ); + fireNative( $fixture[ 0 ], "click" ); delete jQuery.event.fixHooks.click; $fixture.off( "click" ).remove(); jQuery.event.fixHooks.click = saved; -}); +} ); // IE8 doesn't support custom event triggering natively, but we can skip // this test in IE8 since a native HTML5 drag event will never occur there. @@ -2470,44 +2475,44 @@ if ( document.createEvent ) { $fixture.on( "dragmove", function( evt ) { ok( "pageX" in evt, "checking for pageX property on dragmove" ); ok( "pageY" in evt, "checking for pageY property on dragmove" ); - }); + } ); fireNative( $fixture[ 0 ], "dragmove" ); $fixture.on( "drop", function( evt ) { ok( "pageX" in evt, "checking for pageX property on drop" ); ok( "pageY" in evt, "checking for pageY property on drop" ); - }); + } ); fireNative( $fixture[ 0 ], "drop" ); $fixture.unbind( "dragmove drop" ).remove(); - }); + } ); } test( "focusin using non-element targets", function() { expect( 2 ); jQuery( document ).on( "focusin", function( e ) { ok( e.type === "focusin", "got a focusin event on a document" ); - }).trigger( "focusin" ).off( "focusin" ); + } ).trigger( "focusin" ).off( "focusin" ); jQuery( window ).on( "focusin", function( e ) { ok( e.type === "focusin", "got a focusin event on a window" ); - }).trigger( "focusin" ).off( "focusin" ); + } ).trigger( "focusin" ).off( "focusin" ); -}); +} ); testIframeWithCallback( "focusin from an iframe", "event/focusinCrossFrame.html", function( frameDoc ) { - expect(1); + expect( 1 ); var input = jQuery( frameDoc ).find( "#frame-input" ); // Create a focusin handler on the parent; shouldn't affect the iframe's fate jQuery ( "body" ).on( "focusin.iframeTest", function() { ok( false, "fired a focusin event in the parent document" ); - }); + } ); input.on( "focusin", function() { ok( true, "fired a focusin event in the iframe" ); - }); + } ); // Avoid a native event; Chrome can't force focus to another frame input.trigger( "focusin" ); @@ -2520,64 +2525,65 @@ testIframeWithCallback( "focusin from an iframe", "event/focusinCrossFrame.html" // Remove body handler manually since it's outside the fixture jQuery( "body" ).off( "focusin.iframeTest" ); -}); +} ); testIframeWithCallback( "jQuery.ready promise", "event/promiseReady.html", function( isOk ) { - expect(1); + expect( 1 ); ok( isOk, "$.when( $.ready ) works" ); -}); +} ); testIframeWithCallback( "Focusing iframe element", "event/focusElem.html", function( isOk ) { - expect(1); + expect( 1 ); ok( isOk, "Focused an element in an iframe" ); -}); +} ); testIframeWithCallback( "triggerHandler(onbeforeunload)", "event/triggerunload.html", function( isOk ) { expect( 1 ); ok( isOk, "Triggered onbeforeunload without an error" ); -}); +} ); // need PHP here to make the incepted IFRAME hang if ( hasPHP ) { testIframeWithCallback( "jQuery.ready synchronous load with long loading subresources", "event/syncReady.html", function( isOk ) { - expect(1); + expect( 1 ); ok( isOk, "jQuery loaded synchronously fires ready when the DOM can truly be interacted with" ); - }); + } ); } -test("change handler should be detached from element", function() { +test( "change handler should be detached from element", function() { expect( 2 ); var $fixture = jQuery( "<input type='text' id='change-ie-leak' />" ).appendTo( "body" ), originRemoveEvent = jQuery.removeEvent, - wrapperRemoveEvent = function(elem, type, handle){ - equal("change", type, "Event handler for 'change' event should be removed"); - equal("change-ie-leak", jQuery(elem).attr("id"), "Event handler for 'change' event should be removed from appropriate element"); - originRemoveEvent(elem, type, handle); + wrapperRemoveEvent = function( elem, type, handle ) { + equal( "change", type, "Event handler for 'change' event should be removed" ); + equal( "change-ie-leak", jQuery( elem ).attr( "id" ), "Event handler for 'change' event should be removed from appropriate element" ); + originRemoveEvent( elem, type, handle ); }; jQuery.removeEvent = wrapperRemoveEvent ; - $fixture.on( "change", function() {}); + $fixture.on( "change", function() {} ); $fixture.off( "change" ); $fixture.remove(); jQuery.removeEvent = originRemoveEvent; -}); +} ); -asyncTest("trigger click on checkbox, fires change event", function() { - expect(1); +asyncTest( "trigger click on checkbox, fires change event", function() { + expect( 1 ); - var check = jQuery("#check2"); + var check = jQuery( "#check2" ); check.on( "change", function() { + // get it? - check.off("change"); + check.off( "change" ); ok( true, "Change event fired as a result of triggered click" ); start(); - }).trigger("click"); -}); + } ).trigger( "click" ); +} ); test( "Namespace preserved when passed an Event (#12739)", function() { expect( 4 ); @@ -2588,84 +2594,84 @@ test( "Namespace preserved when passed an Event (#12739)", function() { triggered = 0, fooEvent; - markup.find("div") + markup.find( "div" ) .addBack() .on( "foo.bar", function( e ) { if ( !e.handled ) { triggered++; e.handled = true; equal( e.namespace, "bar", "namespace is bar" ); - jQuery( e.target ).find("div").each(function() { + jQuery( e.target ).find( "div" ).each( function() { jQuery( this ).triggerHandler( e ); - }); + } ); } - }) + } ) .on( "foo.bar2", function() { ok( false, "foo.bar2 called on trigger " + triggered + " id " + this.id ); - }); + } ); - markup.trigger("foo.bar"); - markup.trigger( jQuery.Event("foo.bar") ); - fooEvent = jQuery.Event("foo"); + markup.trigger( "foo.bar" ); + markup.trigger( jQuery.Event( "foo.bar" ) ); + fooEvent = jQuery.Event( "foo" ); fooEvent.namespace = "bar"; markup.trigger( fooEvent ); markup.remove(); equal( triggered, 3, "foo.bar triggered" ); -}); +} ); test( "make sure events cloned correctly", function() { expect( 18 ); var clone, - fixture = jQuery("#qunit-fixture"), - checkbox = jQuery("#check1"), - p = jQuery("#firstp"); + fixture = jQuery( "#qunit-fixture" ), + checkbox = jQuery( "#check1" ), + p = jQuery( "#firstp" ); fixture.on( "click change", function( event, result ) { ok( result, event.type + " on original element is fired" ); - }).on( "click", "#firstp", function( event, result ) { + } ).on( "click", "#firstp", function( event, result ) { ok( result, "Click on original child element though delegation is fired" ); - }).on( "change", "#check1", function( event, result ) { + } ).on( "change", "#check1", function( event, result ) { ok( result, "Change on original child element though delegation is fired" ); - }); + } ); - p.on("click", function() { + p.on( "click", function() { ok( true, "Click on original child element is fired" ); - }); + } ); - checkbox.on("change", function() { + checkbox.on( "change", function() { ok( true, "Change on original child element is fired" ); - }); + } ); - fixture.clone().trigger("click").trigger("change"); // 0 events should be fired + fixture.clone().trigger( "click" ).trigger( "change" ); // 0 events should be fired clone = fixture.clone( true ); - clone.find("p").eq(0).trigger( "click", true ); // 3 events should fire - clone.find("#check1").trigger( "change", true ); // 3 events should fire + clone.find( "p" ).eq( 0 ).trigger( "click", true ); // 3 events should fire + clone.find( "#check1" ).trigger( "change", true ); // 3 events should fire clone.remove(); clone = fixture.clone( true, true ); - clone.find("p").eq(0).trigger( "click", true ); // 3 events should fire - clone.find("#check1").trigger( "change", true ); // 3 events should fire + clone.find( "p" ).eq( 0 ).trigger( "click", true ); // 3 events should fire + clone.find( "#check1" ).trigger( "change", true ); // 3 events should fire fixture.off(); p.off(); checkbox.off(); - p.trigger("click"); // 0 should be fired - checkbox.trigger("change"); // 0 should be fired + p.trigger( "click" ); // 0 should be fired + checkbox.trigger( "change" ); // 0 should be fired - clone.find("p").eq(0).trigger( "click", true ); // 3 events should fire - clone.find("#check1").trigger( "change", true ); // 3 events should fire + clone.find( "p" ).eq( 0 ).trigger( "click", true ); // 3 events should fire + clone.find( "#check1" ).trigger( "change", true ); // 3 events should fire clone.remove(); - clone.find("p").eq(0).trigger("click"); // 0 should be fired - clone.find("#check1").trigger("change"); // 0 events should fire -}); + clone.find( "p" ).eq( 0 ).trigger( "click" ); // 0 should be fired + clone.find( "#check1" ).trigger( "change" ); // 0 events should fire +} ); test( "String.prototype.namespace does not cause trigger() to throw (#13360)", function() { expect( 1 ); @@ -2674,21 +2680,21 @@ test( "String.prototype.namespace does not cause trigger() to throw (#13360)", f String.prototype.namespace = function() {}; try { - jQuery("<p>").trigger("foo.bar"); - } catch( e ) { + jQuery( "<p>" ).trigger( "foo.bar" ); + } catch ( e ) { errored = true; } equal( errored, false, "trigger() did not throw exception" ); delete String.prototype.namespace; -}); +} ); test( "Inline event result is returned (#13993)", function() { expect( 1 ); - var result = jQuery("<p onclick='return 42'>hello</p>").triggerHandler("click"); + var result = jQuery( "<p onclick='return 42'>hello</p>" ).triggerHandler( "click" ); equal( result, 42, "inline handler returned value" ); -}); +} ); test( "preventDefault() on focusin does not throw exception", function( assert ) { expect( 1 ); @@ -2745,7 +2751,7 @@ test( "Donor event interference", function( assert ) { } ); test( "originalEvent property for IE8", function( assert ) { - if ( !(/msie 8\.0/i.test( window.navigator.userAgent )) ) { + if ( !( /msie 8\.0/i.test( window.navigator.userAgent ) ) ) { assert.expect( 1 ); assert.ok( true, "Assertions should run only in IE" ); return; @@ -2789,7 +2795,7 @@ test( "originalEvent property for IE8", function( assert ) { test( "originalEvent property for Chrome, Safari and FF of simulated event", function( assert ) { var userAgent = window.navigator.userAgent; - if ( !(/chrome/i.test( userAgent ) || + if ( !( /chrome/i.test( userAgent ) || /firefox/i.test( userAgent ) || /safari/i.test( userAgent ) ) ) { assert.expect( 1 ); @@ -2820,7 +2826,7 @@ test( "originalEvent property for Chrome, Safari and FF of simulated event", fun } ); // This tests are unreliable in Firefox -if ( !(/firefox/i.test( window.navigator.userAgent )) ) { +if ( !( /firefox/i.test( window.navigator.userAgent ) ) ) { test( "Check order of focusin/focusout events", function() { expect( 2 ); @@ -2830,15 +2836,15 @@ if ( !(/firefox/i.test( window.navigator.userAgent )) ) { input.on( "focus", function() { focus = true; - }).on( "focusin", function() { + } ).on( "focusin", function() { ok( !focus, "Focusin event should fire before focus does" ); - }).on( "blur", function() { + } ).on( "blur", function() { blur = true; - }).on( "focusout", function() { + } ).on( "focusout", function() { ok( !blur, "Focusout event should fire before blur does" ); - }); + } ); // gain focus input.trigger( "focus" ); @@ -2848,44 +2854,44 @@ if ( !(/firefox/i.test( window.navigator.userAgent )) ) { // cleanup input.off(); - }); + } ); - test("focus-blur order (#12868)", function() { + test( "focus-blur order (#12868)", function() { expect( 5 ); var order, - $text = jQuery("#text1"), - $radio = jQuery("#radio1").trigger("focus"); + $text = jQuery( "#text1" ), + $radio = jQuery( "#radio1" ).trigger( "focus" ); // Support: IE<11 // IE8-10 fire focus/blur events asynchronously; this is the resulting mess. // IE's browser window must be topmost for this to work properly!! stop(); - $radio[0].focus(); + $radio[ 0 ].focus(); setTimeout( function() { $text - .on( "focus", function(){ + .on( "focus", function() { equal( order++, 1, "text focus" ); - }) - .on( "blur", function(){ + } ) + .on( "blur", function() { equal( order++, 0, "text blur" ); - }); + } ); $radio - .on( "focus", function(){ + .on( "focus", function() { equal( order++, 1, "radio focus" ); - }) - .on( "blur", function(){ + } ) + .on( "blur", function() { equal( order++, 0, "radio blur" ); - }); + } ); // Enabled input getting focus order = 0; - equal( document.activeElement, $radio[0], "radio has focus" ); - $text.trigger("focus"); + equal( document.activeElement, $radio[ 0 ], "radio has focus" ); + $text.trigger( "focus" ); setTimeout( function() { - equal( document.activeElement, $text[0], "text has focus" ); + equal( document.activeElement, $text[ 0 ], "text has focus" ); // Run handlers without native method on an input order = 1; @@ -2894,5 +2900,5 @@ if ( !(/firefox/i.test( window.navigator.userAgent )) ) { start(); }, 50 ); }, 50 ); - }); + } ); } diff --git a/test/unit/exports.js b/test/unit/exports.js index c78b57250..113f42316 100644 --- a/test/unit/exports.js +++ b/test/unit/exports.js @@ -1,7 +1,7 @@ -module("exports", { teardown: moduleTeardown }); +module( "exports", { teardown: moduleTeardown } ); -test("amdModule", function() { - expect(1); +test( "amdModule", function() { + expect( 1 ); equal( jQuery, amdDefined, "Make sure defined module matches jQuery" ); -}); +} ); diff --git a/test/unit/manipulation.js b/test/unit/manipulation.js index 0db95cbd5..26aedcbe2 100644 --- a/test/unit/manipulation.js +++ b/test/unit/manipulation.js @@ -1,10 +1,10 @@ module( "manipulation", { teardown: moduleTeardown -}); +} ); // Ensure that an extended Array prototype doesn't break jQuery Array.prototype.arrayProtoFn = function() { - throw("arrayProtoFn should not be called"); + throw( "arrayProtoFn should not be called" ); }; function manipulationBareObj( value ) { @@ -36,31 +36,31 @@ test( "text()", function() { var expected, frag, $newLineTest; expected = "This link has class=\"blog\": Simon Willison's Weblog"; - equal( jQuery("#sap").text(), expected, "Check for merged text of more then one element." ); + equal( jQuery( "#sap" ).text(), expected, "Check for merged text of more then one element." ); // Check serialization of text values - equal( jQuery(document.createTextNode("foo")).text(), "foo", "Text node was retrieved from .text()." ); - notEqual( jQuery(document).text(), "", "Retrieving text for the document retrieves all text (#10724)." ); + equal( jQuery( document.createTextNode( "foo" ) ).text(), "foo", "Text node was retrieved from .text()." ); + notEqual( jQuery( document ).text(), "", "Retrieving text for the document retrieves all text (#10724)." ); // Retrieve from document fragments #10864 frag = document.createDocumentFragment(); - frag.appendChild( document.createTextNode("foo") ); + frag.appendChild( document.createTextNode( "foo" ) ); - equal( jQuery(frag).text(), "foo", "Document Fragment Text node was retrieved from .text()." ); + equal( jQuery( frag ).text(), "foo", "Document Fragment Text node was retrieved from .text()." ); - $newLineTest = jQuery("<div>test<br/>testy</div>").appendTo("#moretests"); - $newLineTest.find("br").replaceWith("\n"); + $newLineTest = jQuery( "<div>test<br/>testy</div>" ).appendTo( "#moretests" ); + $newLineTest.find( "br" ).replaceWith( "\n" ); equal( $newLineTest.text(), "test\ntesty", "text() does not remove new lines (#11153)" ); $newLineTest.remove(); -}); +} ); test( "text(undefined)", function() { expect( 1 ); - equal( jQuery("#foo").text("<div").text(undefined)[ 0 ].innerHTML, "<div", ".text(undefined) is chainable (#5571)" ); -}); + equal( jQuery( "#foo" ).text( "<div" ).text( undefined )[ 0 ].innerHTML, "<div", ".text(undefined) is chainable (#5571)" ); +} ); function testText( valueObj ) { @@ -68,12 +68,12 @@ function testText( valueObj ) { var val, j, expected, $multipleElements, $parentDiv, $childDiv; - val = valueObj("<div><b>Hello</b> cruel world!</div>"); - equal( jQuery("#foo").text(val)[ 0 ].innerHTML.replace(/>/g, ">"), "<div><b>Hello</b> cruel world!</div>", "Check escaped text" ); + val = valueObj( "<div><b>Hello</b> cruel world!</div>" ); + equal( jQuery( "#foo" ).text( val )[ 0 ].innerHTML.replace( />/g, ">" ), "<div><b>Hello</b> cruel world!</div>", "Check escaped text" ); // using contents will get comments regular, text, and comment nodes - j = jQuery("#nonnodes").contents(); - j.text( valueObj("hi!") ); + j = jQuery( "#nonnodes" ).contents(); + j.text( valueObj( "hi!" ) ); equal( jQuery( j[ 0 ] ).text(), "hi!", "Check node,textnode,comment with text()" ); equal( j[ 1 ].nodeValue, " there ", "Check node,textnode,comment with text()" ); @@ -85,26 +85,26 @@ function testText( valueObj ) { $multipleElements = jQuery( "<div>Hello</div>" ).add( "<div>World</div>" ); $multipleElements.text( expected ); - equal( $multipleElements.eq(0).text(), expected, "text() updates multiple elements (#11809)" ); - equal( $multipleElements.eq(1).text(), expected, "text() updates multiple elements (#11809)" ); + equal( $multipleElements.eq( 0 ).text(), expected, "text() updates multiple elements (#11809)" ); + equal( $multipleElements.eq( 1 ).text(), expected, "text() updates multiple elements (#11809)" ); // Prevent memory leaks #11809 $childDiv = jQuery( "<div/>" ); - $childDiv.data("leak", true); + $childDiv.data( "leak", true ); $parentDiv = jQuery( "<div/>" ); $parentDiv.append( $childDiv ); - $parentDiv.text("Dry off"); + $parentDiv.text( "Dry off" ); - equal( $childDiv.data("leak"), undefined, "Check for leaks (#11809)" ); + equal( $childDiv.data( "leak" ), undefined, "Check for leaks (#11809)" ); } test( "text(String)", function() { testText( manipulationBareObj ); -}); +} ); test( "text(Function)", function() { testText( manipulationFunctionReturningObj ); -}); +} ); test( "text(Function) with incoming value", function() { @@ -112,43 +112,43 @@ test( "text(Function) with incoming value", function() { var old = "This link has class=\"blog\": Simon Willison's Weblog"; - jQuery("#sap").text(function( i, val ) { + jQuery( "#sap" ).text( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); return "foobar"; - }); + } ); - equal( jQuery("#sap").text(), "foobar", "Check for merged text of more then one element." ); -}); + equal( jQuery( "#sap" ).text(), "foobar", "Check for merged text of more then one element." ); +} ); function testAppendForObject( valueObj, isFragment ) { var $base, type = isFragment ? " (DocumentFragment)" : " (Element)", text = "This link has class=\"blog\": Simon Willison's Weblog", - el = document.getElementById("sap").cloneNode( true ), - first = document.getElementById("first"), - yahoo = document.getElementById("yahoo"); + el = document.getElementById( "sap" ).cloneNode( true ), + first = document.getElementById( "first" ), + yahoo = document.getElementById( "yahoo" ); if ( isFragment ) { $base = document.createDocumentFragment(); - jQuery( el ).contents().each(function() { + jQuery( el ).contents().each( function() { $base.appendChild( this ); - }); + } ); $base = jQuery( $base ); } else { $base = jQuery( el ); } - equal( $base.clone().append( valueObj(first.cloneNode(true)) ).text(), + equal( $base.clone().append( valueObj( first.cloneNode( true ) ) ).text(), text + "Try them out:", "Check for appending of element" + type ); - equal( $base.clone().append( valueObj([ first.cloneNode(true), yahoo.cloneNode(true) ]) ).text(), + equal( $base.clone().append( valueObj( [ first.cloneNode( true ), yahoo.cloneNode( true ) ] ) ).text(), text + "Try them out:Yahoo", "Check for appending of array of elements" + type ); - equal( $base.clone().append( valueObj(jQuery("#yahoo, #first").clone()) ).text(), + equal( $base.clone().append( valueObj( jQuery( "#yahoo, #first" ).clone() ) ).text(), text + "YahooTry them out:", "Check for appending of jQuery object" + type ); @@ -158,27 +158,27 @@ function testAppendForObject( valueObj, isFragment ) { "Check for appending a number" + type ); - equal( $base.clone().append( valueObj([ jQuery("#first").clone(), jQuery("#yahoo, #google").clone() ]) ).text(), + equal( $base.clone().append( valueObj( [ jQuery( "#first" ).clone(), jQuery( "#yahoo, #google" ).clone() ] ) ).text(), text + "Try them out:GoogleYahoo", "Check for appending of array of jQuery objects" ); - equal( $base.clone().append( valueObj(" text with spaces ") ).text(), + equal( $base.clone().append( valueObj( " text with spaces " ) ).text(), text + " text with spaces ", "Check for appending text with spaces" + type ); - equal( $base.clone().append( valueObj([]) ).text(), + equal( $base.clone().append( valueObj( [] ) ).text(), text, "Check for appending an empty array" + type ); - equal( $base.clone().append( valueObj("") ).text(), + equal( $base.clone().append( valueObj( "" ) ).text(), text, "Check for appending an empty string" + type ); - equal( $base.clone().append( valueObj(document.getElementsByTagName("foo")) ).text(), + equal( $base.clone().append( valueObj( document.getElementsByTagName( "foo" ) ) ).text(), text, "Check for appending an empty nodelist" + type ); @@ -188,7 +188,7 @@ function testAppendForObject( valueObj, isFragment ) { "Make sure that multiple arguments works." + type ); - equal( $base.clone().append( valueObj(document.getElementById("form").cloneNode(true)) ).children("form").length, + equal( $base.clone().append( valueObj( document.getElementById( "form" ).cloneNode( true ) ) ).children( "form" ).length, 1, "Check for appending a form (#910)" + type ); @@ -205,130 +205,130 @@ function testAppend( valueObj ) { $input, $radioChecked, $radioUnchecked, $radioParent, $map, $table; defaultText = "Try them out:"; - result = jQuery("#first").append( valueObj("<b>buga</b>") ); + result = jQuery( "#first" ).append( valueObj( "<b>buga</b>" ) ); equal( result.text(), defaultText + "buga", "Check if text appending works" ); - equal( jQuery("#select3").append( valueObj("<option value='appendTest'>Append Test</option>") ).find("option:last-child").attr("value"), "appendTest", "Appending html options to select element" ); + equal( jQuery( "#select3" ).append( valueObj( "<option value='appendTest'>Append Test</option>" ) ).find( "option:last-child" ).attr( "value" ), "appendTest", "Appending html options to select element" ); - jQuery("#qunit-fixture form").append( valueObj("<input name='radiotest' type='radio' checked='checked' />") ); - jQuery("#qunit-fixture form input[name=radiotest]").each(function() { - ok( jQuery(this).is(":checked"), "Append checked radio" ); - }).remove(); + jQuery( "#qunit-fixture form" ).append( valueObj( "<input name='radiotest' type='radio' checked='checked' />" ) ); + jQuery( "#qunit-fixture form input[name=radiotest]" ).each( function() { + ok( jQuery( this ).is( ":checked" ), "Append checked radio" ); + } ).remove(); - jQuery("#qunit-fixture form").append( valueObj("<input name='radiotest2' type='radio' checked = 'checked' />") ); - jQuery("#qunit-fixture form input[name=radiotest2]").each(function() { - ok( jQuery(this).is(":checked"), "Append alternately formated checked radio" ); - }).remove(); + jQuery( "#qunit-fixture form" ).append( valueObj( "<input name='radiotest2' type='radio' checked = 'checked' />" ) ); + jQuery( "#qunit-fixture form input[name=radiotest2]" ).each( function() { + ok( jQuery( this ).is( ":checked" ), "Append alternately formated checked radio" ); + } ).remove(); - jQuery("#qunit-fixture form").append( valueObj("<input name='radiotest3' type='radio' checked />") ); - jQuery("#qunit-fixture form input[name=radiotest3]").each(function() { - ok( jQuery(this).is(":checked"), "Append HTML5-formated checked radio" ); - }).remove(); + jQuery( "#qunit-fixture form" ).append( valueObj( "<input name='radiotest3' type='radio' checked />" ) ); + jQuery( "#qunit-fixture form input[name=radiotest3]" ).each( function() { + ok( jQuery( this ).is( ":checked" ), "Append HTML5-formated checked radio" ); + } ).remove(); - jQuery("#qunit-fixture form").append( valueObj("<input type='radio' checked='checked' name='radiotest4' />") ); - jQuery("#qunit-fixture form input[name=radiotest4]").each(function() { - ok( jQuery(this).is(":checked"), "Append with name attribute after checked attribute" ); - }).remove(); + jQuery( "#qunit-fixture form" ).append( valueObj( "<input type='radio' checked='checked' name='radiotest4' />" ) ); + jQuery( "#qunit-fixture form input[name=radiotest4]" ).each( function() { + ok( jQuery( this ).is( ":checked" ), "Append with name attribute after checked attribute" ); + } ).remove(); message = "Test for appending a DOM node to the contents of an iframe"; - iframe = jQuery("#iframe")[ 0 ]; + iframe = jQuery( "#iframe" )[ 0 ]; iframeDoc = iframe.contentDocument || iframe.contentWindow && iframe.contentWindow.document; try { if ( iframeDoc && iframeDoc.body ) { - equal( jQuery(iframeDoc.body).append( valueObj("<div id='success'>test</div>") )[ 0 ].lastChild.id, "success", message ); + equal( jQuery( iframeDoc.body ).append( valueObj( "<div id='success'>test</div>" ) )[ 0 ].lastChild.id, "success", message ); } else { ok( true, message + " - can't test" ); } - } catch( e ) { + } catch ( e ) { strictEqual( e.message || e, undefined, message ); } - jQuery("<fieldset/>").appendTo("#form").append( valueObj("<legend id='legend'>test</legend>") ); + jQuery( "<fieldset/>" ).appendTo( "#form" ).append( valueObj( "<legend id='legend'>test</legend>" ) ); t( "Append legend", "#legend", [ "legend" ] ); - $map = jQuery("<map/>").append( valueObj("<area id='map01' shape='rect' coords='50,50,150,150' href='http://www.jquery.com/' alt='jQuery'>") ); + $map = jQuery( "<map/>" ).append( valueObj( "<area id='map01' shape='rect' coords='50,50,150,150' href='http://www.jquery.com/' alt='jQuery'>" ) ); equal( $map[ 0 ].childNodes.length, 1, "The area was inserted." ); equal( $map[ 0 ].firstChild.nodeName.toLowerCase(), "area", "The area was inserted." ); - jQuery("#select1").append( valueObj("<OPTION>Test</OPTION>") ); - equal( jQuery("#select1 option:last-child").text(), "Test", "Appending OPTION (all caps)" ); + jQuery( "#select1" ).append( valueObj( "<OPTION>Test</OPTION>" ) ); + equal( jQuery( "#select1 option:last-child" ).text(), "Test", "Appending OPTION (all caps)" ); - jQuery("#select1").append( valueObj("<optgroup label='optgroup'><option>optgroup</option></optgroup>") ); - equal( jQuery("#select1 optgroup").attr("label"), "optgroup", "Label attribute in newly inserted optgroup is correct" ); - equal( jQuery("#select1 option").last().text(), "optgroup", "Appending optgroup" ); + jQuery( "#select1" ).append( valueObj( "<optgroup label='optgroup'><option>optgroup</option></optgroup>" ) ); + equal( jQuery( "#select1 optgroup" ).attr( "label" ), "optgroup", "Label attribute in newly inserted optgroup is correct" ); + equal( jQuery( "#select1 option" ).last().text(), "optgroup", "Appending optgroup" ); - $table = jQuery("#table").empty(); + $table = jQuery( "#table" ).empty(); - jQuery.each( "thead tbody tfoot colgroup caption tr th td".split(" "), function( i, name ) { + jQuery.each( "thead tbody tfoot colgroup caption tr th td".split( " " ), function( i, name ) { $table.append( valueObj( "<" + name + "/>" ) ); ok( $table.find( name ).length >= 1, "Append " + name ); ok( jQuery.parseHTML( "<" + name + "/>" ).length, name + " wrapped correctly" ); - }); + } ); - jQuery("#table colgroup").append( valueObj("<col/>") ); - equal( jQuery("#table colgroup col").length, 1, "Append col" ); + jQuery( "#table colgroup" ).append( valueObj( "<col/>" ) ); + equal( jQuery( "#table colgroup col" ).length, 1, "Append col" ); - jQuery("#form") - .append( valueObj("<select id='appendSelect1'></select>") ) - .append( valueObj("<select id='appendSelect2'><option>Test</option></select>") ); + jQuery( "#form" ) + .append( valueObj( "<select id='appendSelect1'></select>" ) ) + .append( valueObj( "<select id='appendSelect2'><option>Test</option></select>" ) ); t( "Append Select", "#appendSelect1, #appendSelect2", [ "appendSelect1", "appendSelect2" ] ); - equal( "Two nodes", jQuery("<div />").append( "Two", " nodes" ).text(), "Appending two text nodes (#4011)" ); - equal( jQuery("<div />").append( "1", "", 3 ).text(), "13", "If median is false-like value, subsequent arguments should not be ignored" ); + equal( "Two nodes", jQuery( "<div />" ).append( "Two", " nodes" ).text(), "Appending two text nodes (#4011)" ); + equal( jQuery( "<div />" ).append( "1", "", 3 ).text(), "13", "If median is false-like value, subsequent arguments should not be ignored" ); // using contents will get comments regular, text, and comment nodes - j = jQuery("#nonnodes").contents(); - d = jQuery("<div/>").appendTo("#nonnodes").append( j ); + j = jQuery( "#nonnodes" ).contents(); + d = jQuery( "<div/>" ).appendTo( "#nonnodes" ).append( j ); - equal( jQuery("#nonnodes").length, 1, "Check node,textnode,comment append moved leaving just the div" ); + equal( jQuery( "#nonnodes" ).length, 1, "Check node,textnode,comment append moved leaving just the div" ); equal( d.contents().length, 3, "Check node,textnode,comment append works" ); - d.contents().appendTo("#nonnodes"); + d.contents().appendTo( "#nonnodes" ); d.remove(); - equal( jQuery("#nonnodes").contents().length, 3, "Check node,textnode,comment append cleanup worked" ); + equal( jQuery( "#nonnodes" ).contents().length, 3, "Check node,textnode,comment append cleanup worked" ); - $input = jQuery("<input type='checkbox'/>").prop( "checked", true ).appendTo("#testForm"); + $input = jQuery( "<input type='checkbox'/>" ).prop( "checked", true ).appendTo( "#testForm" ); equal( $input[ 0 ].checked, true, "A checked checkbox that is appended stays checked" ); - $radioChecked = jQuery("input[type='radio'][name='R1']").eq( 1 ); + $radioChecked = jQuery( "input[type='radio'][name='R1']" ).eq( 1 ); $radioParent = $radioChecked.parent(); - $radioUnchecked = jQuery("<input type='radio' name='R1' checked='checked'/>").appendTo( $radioParent ); - $radioChecked.trigger("click"); + $radioUnchecked = jQuery( "<input type='radio' name='R1' checked='checked'/>" ).appendTo( $radioParent ); + $radioChecked.trigger( "click" ); $radioUnchecked[ 0 ].checked = false; - jQuery("<div/>").insertBefore($radioParent).append($radioParent); + jQuery( "<div/>" ).insertBefore( $radioParent ).append( $radioParent ); equal( $radioChecked[ 0 ].checked, true, "Reappending radios uphold which radio is checked" ); equal( $radioUnchecked[ 0 ].checked, false, "Reappending radios uphold not being checked" ); - equal( jQuery("<div/>").append( valueObj("option<area/>") )[ 0 ].childNodes.length, 2, "HTML-string with leading text should be processed correctly" ); + equal( jQuery( "<div/>" ).append( valueObj( "option<area/>" ) )[ 0 ].childNodes.length, 2, "HTML-string with leading text should be processed correctly" ); } test( "append(String|Element|Array<Element>|jQuery)", function() { testAppend( manipulationBareObj ); -}); +} ); test( "append(Function)", function() { testAppend( manipulationFunctionReturningObj ); -}); +} ); test( "append(param) to object, see #11280", function() { expect( 5 ); - var object = jQuery( document.createElement("object") ).appendTo( document.body ); + var object = jQuery( document.createElement( "object" ) ).appendTo( document.body ); equal( object.children().length, 0, "object does not start with children" ); - object.append( jQuery("<param type='wmode' name='foo'>") ); + object.append( jQuery( "<param type='wmode' name='foo'>" ) ); equal( object.children().length, 1, "appended param" ); - equal( object.children().eq(0).attr("name"), "foo", "param has name=foo" ); + equal( object.children().eq( 0 ).attr( "name" ), "foo", "param has name=foo" ); - object = jQuery("<object><param type='baz' name='bar'></object>"); + object = jQuery( "<object><param type='baz' name='bar'></object>" ); equal( object.children().length, 1, "object created with child param" ); - equal( object.children().eq(0).attr("name"), "bar", "param has name=bar" ); -}); + equal( object.children().eq( 0 ).attr( "name" ), "bar", "param has name=bar" ); +} ); test( "append(Function) returns String", function() { @@ -337,86 +337,86 @@ test( "append(Function) returns String", function() { var defaultText, result, select, old; defaultText = "Try them out:"; - old = jQuery("#first").html(); + old = jQuery( "#first" ).html(); - result = jQuery("#first").append(function( i, val ) { + result = jQuery( "#first" ).append( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); return "<b>buga</b>"; - }); + } ); equal( result.text(), defaultText + "buga", "Check if text appending works" ); - select = jQuery("#select3"); + select = jQuery( "#select3" ); old = select.html(); - equal( select.append(function( i, val ) { + equal( select.append( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); return "<option value='appendTest'>Append Test</option>"; - }).find("option:last-child").attr("value"), "appendTest", "Appending html options to select element" ); -}); + } ).find( "option:last-child" ).attr( "value" ), "appendTest", "Appending html options to select element" ); +} ); test( "append(Function) returns Element", function() { expect( 2 ); var expected = "This link has class=\"blog\": Simon Willison's WeblogTry them out:", - old = jQuery("#sap").html(); + old = jQuery( "#sap" ).html(); - jQuery("#sap").append(function( i, val ) { + jQuery( "#sap" ).append( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); - return document.getElementById("first"); - }); - equal( jQuery("#sap").text(), expected, "Check for appending of element" ); -}); + return document.getElementById( "first" ); + } ); + equal( jQuery( "#sap" ).text(), expected, "Check for appending of element" ); +} ); test( "append(Function) returns Array<Element>", function() { expect( 2 ); var expected = "This link has class=\"blog\": Simon Willison's WeblogTry them out:Yahoo", - old = jQuery("#sap").html(); + old = jQuery( "#sap" ).html(); - jQuery("#sap").append(function( i, val ) { + jQuery( "#sap" ).append( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); - return [ document.getElementById("first"), document.getElementById("yahoo") ]; - }); - equal( jQuery("#sap").text(), expected, "Check for appending of array of elements" ); -}); + return [ document.getElementById( "first" ), document.getElementById( "yahoo" ) ]; + } ); + equal( jQuery( "#sap" ).text(), expected, "Check for appending of array of elements" ); +} ); test( "append(Function) returns jQuery", function() { expect( 2 ); var expected = "This link has class=\"blog\": Simon Willison's WeblogYahooTry them out:", - old = jQuery("#sap").html(); + old = jQuery( "#sap" ).html(); - jQuery("#sap").append(function( i, val ) { + jQuery( "#sap" ).append( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); - return jQuery("#yahoo, #first"); - }); - equal( jQuery("#sap").text(), expected, "Check for appending of jQuery object" ); -}); + return jQuery( "#yahoo, #first" ); + } ); + equal( jQuery( "#sap" ).text(), expected, "Check for appending of jQuery object" ); +} ); test( "append(Function) returns Number", function() { expect( 2 ); - var old = jQuery("#sap").html(); + var old = jQuery( "#sap" ).html(); - jQuery("#sap").append(function( i, val ) { + jQuery( "#sap" ).append( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); return 5; - }); - ok( jQuery("#sap")[ 0 ].innerHTML.match( /5$/ ), "Check for appending a number" ); -}); + } ); + ok( jQuery( "#sap" )[ 0 ].innerHTML.match( /5$/ ), "Check for appending a number" ); +} ); test( "XML DOM manipulation (#9960)", function() { expect( 5 ); var scxml1Adopted, - xmlDoc1 = jQuery.parseXML("<scxml xmlns='http://www.w3.org/2005/07/scxml' version='1.0'><state x='100' y='100' initial='actions' id='provisioning'></state><state x='100' y='100' id='error'></state><state x='100' y='100' id='finished' final='true'></state></scxml>"), - xmlDoc2 = jQuery.parseXML("<scxml xmlns='http://www.w3.org/2005/07/scxml' version='1.0'><state id='provisioning3'></state></scxml>"), + xmlDoc1 = jQuery.parseXML( "<scxml xmlns='http://www.w3.org/2005/07/scxml' version='1.0'><state x='100' y='100' initial='actions' id='provisioning'></state><state x='100' y='100' id='error'></state><state x='100' y='100' id='finished' final='true'></state></scxml>" ), + xmlDoc2 = jQuery.parseXML( "<scxml xmlns='http://www.w3.org/2005/07/scxml' version='1.0'><state id='provisioning3'></state></scxml>" ), xml1 = jQuery( xmlDoc1 ), xml2 = jQuery( xmlDoc2 ), scxml1 = jQuery( "scxml", xml1 ), scxml2 = jQuery( "scxml", xml2 ), - state = scxml2.find("state"); + state = scxml2.find( "state" ); // Android 2.3 doesn't automatically adopt nodes from foreign documents. // Although technically this is compliant behavior, no other browser @@ -428,16 +428,16 @@ test( "XML DOM manipulation (#9960)", function() { } scxml1.append( state ); - strictEqual( scxml1[0].lastChild, state[0], "append" ); + strictEqual( scxml1[ 0 ].lastChild, state[ 0 ], "append" ); scxml1.prepend( state ); - strictEqual( scxml1[0].firstChild, state[0], "prepend" ); + strictEqual( scxml1[ 0 ].firstChild, state[ 0 ], "prepend" ); - scxml1.find("#finished").after( state ); - strictEqual( scxml1[0].lastChild, state[0], "after" ); + scxml1.find( "#finished" ).after( state ); + strictEqual( scxml1[ 0 ].lastChild, state[ 0 ], "after" ); - scxml1.find("#provisioning").before( state ); - strictEqual( scxml1[0].firstChild, state[0], "before" ); + scxml1.find( "#provisioning" ).before( state ); + strictEqual( scxml1[ 0 ].firstChild, state[ 0 ], "before" ); // Support: Android 2.3 if ( /android 2\.3/i.test( navigator.userAgent ) ) { @@ -446,13 +446,13 @@ test( "XML DOM manipulation (#9960)", function() { } else { scxml2.replaceWith( scxml1 ); } - deepEqual( jQuery( "state", xml2 ).get(), scxml1.find("state").get(), "replaceWith" ); -}); + deepEqual( jQuery( "state", xml2 ).get(), scxml1.find( "state" ).get(), "replaceWith" ); +} ); test( "append the same fragment with events (Bug #6997, 5566)", function() { var element, clone, - doExtra = !jQuery.support.noCloneEvent && document["fireEvent"]; + doExtra = !jQuery.support.noCloneEvent && document[ "fireEvent" ]; expect( 2 + ( doExtra ? 1 : 0 ) ); @@ -462,33 +462,33 @@ test( "append the same fragment with events (Bug #6997, 5566)", function() { // native event handlers on the original object don't get disturbed when they are // modified on the clone if ( doExtra ) { - element = jQuery("div:first").on( "click", function() { + element = jQuery( "div:first" ).on( "click", function() { ok( true, "Event exists on original after being unbound on clone" ); - jQuery( this ).off("click"); - }); - clone = element.clone( true ).off("click"); - clone[ 0 ].fireEvent("onclick"); - element[ 0 ].fireEvent("onclick"); + jQuery( this ).off( "click" ); + } ); + clone = element.clone( true ).off( "click" ); + clone[ 0 ].fireEvent( "onclick" ); + element[ 0 ].fireEvent( "onclick" ); // manually clean up detached elements clone.remove(); } - element = jQuery("<a class='test6997'></a>").on( "click", function() { + element = jQuery( "<a class='test6997'></a>" ).on( "click", function() { ok( true, "Append second element events work" ); - }); + } ); - jQuery("#listWithTabIndex li").append( element ) - .find("a.test6997").eq( 1 ).trigger("click"); + jQuery( "#listWithTabIndex li" ).append( element ) + .find( "a.test6997" ).eq( 1 ).trigger( "click" ); - element = jQuery("<li class='test6997'></li>").on( "click", function() { + element = jQuery( "<li class='test6997'></li>" ).on( "click", function() { ok( true, "Before second element events work" ); start(); - }); + } ); - jQuery("#listWithTabIndex li").before( element ); - jQuery("#listWithTabIndex li.test6997").eq( 1 ).trigger("click"); -}); + jQuery( "#listWithTabIndex li" ).before( element ); + jQuery( "#listWithTabIndex li.test6997" ).eq( 1 ).trigger( "click" ); +} ); test( "append HTML5 sectioning elements (Bug #6485)", function() { @@ -496,36 +496,36 @@ test( "append HTML5 sectioning elements (Bug #6485)", function() { var article, aside; - jQuery("#qunit-fixture").append("<article style='font-size:10px'><section><aside>HTML5 elements</aside></section></article>"); + jQuery( "#qunit-fixture" ).append( "<article style='font-size:10px'><section><aside>HTML5 elements</aside></section></article>" ); - article = jQuery("article"); - aside = jQuery("aside"); + article = jQuery( "article" ); + aside = jQuery( "aside" ); equal( article.get( 0 ).style.fontSize, "10px", "HTML5 elements are styleable" ); equal( aside.length, 1, "HTML5 elements do not collapse their children" ); -}); +} ); if ( jQuery.css ) { 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>"); + 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" ); - }); + notEqual( jQuery( "section" ).css( "background-color" ), "transparent", "HTML5 elements inherit styles" ); + } ); } test( "html(String) with HTML5 (Bug #6485)", function() { expect( 2 ); - jQuery("#qunit-fixture").html("<article><section><aside>HTML5 elements</aside></section></article>"); - equal( jQuery("#qunit-fixture").children().children().length, 1, "Make sure HTML5 article elements can hold children. innerHTML shortcut path" ); - equal( jQuery("#qunit-fixture").children().children().children().length, 1, "Make sure nested HTML5 elements can hold children." ); -}); + jQuery( "#qunit-fixture" ).html( "<article><section><aside>HTML5 elements</aside></section></article>" ); + equal( jQuery( "#qunit-fixture" ).children().children().length, 1, "Make sure HTML5 article elements can hold children. innerHTML shortcut path" ); + equal( jQuery( "#qunit-fixture" ).children().children().children().length, 1, "Make sure nested HTML5 elements can hold children." ); +} ); test( "html(String) tag-hyphenated elements (Bug #1987)", function() { @@ -538,40 +538,40 @@ test( "html(String) tag-hyphenated elements (Bug #1987)", function() { expect( 27 ); - jQuery.each( "thead tbody tfoot colgroup caption tr th td".split(" "), function( i, name ) { - var j = jQuery("<" + name + "-d></" + name + "-d><" + name + "-d></" + name + "-d>"); - ok( j[0], "Create a tag-hyphenated element" ); - ok( jQuery.nodeName(j[0], name.toUpperCase() + "-D"), "Hyphenated node name" ); - ok( jQuery.nodeName(j[1], name.toUpperCase() + "-D"), "Hyphenated node name" ); - }); + jQuery.each( "thead tbody tfoot colgroup caption tr th td".split( " " ), function( i, name ) { + var j = jQuery( "<" + name + "-d></" + name + "-d><" + name + "-d></" + name + "-d>" ); + ok( j[ 0 ], "Create a tag-hyphenated element" ); + ok( jQuery.nodeName( j[ 0 ], name.toUpperCase() + "-D" ), "Hyphenated node name" ); + ok( jQuery.nodeName( j[ 1 ], name.toUpperCase() + "-D" ), "Hyphenated node name" ); + } ); - var j = jQuery("<tr-multiple-hyphens><td-with-hyphen>text</td-with-hyphen></tr-multiple-hyphens>"); - ok( jQuery.nodeName(j[0], "TR-MULTIPLE-HYPHENS"), "Tags with multiple hypens" ); - ok( jQuery.nodeName(j.children()[0], "TD-WITH-HYPHEN"), "Tags with multiple hypens" ); + var j = jQuery( "<tr-multiple-hyphens><td-with-hyphen>text</td-with-hyphen></tr-multiple-hyphens>" ); + ok( jQuery.nodeName( j[ 0 ], "TR-MULTIPLE-HYPHENS" ), "Tags with multiple hypens" ); + ok( jQuery.nodeName( j.children()[ 0 ], "TD-WITH-HYPHEN" ), "Tags with multiple hypens" ); equal( j.children().text(), "text", "Tags with multiple hypens behave normally" ); -}); +} ); test( "IE8 serialization bug", function() { expect( 2 ); - var wrapper = jQuery("<div></div>"); + var wrapper = jQuery( "<div></div>" ); - wrapper.html("<div></div><article></article>"); - equal( wrapper.children("article").length, 1, "HTML5 elements are insertable with .html()" ); + wrapper.html( "<div></div><article></article>" ); + equal( wrapper.children( "article" ).length, 1, "HTML5 elements are insertable with .html()" ); - wrapper.html("<div></div><link></link>"); - equal( wrapper.children("link").length, 1, "Link elements are insertable with .html()" ); -}); + wrapper.html( "<div></div><link></link>" ); + equal( wrapper.children( "link" ).length, 1, "Link elements are insertable with .html()" ); +} ); test( "html() object element #10324", function() { expect( 1 ); - var object = jQuery("<object id='object2'><param name='object2test' value='test'></param></object>?").appendTo("#qunit-fixture"), + var object = jQuery( "<object id='object2'><param name='object2test' value='test'></param></object>?" ).appendTo( "#qunit-fixture" ), clone = object.clone(); equal( clone.html(), object.html(), "html() returns correct innerhtml of cloned object elements" ); -}); +} ); test( "append(xml)", function() { @@ -580,6 +580,7 @@ test( "append(xml)", function() { var xmlDoc, xml1, xml2; function createXMLDoc() { + // Initialize DOM based upon latest installed MSXML or Netscape var elem, n, len, aActiveX = @@ -592,23 +593,24 @@ test( "append(xml)", function() { if ( document.implementation && "createDocument" in document.implementation ) { return document.implementation.createDocument( "", "", null ); } else { + // IE for ( n = 0, len = aActiveX.length; n < len; n++ ) { try { elem = new ActiveXObject( aActiveX[ n ] ); return elem; - } catch(_) {} + } catch ( _ ) {} } } } xmlDoc = createXMLDoc(); - xml1 = xmlDoc.createElement("head"); - xml2 = xmlDoc.createElement("test"); + xml1 = xmlDoc.createElement( "head" ); + xml2 = xmlDoc.createElement( "test" ); - ok( jQuery(xml1).append(xml2), "Append an xml element to another without raising an exception." ); + ok( jQuery( xml1 ).append( xml2 ), "Append an xml element to another without raising an exception." ); -}); +} ); test( "appendTo(String)", function() { @@ -617,76 +619,76 @@ test( "appendTo(String)", function() { var l, defaultText; defaultText = "Try them out:"; - jQuery("<b>buga</b>").appendTo("#first"); - equal( jQuery("#first").text(), defaultText + "buga", "Check if text appending works" ); - equal( jQuery("<option value='appendTest'>Append Test</option>").appendTo("#select3").parent().find("option:last-child").attr("value"), "appendTest", "Appending html options to select element" ); - - l = jQuery("#first").children().length + 2; - jQuery("<strong>test</strong>"); - jQuery("<strong>test</strong>"); - jQuery([ jQuery("<strong>test</strong>")[ 0 ], jQuery("<strong>test</strong>")[ 0 ] ]) - .appendTo("#first"); - equal( jQuery("#first").children().length, l, "Make sure the elements were inserted." ); - equal( jQuery("#first").children().last()[ 0 ].nodeName.toLowerCase(), "strong", "Verify the last element." ); -}); + jQuery( "<b>buga</b>" ).appendTo( "#first" ); + equal( jQuery( "#first" ).text(), defaultText + "buga", "Check if text appending works" ); + equal( jQuery( "<option value='appendTest'>Append Test</option>" ).appendTo( "#select3" ).parent().find( "option:last-child" ).attr( "value" ), "appendTest", "Appending html options to select element" ); + + l = jQuery( "#first" ).children().length + 2; + jQuery( "<strong>test</strong>" ); + jQuery( "<strong>test</strong>" ); + jQuery( [ jQuery( "<strong>test</strong>" )[ 0 ], jQuery( "<strong>test</strong>" )[ 0 ] ] ) + .appendTo( "#first" ); + equal( jQuery( "#first" ).children().length, l, "Make sure the elements were inserted." ); + equal( jQuery( "#first" ).children().last()[ 0 ].nodeName.toLowerCase(), "strong", "Verify the last element." ); +} ); test( "appendTo(Element|Array<Element>)", function() { expect( 2 ); var expected = "This link has class=\"blog\": Simon Willison's WeblogTry them out:"; - jQuery( document.getElementById("first") ).appendTo("#sap"); - equal( jQuery("#sap").text(), expected, "Check for appending of element" ); + jQuery( document.getElementById( "first" ) ).appendTo( "#sap" ); + equal( jQuery( "#sap" ).text(), expected, "Check for appending of element" ); expected = "This link has class=\"blog\": Simon Willison's WeblogTry them out:Yahoo"; - jQuery([ document.getElementById("first"), document.getElementById("yahoo") ]).appendTo("#sap"); - equal( jQuery("#sap").text(), expected, "Check for appending of array of elements" ); + jQuery( [ document.getElementById( "first" ), document.getElementById( "yahoo" ) ] ).appendTo( "#sap" ); + equal( jQuery( "#sap" ).text(), expected, "Check for appending of array of elements" ); -}); +} ); test( "appendTo(jQuery)", function() { expect( 10 ); var expected, num, div; - ok( jQuery(document.createElement("script")).appendTo("body").length, "Make sure a disconnected script can be appended." ); + ok( jQuery( document.createElement( "script" ) ).appendTo( "body" ).length, "Make sure a disconnected script can be appended." ); expected = "This link has class=\"blog\": Simon Willison's WeblogYahooTry them out:"; - jQuery("#yahoo, #first").appendTo("#sap"); - equal( jQuery("#sap").text(), expected, "Check for appending of jQuery object" ); + jQuery( "#yahoo, #first" ).appendTo( "#sap" ); + equal( jQuery( "#sap" ).text(), expected, "Check for appending of jQuery object" ); - jQuery("#select1").appendTo("#foo"); + jQuery( "#select1" ).appendTo( "#foo" ); t( "Append select", "#foo select", [ "select1" ] ); - div = jQuery("<div/>").on( "click", function() { + div = jQuery( "<div/>" ).on( "click", function() { ok( true, "Running a cloned click." ); - }); - div.appendTo("#qunit-fixture, #moretests"); + } ); + div.appendTo( "#qunit-fixture, #moretests" ); - jQuery("#qunit-fixture div").last().trigger("click"); - jQuery("#moretests div").last().trigger("click"); + jQuery( "#qunit-fixture div" ).last().trigger( "click" ); + jQuery( "#moretests div" ).last().trigger( "click" ); - div = jQuery("<div/>").appendTo("#qunit-fixture, #moretests"); + div = jQuery( "<div/>" ).appendTo( "#qunit-fixture, #moretests" ); equal( div.length, 2, "appendTo returns the inserted elements" ); - div.addClass("test"); + div.addClass( "test" ); - ok( jQuery("#qunit-fixture div").last().hasClass("test"), "appendTo element was modified after the insertion" ); - ok( jQuery("#moretests div").last().hasClass("test"), "appendTo element was modified after the insertion" ); + ok( jQuery( "#qunit-fixture div" ).last().hasClass( "test" ), "appendTo element was modified after the insertion" ); + ok( jQuery( "#moretests div" ).last().hasClass( "test" ), "appendTo element was modified after the insertion" ); - div = jQuery("<div/>"); - jQuery("<span>a</span><b>b</b>").filter("span").appendTo( div ); + div = jQuery( "<div/>" ); + jQuery( "<span>a</span><b>b</b>" ).filter( "span" ).appendTo( div ); equal( div.children().length, 1, "Make sure the right number of children were inserted." ); - div = jQuery("#moretests div"); + div = jQuery( "#moretests div" ); - num = jQuery("#qunit-fixture div").length; - div.remove().appendTo("#qunit-fixture"); + num = jQuery( "#qunit-fixture div" ).length; + div.remove().appendTo( "#qunit-fixture" ); - equal( jQuery("#qunit-fixture div").length, num, "Make sure all the removed divs were inserted." ); -}); + equal( jQuery( "#qunit-fixture div" ).length, num, "Make sure all the removed divs were inserted." ); +} ); test( "prepend(String)", function() { @@ -694,10 +696,10 @@ test( "prepend(String)", function() { var result, expected; expected = "Try them out:"; - result = jQuery("#first").prepend( "<b>buga</b>" ); + result = jQuery( "#first" ).prepend( "<b>buga</b>" ); equal( result.text(), "buga" + expected, "Check if text prepending works" ); - equal( jQuery("#select3").prepend( "<option value='prependTest'>Prepend Test</option>" ).find("option:first-child").attr("value"), "prependTest", "Prepending html options to select element" ); -}); + equal( jQuery( "#select3" ).prepend( "<option value='prependTest'>Prepend Test</option>" ).find( "option:first-child" ).attr( "value" ), "prependTest", "Prepending html options to select element" ); +} ); test( "prepend(Element)", function() { @@ -705,9 +707,9 @@ test( "prepend(Element)", function() { var expected; expected = "Try them out:This link has class=\"blog\": Simon Willison's Weblog"; - jQuery("#sap").prepend( document.getElementById("first") ); - equal( jQuery("#sap").text(), expected, "Check for prepending of element" ); -}); + jQuery( "#sap" ).prepend( document.getElementById( "first" ) ); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of element" ); +} ); test( "prepend(Array<Element>)", function() { @@ -715,9 +717,9 @@ test( "prepend(Array<Element>)", function() { var expected; expected = "Try them out:YahooThis link has class=\"blog\": Simon Willison's Weblog"; - jQuery("#sap").prepend( [ document.getElementById("first"), document.getElementById("yahoo") ] ); - equal( jQuery("#sap").text(), expected, "Check for prepending of array of elements" ); -}); + jQuery( "#sap" ).prepend( [ document.getElementById( "first" ), document.getElementById( "yahoo" ) ] ); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of array of elements" ); +} ); test( "prepend(jQuery)", function() { @@ -725,9 +727,9 @@ test( "prepend(jQuery)", function() { var expected; expected = "YahooTry them out:This link has class=\"blog\": Simon Willison's Weblog"; - jQuery("#sap").prepend( jQuery("#yahoo, #first") ); - equal( jQuery("#sap").text(), expected, "Check for prepending of jQuery object" ); -}); + jQuery( "#sap" ).prepend( jQuery( "#yahoo, #first" ) ); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of jQuery object" ); +} ); test( "prepend(Array<jQuery>)", function() { @@ -735,9 +737,9 @@ test( "prepend(Array<jQuery>)", function() { var expected; expected = "Try them out:GoogleYahooThis link has class=\"blog\": Simon Willison's Weblog"; - jQuery("#sap").prepend( [ jQuery("#first"), jQuery("#yahoo, #google") ] ); - equal( jQuery("#sap").text(), expected, "Check for prepending of array of jQuery objects" ); -}); + jQuery( "#sap" ).prepend( [ jQuery( "#first" ), jQuery( "#yahoo, #google" ) ] ); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of array of jQuery objects" ); +} ); test( "prepend(Function) with incoming value -- String", function() { @@ -746,21 +748,21 @@ test( "prepend(Function) with incoming value -- String", function() { var defaultText, old, result; defaultText = "Try them out:"; - old = jQuery("#first").html(); - result = jQuery("#first").prepend(function( i, val ) { + old = jQuery( "#first" ).html(); + result = jQuery( "#first" ).prepend( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); return "<b>buga</b>"; - }); + } ); equal( result.text(), "buga" + defaultText, "Check if text prepending works" ); - old = jQuery("#select3").html(); + old = jQuery( "#select3" ).html(); - equal( jQuery("#select3").prepend(function( i, val ) { + equal( jQuery( "#select3" ).prepend( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); return "<option value='prependTest'>Prepend Test</option>"; - }).find("option:first-child").attr("value"), "prependTest", "Prepending html options to select element" ); -}); + } ).find( "option:first-child" ).attr( "value" ), "prependTest", "Prepending html options to select element" ); +} ); test( "prepend(Function) with incoming value -- Element", function() { @@ -768,15 +770,15 @@ test( "prepend(Function) with incoming value -- Element", function() { var old, expected; expected = "Try them out:This link has class=\"blog\": Simon Willison's Weblog"; - old = jQuery("#sap").html(); + old = jQuery( "#sap" ).html(); - jQuery("#sap").prepend(function( i, val ) { + jQuery( "#sap" ).prepend( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); - return document.getElementById("first"); - }); + return document.getElementById( "first" ); + } ); - equal( jQuery("#sap").text(), expected, "Check for prepending of element" ); -}); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of element" ); +} ); test( "prepend(Function) with incoming value -- Array<Element>", function() { @@ -784,15 +786,15 @@ test( "prepend(Function) with incoming value -- Array<Element>", function() { var old, expected; expected = "Try them out:YahooThis link has class=\"blog\": Simon Willison's Weblog"; - old = jQuery("#sap").html(); + old = jQuery( "#sap" ).html(); - jQuery("#sap").prepend(function( i, val ) { + jQuery( "#sap" ).prepend( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); - return [ document.getElementById("first"), document.getElementById("yahoo") ]; - }); + return [ document.getElementById( "first" ), document.getElementById( "yahoo" ) ]; + } ); - equal( jQuery("#sap").text(), expected, "Check for prepending of array of elements" ); -}); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of array of elements" ); +} ); test( "prepend(Function) with incoming value -- jQuery", function() { @@ -800,15 +802,15 @@ test( "prepend(Function) with incoming value -- jQuery", function() { var old, expected; expected = "YahooTry them out:This link has class=\"blog\": Simon Willison's Weblog"; - old = jQuery("#sap").html(); + old = jQuery( "#sap" ).html(); - jQuery("#sap").prepend(function( i, val ) { + jQuery( "#sap" ).prepend( function( i, val ) { equal( val, old, "Make sure the incoming value is correct." ); - return jQuery("#yahoo, #first"); - }); + return jQuery( "#yahoo, #first" ); + } ); - equal( jQuery("#sap").text(), expected, "Check for prepending of jQuery object" ); -}); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of jQuery object" ); +} ); test( "prependTo(String)", function() { @@ -817,11 +819,11 @@ test( "prependTo(String)", function() { var defaultText; defaultText = "Try them out:"; - jQuery("<b>buga</b>").prependTo("#first"); - equal( jQuery("#first").text(), "buga" + defaultText, "Check if text prepending works" ); - equal( jQuery("<option value='prependTest'>Prepend Test</option>").prependTo("#select3").parent().find("option:first-child").attr("value"), "prependTest", "Prepending html options to select element" ); + jQuery( "<b>buga</b>" ).prependTo( "#first" ); + equal( jQuery( "#first" ).text(), "buga" + defaultText, "Check if text prepending works" ); + equal( jQuery( "<option value='prependTest'>Prepend Test</option>" ).prependTo( "#select3" ).parent().find( "option:first-child" ).attr( "value" ), "prependTest", "Prepending html options to select element" ); -}); +} ); test( "prependTo(Element)", function() { @@ -830,9 +832,9 @@ test( "prependTo(Element)", function() { var expected; expected = "Try them out:This link has class=\"blog\": Simon Willison's Weblog"; - jQuery( document.getElementById("first") ).prependTo("#sap"); - equal( jQuery("#sap").text(), expected, "Check for prepending of element" ); -}); + jQuery( document.getElementById( "first" ) ).prependTo( "#sap" ); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of element" ); +} ); test( "prependTo(Array<Element>)", function() { @@ -841,9 +843,9 @@ test( "prependTo(Array<Element>)", function() { var expected; expected = "Try them out:YahooThis link has class=\"blog\": Simon Willison's Weblog"; - jQuery( [ document.getElementById("first"), document.getElementById("yahoo") ] ).prependTo("#sap"); - equal( jQuery("#sap").text(), expected, "Check for prepending of array of elements" ); -}); + jQuery( [ document.getElementById( "first" ), document.getElementById( "yahoo" ) ] ).prependTo( "#sap" ); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of array of elements" ); +} ); test( "prependTo(jQuery)", function() { @@ -852,19 +854,19 @@ test( "prependTo(jQuery)", function() { var expected; expected = "YahooTry them out:This link has class=\"blog\": Simon Willison's Weblog"; - jQuery("#yahoo, #first").prependTo("#sap"); - equal( jQuery("#sap").text(), expected, "Check for prepending of jQuery object" ); -}); + jQuery( "#yahoo, #first" ).prependTo( "#sap" ); + equal( jQuery( "#sap" ).text(), expected, "Check for prepending of jQuery object" ); +} ); test( "prependTo(Array<jQuery>)", function() { expect( 1 ); - jQuery("<select id='prependSelect1'></select>").prependTo("#form"); - jQuery("<select id='prependSelect2'><option>Test</option></select>").prependTo("#form"); + jQuery( "<select id='prependSelect1'></select>" ).prependTo( "#form" ); + jQuery( "<select id='prependSelect2'><option>Test</option></select>" ).prependTo( "#form" ); t( "Prepend Select", "#prependSelect2, #prependSelect1", [ "prependSelect2", "prependSelect1" ] ); -}); +} ); test( "before(String)", function() { @@ -873,9 +875,9 @@ test( "before(String)", function() { var expected; expected = "This is a normal link: bugaYahoo"; - jQuery("#yahoo").before( manipulationBareObj("<b>buga</b>") ); - equal( jQuery("#en").text(), expected, "Insert String before" ); -}); + jQuery( "#yahoo" ).before( manipulationBareObj( "<b>buga</b>" ) ); + equal( jQuery( "#en" ).text(), expected, "Insert String before" ); +} ); test( "before(Element)", function() { @@ -884,9 +886,9 @@ test( "before(Element)", function() { var expected; expected = "This is a normal link: Try them out:Yahoo"; - jQuery("#yahoo").before( manipulationBareObj(document.getElementById("first")) ); - equal( jQuery("#en").text(), expected, "Insert element before" ); -}); + jQuery( "#yahoo" ).before( manipulationBareObj( document.getElementById( "first" ) ) ); + equal( jQuery( "#en" ).text(), expected, "Insert element before" ); +} ); test( "before(Array<Element>)", function() { @@ -894,9 +896,9 @@ test( "before(Array<Element>)", function() { var expected; expected = "This is a normal link: Try them out:diveintomarkYahoo"; - jQuery("#yahoo").before( manipulationBareObj([ document.getElementById("first"), document.getElementById("mark") ]) ); - equal( jQuery("#en").text(), expected, "Insert array of elements before" ); -}); + jQuery( "#yahoo" ).before( manipulationBareObj( [ document.getElementById( "first" ), document.getElementById( "mark" ) ] ) ); + equal( jQuery( "#en" ).text(), expected, "Insert array of elements before" ); +} ); test( "before(jQuery)", function() { @@ -904,9 +906,9 @@ test( "before(jQuery)", function() { var expected; expected = "This is a normal link: diveintomarkTry them out:Yahoo"; - jQuery("#yahoo").before( manipulationBareObj(jQuery("#mark, #first")) ); - equal( jQuery("#en").text(), expected, "Insert jQuery before" ); -}); + jQuery( "#yahoo" ).before( manipulationBareObj( jQuery( "#mark, #first" ) ) ); + equal( jQuery( "#en" ).text(), expected, "Insert jQuery before" ); +} ); test( "before(Array<jQuery>)", function() { @@ -914,9 +916,9 @@ test( "before(Array<jQuery>)", function() { var expected; expected = "This is a normal link: Try them out:GooglediveintomarkYahoo"; - jQuery("#yahoo").before( manipulationBareObj([ jQuery("#first"), jQuery("#mark, #google") ]) ); - equal( jQuery("#en").text(), expected, "Insert array of jQuery objects before" ); -}); + jQuery( "#yahoo" ).before( manipulationBareObj( [ jQuery( "#first" ), jQuery( "#mark, #google" ) ] ) ); + equal( jQuery( "#en" ).text(), expected, "Insert array of jQuery objects before" ); +} ); test( "before(Function) -- Returns String", function() { @@ -925,9 +927,9 @@ test( "before(Function) -- Returns String", function() { var expected; expected = "This is a normal link: bugaYahoo"; - jQuery("#yahoo").before( manipulationFunctionReturningObj("<b>buga</b>") ); - equal( jQuery("#en").text(), expected, "Insert String before" ); -}); + jQuery( "#yahoo" ).before( manipulationFunctionReturningObj( "<b>buga</b>" ) ); + equal( jQuery( "#en" ).text(), expected, "Insert String before" ); +} ); test( "before(Function) -- Returns Element", function() { @@ -936,9 +938,9 @@ test( "before(Function) -- Returns Element", function() { var expected; expected = "This is a normal link: Try them out:Yahoo"; - jQuery("#yahoo").before( manipulationFunctionReturningObj(document.getElementById("first")) ); - equal( jQuery("#en").text(), expected, "Insert element before" ); -}); + jQuery( "#yahoo" ).before( manipulationFunctionReturningObj( document.getElementById( "first" ) ) ); + equal( jQuery( "#en" ).text(), expected, "Insert element before" ); +} ); test( "before(Function) -- Returns Array<Element>", function() { @@ -946,9 +948,9 @@ test( "before(Function) -- Returns Array<Element>", function() { var expected; expected = "This is a normal link: Try them out:diveintomarkYahoo"; - jQuery("#yahoo").before( manipulationFunctionReturningObj([ document.getElementById("first"), document.getElementById("mark") ]) ); - equal( jQuery("#en").text(), expected, "Insert array of elements before" ); -}); + jQuery( "#yahoo" ).before( manipulationFunctionReturningObj( [ document.getElementById( "first" ), document.getElementById( "mark" ) ] ) ); + equal( jQuery( "#en" ).text(), expected, "Insert array of elements before" ); +} ); test( "before(Function) -- Returns jQuery", function() { @@ -956,9 +958,9 @@ test( "before(Function) -- Returns jQuery", function() { var expected; expected = "This is a normal link: diveintomarkTry them out:Yahoo"; - jQuery("#yahoo").before( manipulationFunctionReturningObj(jQuery("#mark, #first")) ); - equal( jQuery("#en").text(), expected, "Insert jQuery before" ); -}); + jQuery( "#yahoo" ).before( manipulationFunctionReturningObj( jQuery( "#mark, #first" ) ) ); + equal( jQuery( "#en" ).text(), expected, "Insert jQuery before" ); +} ); test( "before(Function) -- Returns Array<jQuery>", function() { @@ -966,19 +968,19 @@ test( "before(Function) -- Returns Array<jQuery>", function() { var expected; expected = "This is a normal link: Try them out:GooglediveintomarkYahoo"; - jQuery("#yahoo").before( manipulationFunctionReturningObj([ jQuery("#first"), jQuery("#mark, #google") ]) ); - equal( jQuery("#en").text(), expected, "Insert array of jQuery objects before" ); -}); + jQuery( "#yahoo" ).before( manipulationFunctionReturningObj( [ jQuery( "#first" ), jQuery( "#mark, #google" ) ] ) ); + equal( jQuery( "#en" ).text(), expected, "Insert array of jQuery objects before" ); +} ); test( "before(no-op)", function() { expect( 2 ); var set; - set = jQuery("<div/>").before("<span>test</span>"); + set = jQuery( "<div/>" ).before( "<span>test</span>" ); equal( set[ 0 ].nodeName.toLowerCase(), "div", "Insert before a disconnected node should be a no-op" ); equal( set.length, 1, "Insert the element before the disconnected node. should be a no-op" ); -}); +} ); test( "before and after w/ empty object (#10812)", function() { @@ -988,127 +990,127 @@ test( "before and after w/ empty object (#10812)", function() { res = jQuery( "#notInTheDocument" ).before( "(" ).after( ")" ); equal( res.length, 0, "didn't choke on empty object" ); -}); +} ); test( ".before() and .after() disconnected node", function() { - expect(2); + expect( 2 ); - equal( jQuery("<input type='checkbox'/>").before("<div/>").length, 1, "before() on disconnected node is no-op" ); - equal( jQuery("<input type='checkbox'/>").after("<div/>").length, 1, "after() on disconnected node is no-op" ); -}); + equal( jQuery( "<input type='checkbox'/>" ).before( "<div/>" ).length, 1, "before() on disconnected node is no-op" ); + equal( jQuery( "<input type='checkbox'/>" ).after( "<div/>" ).length, 1, "after() on disconnected node is no-op" ); +} ); test( "insert with .before() on disconnected node last", function() { - expect(1); + expect( 1 ); var expectedBefore = "This is a normal link: bugaYahoo"; - jQuery("#yahoo").add("<span/>").before("<b>buga</b>"); - equal( jQuery("#en").text(), expectedBefore, "Insert String before with disconnected node last" ); -}); + jQuery( "#yahoo" ).add( "<span/>" ).before( "<b>buga</b>" ); + equal( jQuery( "#en" ).text(), expectedBefore, "Insert String before with disconnected node last" ); +} ); test( "insert with .before() on disconnected node first", function() { - expect(1); + expect( 1 ); var expectedBefore = "This is a normal link: bugaYahoo"; - jQuery("<span/>").add("#yahoo").before("<b>buga</b>"); - equal( jQuery("#en").text(), expectedBefore, "Insert String before with disconnected node first" ); -}); + jQuery( "<span/>" ).add( "#yahoo" ).before( "<b>buga</b>" ); + equal( jQuery( "#en" ).text(), expectedBefore, "Insert String before with disconnected node first" ); +} ); test( "insert with .before() on disconnected node last", function() { - expect(1); + expect( 1 ); var expectedAfter = "This is a normal link: Yahoobuga"; - jQuery("#yahoo").add("<span/>").after("<b>buga</b>"); - equal( jQuery("#en").text(), expectedAfter, "Insert String after with disconnected node last" ); -}); + jQuery( "#yahoo" ).add( "<span/>" ).after( "<b>buga</b>" ); + equal( jQuery( "#en" ).text(), expectedAfter, "Insert String after with disconnected node last" ); +} ); test( "insert with .before() on disconnected node last", function() { - expect(1); + expect( 1 ); var expectedAfter = "This is a normal link: Yahoobuga"; - jQuery("<span/>").add("#yahoo").after("<b>buga</b>"); - equal( jQuery("#en").text(), expectedAfter, "Insert String after with disconnected node first" ); -}); + jQuery( "<span/>" ).add( "#yahoo" ).after( "<b>buga</b>" ); + equal( jQuery( "#en" ).text(), expectedAfter, "Insert String after with disconnected node first" ); +} ); test( "insertBefore(String)", function() { expect( 1 ); var expected = "This is a normal link: bugaYahoo"; - jQuery("<b>buga</b>").insertBefore("#yahoo"); - equal( jQuery("#en").text(), expected, "Insert String before" ); -}); + jQuery( "<b>buga</b>" ).insertBefore( "#yahoo" ); + equal( jQuery( "#en" ).text(), expected, "Insert String before" ); +} ); test( "insertBefore(Element)", function() { expect( 1 ); var expected = "This is a normal link: Try them out:Yahoo"; - jQuery( document.getElementById("first") ).insertBefore("#yahoo"); - equal( jQuery("#en").text(), expected, "Insert element before" ); -}); + jQuery( document.getElementById( "first" ) ).insertBefore( "#yahoo" ); + equal( jQuery( "#en" ).text(), expected, "Insert element before" ); +} ); test( "insertBefore(Array<Element>)", function() { expect( 1 ); var expected = "This is a normal link: Try them out:diveintomarkYahoo"; - jQuery( [ document.getElementById("first"), document.getElementById("mark") ] ).insertBefore("#yahoo"); - equal( jQuery("#en").text(), expected, "Insert array of elements before" ); -}); + jQuery( [ document.getElementById( "first" ), document.getElementById( "mark" ) ] ).insertBefore( "#yahoo" ); + equal( jQuery( "#en" ).text(), expected, "Insert array of elements before" ); +} ); test( "insertBefore(jQuery)", function() { expect( 1 ); var expected = "This is a normal link: diveintomarkTry them out:Yahoo"; - jQuery("#mark, #first").insertBefore("#yahoo"); - equal( jQuery("#en").text(), expected, "Insert jQuery before" ); -}); + jQuery( "#mark, #first" ).insertBefore( "#yahoo" ); + equal( jQuery( "#en" ).text(), expected, "Insert jQuery before" ); +} ); test( ".after(String)", function() { expect( 1 ); var expected = "This is a normal link: Yahoobuga"; - jQuery("#yahoo").after( "<b>buga</b>" ); - equal( jQuery("#en").text(), expected, "Insert String after" ); -}); + jQuery( "#yahoo" ).after( "<b>buga</b>" ); + equal( jQuery( "#en" ).text(), expected, "Insert String after" ); +} ); test( ".after(Element)", function() { expect( 1 ); var expected = "This is a normal link: YahooTry them out:"; - jQuery("#yahoo").after( document.getElementById("first") ); - equal( jQuery("#en").text(), expected, "Insert element after" ); -}); + jQuery( "#yahoo" ).after( document.getElementById( "first" ) ); + equal( jQuery( "#en" ).text(), expected, "Insert element after" ); +} ); test( ".after(Array<Element>)", function() { expect( 1 ); var expected = "This is a normal link: YahooTry them out:diveintomark"; - jQuery("#yahoo").after( [ document.getElementById("first"), document.getElementById("mark") ] ); - equal( jQuery("#en").text(), expected, "Insert array of elements after" ); -}); + jQuery( "#yahoo" ).after( [ document.getElementById( "first" ), document.getElementById( "mark" ) ] ); + equal( jQuery( "#en" ).text(), expected, "Insert array of elements after" ); +} ); test( ".after(jQuery)", function() { expect( 1 ); var expected = "This is a normal link: YahooTry them out:Googlediveintomark"; - jQuery("#yahoo").after( [ jQuery("#first"), jQuery("#mark, #google") ] ); - equal( jQuery("#en").text(), expected, "Insert array of jQuery objects after" ); -}); + jQuery( "#yahoo" ).after( [ jQuery( "#first" ), jQuery( "#mark, #google" ) ] ); + equal( jQuery( "#en" ).text(), expected, "Insert array of jQuery objects after" ); +} ); test( ".after(Function) returns String", function() { @@ -1116,9 +1118,9 @@ test( ".after(Function) returns String", function() { var expected = "This is a normal link: Yahoobuga", val = manipulationFunctionReturningObj; - jQuery("#yahoo").after( val("<b>buga</b>") ); - equal( jQuery("#en").text(), expected, "Insert String after" ); -}); + jQuery( "#yahoo" ).after( val( "<b>buga</b>" ) ); + equal( jQuery( "#en" ).text(), expected, "Insert String after" ); +} ); test( ".after(Function) returns Element", function() { @@ -1126,9 +1128,9 @@ test( ".after(Function) returns Element", function() { var expected = "This is a normal link: YahooTry them out:", val = manipulationFunctionReturningObj; - jQuery("#yahoo").after( val(document.getElementById("first")) ); - equal( jQuery("#en").text(), expected, "Insert element after" ); -}); + jQuery( "#yahoo" ).after( val( document.getElementById( "first" ) ) ); + equal( jQuery( "#en" ).text(), expected, "Insert element after" ); +} ); test( ".after(Function) returns Array<Element>", function() { @@ -1136,9 +1138,9 @@ test( ".after(Function) returns Array<Element>", function() { var expected = "This is a normal link: YahooTry them out:diveintomark", val = manipulationFunctionReturningObj; - jQuery("#yahoo").after( val([ document.getElementById("first"), document.getElementById("mark") ]) ); - equal( jQuery("#en").text(), expected, "Insert array of elements after" ); -}); + jQuery( "#yahoo" ).after( val( [ document.getElementById( "first" ), document.getElementById( "mark" ) ] ) ); + equal( jQuery( "#en" ).text(), expected, "Insert array of elements after" ); +} ); test( ".after(Function) returns jQuery", function() { @@ -1146,54 +1148,54 @@ test( ".after(Function) returns jQuery", function() { var expected = "This is a normal link: YahooTry them out:Googlediveintomark", val = manipulationFunctionReturningObj; - jQuery("#yahoo").after( val([ jQuery("#first"), jQuery("#mark, #google") ]) ); - equal( jQuery("#en").text(), expected, "Insert array of jQuery objects after" ); -}); + jQuery( "#yahoo" ).after( val( [ jQuery( "#first" ), jQuery( "#mark, #google" ) ] ) ); + equal( jQuery( "#en" ).text(), expected, "Insert array of jQuery objects after" ); +} ); test( ".after(disconnected node)", function() { expect( 2 ); - var set = jQuery("<div/>").before("<span>test</span>"); + var set = jQuery( "<div/>" ).before( "<span>test</span>" ); equal( set[ 0 ].nodeName.toLowerCase(), "div", "Insert after a disconnected node should be a no-op" ); equal( set.length, 1, "Insert the element after the disconnected node should be a no-op" ); -}); +} ); test( "insertAfter(String)", function() { expect( 1 ) ; var expected = "This is a normal link: Yahoobuga"; - jQuery("<b>buga</b>").insertAfter("#yahoo"); - equal( jQuery("#en").text(), expected, "Insert String after" ); -}); + jQuery( "<b>buga</b>" ).insertAfter( "#yahoo" ); + equal( jQuery( "#en" ).text(), expected, "Insert String after" ); +} ); test( "insertAfter(Element)", function() { - expect(1); + expect( 1 ); var expected = "This is a normal link: YahooTry them out:"; - jQuery( document.getElementById("first") ).insertAfter("#yahoo"); - equal( jQuery("#en").text(), expected, "Insert element after" ); -}); + jQuery( document.getElementById( "first" ) ).insertAfter( "#yahoo" ); + equal( jQuery( "#en" ).text(), expected, "Insert element after" ); +} ); test( "insertAfter(Array<Element>)", function() { - expect(1); + expect( 1 ); var expected = "This is a normal link: YahooTry them out:diveintomark"; - jQuery( [ document.getElementById("first"), document.getElementById("mark") ] ).insertAfter("#yahoo"); - equal( jQuery("#en").text(), expected, "Insert array of elements after" ); -}); + jQuery( [ document.getElementById( "first" ), document.getElementById( "mark" ) ] ).insertAfter( "#yahoo" ); + equal( jQuery( "#en" ).text(), expected, "Insert array of elements after" ); +} ); test( "insertAfter(jQuery)", function() { - expect(1); + expect( 1 ); var expected = "This is a normal link: YahoodiveintomarkTry them out:"; - jQuery("#mark, #first").insertAfter("#yahoo"); - equal( jQuery("#en").text(), expected, "Insert jQuery after" ); -}); + jQuery( "#mark, #first" ).insertAfter( "#yahoo" ); + equal( jQuery( "#en" ).text(), expected, "Insert jQuery after" ); +} ); function testReplaceWith( val ) { @@ -1202,132 +1204,127 @@ function testReplaceWith( val ) { expect( expected ); - jQuery("#yahoo").replaceWith( val("<b id='replace'>buga</b>") ); - ok( jQuery("#replace")[ 0 ], "Replace element with element from string" ); - ok( !jQuery("#yahoo")[ 0 ], "Verify that original element is gone, after string" ); + jQuery( "#yahoo" ).replaceWith( val( "<b id='replace'>buga</b>" ) ); + ok( jQuery( "#replace" )[ 0 ], "Replace element with element from string" ); + ok( !jQuery( "#yahoo" )[ 0 ], "Verify that original element is gone, after string" ); - jQuery("#anchor2").replaceWith( val(document.getElementById("first")) ); - ok( jQuery("#first")[ 0 ], "Replace element with element" ); - ok( !jQuery("#anchor2")[ 0 ], "Verify that original element is gone, after element" ); + jQuery( "#anchor2" ).replaceWith( val( document.getElementById( "first" ) ) ); + ok( jQuery( "#first" )[ 0 ], "Replace element with element" ); + ok( !jQuery( "#anchor2" )[ 0 ], "Verify that original element is gone, after element" ); - jQuery("#qunit-fixture").append("<div id='bar'><div id='baz'></div></div>"); - jQuery("#baz").replaceWith( val("Baz") ); - equal( jQuery("#bar").text(),"Baz", "Replace element with text" ); - ok( !jQuery("#baz")[ 0 ], "Verify that original element is gone, after element" ); + jQuery( "#qunit-fixture" ).append( "<div id='bar'><div id='baz'></div></div>" ); + jQuery( "#baz" ).replaceWith( val( "Baz" ) ); + equal( jQuery( "#bar" ).text(), "Baz", "Replace element with text" ); + ok( !jQuery( "#baz" )[ 0 ], "Verify that original element is gone, after element" ); - jQuery("#bar").replaceWith( "<div id='yahoo'></div>", "...", "<div id='baz'></div>" ); - deepEqual( jQuery("#yahoo, #baz").get(), q( "yahoo", "baz" ), "Replace element with multiple arguments (#13722)" ); - strictEqual( jQuery("#yahoo")[0].nextSibling, jQuery("#baz")[0].previousSibling, "Argument order preserved" ); - deepEqual( jQuery("#bar").get(), [], "Verify that original element is gone, after multiple arguments" ); + jQuery( "#bar" ).replaceWith( "<div id='yahoo'></div>", "...", "<div id='baz'></div>" ); + deepEqual( jQuery( "#yahoo, #baz" ).get(), q( "yahoo", "baz" ), "Replace element with multiple arguments (#13722)" ); + strictEqual( jQuery( "#yahoo" )[ 0 ].nextSibling, jQuery( "#baz" )[ 0 ].previousSibling, "Argument order preserved" ); + deepEqual( jQuery( "#bar" ).get(), [], "Verify that original element is gone, after multiple arguments" ); - jQuery("#google").replaceWith( val([ document.getElementById("first"), document.getElementById("mark") ]) ); - deepEqual( jQuery("#mark, #first").get(), q( "first", "mark" ), "Replace element with array of elements" ); - ok( !jQuery("#google")[ 0 ], "Verify that original element is gone, after array of elements" ); + jQuery( "#google" ).replaceWith( val( [ document.getElementById( "first" ), document.getElementById( "mark" ) ] ) ); + deepEqual( jQuery( "#mark, #first" ).get(), q( "first", "mark" ), "Replace element with array of elements" ); + ok( !jQuery( "#google" )[ 0 ], "Verify that original element is gone, after array of elements" ); - jQuery("#groups").replaceWith( val(jQuery("#mark, #first")) ); - deepEqual( jQuery("#mark, #first").get(), q( "first", "mark" ), "Replace element with jQuery collection" ); - ok( !jQuery("#groups")[ 0 ], "Verify that original element is gone, after jQuery collection" ); + jQuery( "#groups" ).replaceWith( val( jQuery( "#mark, #first" ) ) ); + deepEqual( jQuery( "#mark, #first" ).get(), q( "first", "mark" ), "Replace element with jQuery collection" ); + ok( !jQuery( "#groups" )[ 0 ], "Verify that original element is gone, after jQuery collection" ); - jQuery("#mark, #first").replaceWith( val("<span class='replacement'></span><span class='replacement'></span>") ); - equal( jQuery("#qunit-fixture .replacement").length, 4, "Replace multiple elements (#12449)" ); - deepEqual( jQuery("#mark, #first").get(), [], "Verify that original elements are gone, after replace multiple" ); + jQuery( "#mark, #first" ).replaceWith( val( "<span class='replacement'></span><span class='replacement'></span>" ) ); + equal( jQuery( "#qunit-fixture .replacement" ).length, 4, "Replace multiple elements (#12449)" ); + deepEqual( jQuery( "#mark, #first" ).get(), [], "Verify that original elements are gone, after replace multiple" ); - tmp = jQuery("<b>content</b>")[0]; - jQuery("#anchor1").contents().replaceWith( val(tmp) ); - deepEqual( jQuery("#anchor1").contents().get(), [ tmp ], "Replace text node with element" ); + tmp = jQuery( "<b>content</b>" )[ 0 ]; + jQuery( "#anchor1" ).contents().replaceWith( val( tmp ) ); + deepEqual( jQuery( "#anchor1" ).contents().get(), [ tmp ], "Replace text node with element" ); - - tmp = jQuery("<div/>").appendTo("#qunit-fixture").on( "click", function() { + tmp = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ).on( "click", function() { ok( true, "Newly bound click run." ); - }); - y = jQuery("<div/>").appendTo("#qunit-fixture").on( "click", function() { + } ); + y = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ).on( "click", function() { ok( false, "Previously bound click run." ); - }); - child = y.append("<b>test</b>").find("b").on( "click", function() { + } ); + child = y.append( "<b>test</b>" ).find( "b" ).on( "click", function() { ok( true, "Child bound click run." ); return false; - }); - - y.replaceWith( val(tmp) ); + } ); - tmp.trigger("click"); - y.trigger("click"); // Shouldn't be run - child.trigger("click"); // Shouldn't be run + y.replaceWith( val( tmp ) ); + tmp.trigger( "click" ); + y.trigger( "click" ); // Shouldn't be run + child.trigger( "click" ); // Shouldn't be run - y = jQuery("<div/>").appendTo("#qunit-fixture").on( "click", function() { + y = jQuery( "<div/>" ).appendTo( "#qunit-fixture" ).on( "click", function() { ok( false, "Previously bound click run." ); - }); - child2 = y.append("<u>test</u>").find("u").on( "click", function() { + } ); + child2 = y.append( "<u>test</u>" ).find( "u" ).on( "click", function() { ok( true, "Child 2 bound click run." ); return false; - }); - - y.replaceWith( val(child2) ); + } ); - child2.trigger("click"); + y.replaceWith( val( child2 ) ); + child2.trigger( "click" ); - set = jQuery("<div/>").replaceWith( val("<span>test</span>") ); - equal( set[0].nodeName.toLowerCase(), "div", "No effect on a disconnected node." ); + set = jQuery( "<div/>" ).replaceWith( val( "<span>test</span>" ) ); + equal( set[ 0 ].nodeName.toLowerCase(), "div", "No effect on a disconnected node." ); equal( set.length, 1, "No effect on a disconnected node." ); - equal( set[0].childNodes.length, 0, "No effect on a disconnected node." ); + equal( set[ 0 ].childNodes.length, 0, "No effect on a disconnected node." ); - - child = jQuery("#qunit-fixture").children().first(); - $div = jQuery("<div class='pathological'/>").insertBefore( child ); + child = jQuery( "#qunit-fixture" ).children().first(); + $div = jQuery( "<div class='pathological'/>" ).insertBefore( child ); $div.replaceWith( $div ); deepEqual( jQuery( ".pathological", "#qunit-fixture" ).get(), $div.get(), "Self-replacement" ); $div.replaceWith( child ); - deepEqual( jQuery("#qunit-fixture").children().first().get(), child.get(), + deepEqual( jQuery( "#qunit-fixture" ).children().first().get(), child.get(), "Replacement with following sibling (#13810)" ); deepEqual( jQuery( ".pathological", "#qunit-fixture" ).get(), [], "Replacement with following sibling (context removed)" ); - - non_existent = jQuery("#does-not-exist").replaceWith( val("<b>should not throw an error</b>") ); + non_existent = jQuery( "#does-not-exist" ).replaceWith( val( "<b>should not throw an error</b>" ) ); equal( non_existent.length, 0, "Length of non existent element." ); - $div = jQuery("<div class='replacewith'></div>").appendTo("#qunit-fixture"); - $div.replaceWith( val("<div class='replacewith'></div><script>" + + $div = jQuery( "<div class='replacewith'></div>" ).appendTo( "#qunit-fixture" ); + $div.replaceWith( val( "<div class='replacewith'></div><script>" + "equal( jQuery('.replacewith').length, 1, 'Check number of elements in page.' );" + - "</script>") ); + "</script>" ) ); - jQuery("#qunit-fixture").append("<div id='replaceWith'></div>"); - equal( jQuery("#qunit-fixture").find("div[id=replaceWith]").length, 1, "Make sure only one div exists." ); - jQuery("#replaceWith").replaceWith( val("<div id='replaceWith'></div>") ); - equal( jQuery("#qunit-fixture").find("div[id=replaceWith]").length, 1, "Make sure only one div exists after replacement." ); - jQuery("#replaceWith").replaceWith( val("<div id='replaceWith'></div>") ); - equal( jQuery("#qunit-fixture").find("div[id=replaceWith]").length, 1, "Make sure only one div exists after subsequent replacement." ); + jQuery( "#qunit-fixture" ).append( "<div id='replaceWith'></div>" ); + equal( jQuery( "#qunit-fixture" ).find( "div[id=replaceWith]" ).length, 1, "Make sure only one div exists." ); + jQuery( "#replaceWith" ).replaceWith( val( "<div id='replaceWith'></div>" ) ); + equal( jQuery( "#qunit-fixture" ).find( "div[id=replaceWith]" ).length, 1, "Make sure only one div exists after replacement." ); + jQuery( "#replaceWith" ).replaceWith( val( "<div id='replaceWith'></div>" ) ); + equal( jQuery( "#qunit-fixture" ).find( "div[id=replaceWith]" ).length, 1, "Make sure only one div exists after subsequent replacement." ); return expected; } test( "replaceWith(String|Element|Array<Element>|jQuery)", function() { testReplaceWith( manipulationBareObj ); -}); +} ); test( "replaceWith(Function)", function() { - expect( testReplaceWith(manipulationFunctionReturningObj) + 1 ); + expect( testReplaceWith( manipulationFunctionReturningObj ) + 1 ); - var y = jQuery("#foo")[ 0 ]; + var y = jQuery( "#foo" )[ 0 ]; - jQuery( y ).replaceWith(function() { + jQuery( y ).replaceWith( function() { equal( this, y, "Make sure the context is coming in correctly." ); - }); -}); + } ); +} ); test( "replaceWith(string) for more than one element", function() { expect( 3 ); - equal( jQuery("#foo p").length, 3, "ensuring that test data has not changed" ); + equal( jQuery( "#foo p" ).length, 3, "ensuring that test data has not changed" ); - jQuery("#foo p").replaceWith("<span>bar</span>"); - equal(jQuery("#foo span").length, 3, "verify that all the three original element have been replaced"); - equal(jQuery("#foo p").length, 0, "verify that all the three original element have been replaced"); -}); + jQuery( "#foo p" ).replaceWith( "<span>bar</span>" ); + equal( jQuery( "#foo span" ).length, 3, "verify that all the three original element have been replaced" ); + equal( jQuery( "#foo p" ).length, 0, "verify that all the three original element have been replaced" ); +} ); test( "Empty replaceWith (trac-13401; trac-13596; gh-2204)", function() { @@ -1348,97 +1345,97 @@ test( "Empty replaceWith (trac-13401; trac-13596; gh-2204)", function() { jQuery.each( tests, function( label, input ) { $el.html( "<a/>" ).children().replaceWith( input ); strictEqual( $el.html(), "", "replaceWith(" + label + ")" ); - $el.html( "<b/>" ).children().replaceWith(function() { return input; }); + $el.html( "<b/>" ).children().replaceWith( function() { return input; } ); strictEqual( $el.html(), "", "replaceWith(function returning " + label + ")" ); - $el.html( "<i/>" ).children().replaceWith(function( i ) { i; return input; }); + $el.html( "<i/>" ).children().replaceWith( function( i ) { i; return input; } ); strictEqual( $el.html(), "", "replaceWith(other function returning " + label + ")" ); - $el.html( "<p/>" ).children().replaceWith(function( i ) { + $el.html( "<p/>" ).children().replaceWith( function( i ) { return i ? input : jQuery( this ).html( i + "" ); - }); + } ); strictEqual( $el.eq( 0 ).html(), expectedHTML, "replaceWith(function conditionally returning context)" ); strictEqual( $el.eq( 1 ).html(), "", "replaceWith(function conditionally returning " + label + ")" ); - }); -}); + } ); +} ); test( "replaceAll(String)", function() { expect( 2 ); - jQuery("<b id='replace'>buga</b>").replaceAll("#yahoo"); - ok( jQuery("#replace")[ 0 ], "Replace element with string" ); - ok( !jQuery("#yahoo")[ 0 ], "Verify that original element is gone, after string" ); -}); + jQuery( "<b id='replace'>buga</b>" ).replaceAll( "#yahoo" ); + ok( jQuery( "#replace" )[ 0 ], "Replace element with string" ); + ok( !jQuery( "#yahoo" )[ 0 ], "Verify that original element is gone, after string" ); +} ); test( "replaceAll(Element)", function() { expect( 2 ); - jQuery( document.getElementById("first") ).replaceAll("#yahoo"); - ok( jQuery("#first")[ 0 ], "Replace element with element" ); - ok( !jQuery("#yahoo")[ 0 ], "Verify that original element is gone, after element" ); -}); + jQuery( document.getElementById( "first" ) ).replaceAll( "#yahoo" ); + ok( jQuery( "#first" )[ 0 ], "Replace element with element" ); + ok( !jQuery( "#yahoo" )[ 0 ], "Verify that original element is gone, after element" ); +} ); test( "replaceAll(Array<Element>)", function() { expect( 3 ); - jQuery( [ document.getElementById("first"), document.getElementById("mark") ] ).replaceAll("#yahoo"); - ok( jQuery("#first")[ 0 ], "Replace element with array of elements" ); - ok( jQuery("#mark")[ 0 ], "Replace element with array of elements" ); - ok( !jQuery("#yahoo")[ 0 ], "Verify that original element is gone, after array of elements" ); -}); + jQuery( [ document.getElementById( "first" ), document.getElementById( "mark" ) ] ).replaceAll( "#yahoo" ); + ok( jQuery( "#first" )[ 0 ], "Replace element with array of elements" ); + ok( jQuery( "#mark" )[ 0 ], "Replace element with array of elements" ); + ok( !jQuery( "#yahoo" )[ 0 ], "Verify that original element is gone, after array of elements" ); +} ); test( "replaceAll(jQuery)", function() { expect( 3 ); - jQuery("#mark, #first").replaceAll("#yahoo"); - ok( jQuery("#first")[ 0 ], "Replace element with set of elements" ); - ok( jQuery("#mark")[ 0 ], "Replace element with set of elements" ); - ok( !jQuery("#yahoo")[ 0 ], "Verify that original element is gone, after set of elements" ); -}); + jQuery( "#mark, #first" ).replaceAll( "#yahoo" ); + ok( jQuery( "#first" )[ 0 ], "Replace element with set of elements" ); + ok( jQuery( "#mark" )[ 0 ], "Replace element with set of elements" ); + ok( !jQuery( "#yahoo" )[ 0 ], "Verify that original element is gone, after set of elements" ); +} ); test( "jQuery.clone() (#8017)", function() { expect( 2 ); - ok( jQuery.clone && jQuery.isFunction( jQuery.clone ) , "jQuery.clone() utility exists and is a function."); + ok( jQuery.clone && jQuery.isFunction( jQuery.clone ), "jQuery.clone() utility exists and is a function." ); - var main = jQuery("#qunit-fixture")[ 0 ], + var main = jQuery( "#qunit-fixture" )[ 0 ], clone = jQuery.clone( main ); equal( main.childNodes.length, clone.childNodes.length, "Simple child length to ensure a large dom tree copies correctly" ); -}); +} ); test( "append to multiple elements (#8070)", function() { expect( 2 ); - var selects = jQuery("<select class='test8070'></select><select class='test8070'></select>").appendTo("#qunit-fixture"); - selects.append("<OPTION>1</OPTION><OPTION>2</OPTION>"); + var selects = jQuery( "<select class='test8070'></select><select class='test8070'></select>" ).appendTo( "#qunit-fixture" ); + selects.append( "<OPTION>1</OPTION><OPTION>2</OPTION>" ); equal( selects[ 0 ].childNodes.length, 2, "First select got two nodes" ); equal( selects[ 1 ].childNodes.length, 2, "Second select got two nodes" ); -}); +} ); test( "table manipulation", function() { expect( 2 ); - var table = jQuery("<table style='font-size:16px'></table>").appendTo("#qunit-fixture").empty(), - height = table[0].offsetHeight; + var table = jQuery( "<table style='font-size:16px'></table>" ).appendTo( "#qunit-fixture" ).empty(), + height = table[ 0 ].offsetHeight; - table.append("<tr><td>DATA</td></tr>"); - ok( table[0].offsetHeight - height >= 15, "appended rows are visible" ); + table.append( "<tr><td>DATA</td></tr>" ); + ok( table[ 0 ].offsetHeight - height >= 15, "appended rows are visible" ); table.empty(); - height = table[0].offsetHeight; - table.prepend("<tr><td>DATA</td></tr>"); - ok( table[0].offsetHeight - height >= 15, "prepended rows are visible" ); -}); + height = table[ 0 ].offsetHeight; + table.prepend( "<tr><td>DATA</td></tr>" ); + ok( table[ 0 ].offsetHeight - height >= 15, "prepended rows are visible" ); +} ); test( "clone()", function() { @@ -1446,61 +1443,61 @@ test( "clone()", function() { var div, clone, form, body; - equal( jQuery("#en").text(), "This is a normal link: Yahoo", "Assert text for #en" ); - equal( jQuery("#first").append( jQuery("#yahoo").clone() ).text(), "Try them out:Yahoo", "Check for clone" ); - equal( jQuery("#en").text(), "This is a normal link: Yahoo", "Reassert text for #en" ); + equal( jQuery( "#en" ).text(), "This is a normal link: Yahoo", "Assert text for #en" ); + equal( jQuery( "#first" ).append( jQuery( "#yahoo" ).clone() ).text(), "Try them out:Yahoo", "Check for clone" ); + equal( jQuery( "#en" ).text(), "This is a normal link: Yahoo", "Reassert text for #en" ); - jQuery.each( "table thead tbody tfoot tr td div button ul ol li select option textarea iframe".split(" "), function( i, nodeName ) { + jQuery.each( "table thead tbody tfoot tr td div button ul ol li select option textarea iframe".split( " " ), function( i, nodeName ) { equal( jQuery( "<" + nodeName + "/>" ).clone()[ 0 ].nodeName.toLowerCase(), nodeName, "Clone a " + nodeName ); - }); - equal( jQuery("<input type='checkbox' />").clone()[ 0 ].nodeName.toLowerCase(), "input", "Clone a <input type='checkbox' />" ); + } ); + equal( jQuery( "<input type='checkbox' />" ).clone()[ 0 ].nodeName.toLowerCase(), "input", "Clone a <input type='checkbox' />" ); // Check cloning non-elements - equal( jQuery("#nonnodes").contents().clone().length, 3, "Check node,textnode,comment clone works (some browsers delete comments on clone)" ); + equal( jQuery( "#nonnodes" ).contents().clone().length, 3, "Check node,textnode,comment clone works (some browsers delete comments on clone)" ); // Verify that clones of clones can keep event listeners - div = jQuery("<div><ul><li>test</li></ul></div>").on( "click", function() { + div = jQuery( "<div><ul><li>test</li></ul></div>" ).on( "click", function() { ok( true, "Bound event still exists." ); - }); + } ); clone = div.clone( true ); div.remove(); div = clone.clone( true ); clone.remove(); equal( div.length, 1, "One element cloned" ); equal( div[ 0 ].nodeName.toUpperCase(), "DIV", "DIV element cloned" ); - div.trigger("click"); + div.trigger( "click" ); // Manually clean up detached elements div.remove(); // Verify that cloned children can keep event listeners - div = jQuery("<div/>").append([ document.createElement("table"), document.createElement("table") ]); - div.find("table").on( "click", function() { + div = jQuery( "<div/>" ).append( [ document.createElement( "table" ), document.createElement( "table" ) ] ); + div.find( "table" ).on( "click", function() { ok( true, "Bound event still exists." ); - }); + } ); clone = div.clone( true ); equal( clone.length, 1, "One element cloned" ); equal( clone[ 0 ].nodeName.toUpperCase(), "DIV", "DIV element cloned" ); - clone.find("table").trigger("click"); + clone.find( "table" ).trigger( "click" ); // Manually clean up detached elements div.remove(); clone.remove(); // Make sure that doing .clone() doesn't clone event listeners - div = jQuery("<div><ul><li>test</li></ul></div>").on( "click", function() { + div = jQuery( "<div><ul><li>test</li></ul></div>" ).on( "click", function() { ok( false, "Bound event still exists after .clone()." ); - }); + } ); clone = div.clone(); - clone.trigger("click"); + clone.trigger( "click" ); // Manually clean up detached elements clone.remove(); div.remove(); // Test both html() and clone() for <embed> and <object> types - div = jQuery("<div/>").html("<embed height='355' width='425' src='http://www.youtube.com/v/3KANI2dpXLw&hl=en'></embed>"); + div = jQuery( "<div/>" ).html( "<embed height='355' width='425' src='http://www.youtube.com/v/3KANI2dpXLw&hl=en'></embed>" ); clone = div.clone( true ); equal( clone.length, 1, "One element cloned" ); @@ -1510,76 +1507,77 @@ test( "clone()", function() { // this is technically an invalid object, but because of the special // classid instantiation it is the only kind that IE has trouble with, // so let's test with it too. - div = jQuery("<div/>").html("<object height='355' width='425' classid='clsid:D27CDB6E-AE6D-11cf-96B8-444553540000'> <param name='movie' value='http://www.youtube.com/v/3KANI2dpXLw&hl=en'> <param name='wmode' value='transparent'> </object>"); + div = jQuery( "<div/>" ).html( "<object height='355' width='425' classid='clsid:D27CDB6E-AE6D-11cf-96B8-444553540000'> <param name='movie' value='http://www.youtube.com/v/3KANI2dpXLw&hl=en'> <param name='wmode' value='transparent'> </object>" ); clone = div.clone( true ); equal( clone.length, 1, "One element cloned" ); equal( clone[ 0 ].nodeName.toUpperCase(), "DIV", "DIV element cloned" ); - div = div.find("object"); - clone = clone.find("object"); + div = div.find( "object" ); + clone = clone.find( "object" ); + // oldIE adds extra attributes and <param> elements, so just test for existence of the defined set jQuery.each( [ "height", "width", "classid" ], function( i, attr ) { equal( clone.attr( attr ), div.attr( attr ), "<object> attribute cloned: " + attr ); } ); - (function() { + ( function() { var params = {}; - clone.find("param").each(function( index, param ) { + clone.find( "param" ).each( function( index, param ) { params[ param.attributes.name.nodeValue.toLowerCase() ] = param.attributes.value.nodeValue.toLowerCase(); - }); + } ); - div.find("param").each(function( index, param ) { + div.find( "param" ).each( function( index, param ) { var key = param.attributes.name.nodeValue.toLowerCase(); equal( params[ key ], param.attributes.value.nodeValue.toLowerCase(), "<param> cloned: " + key ); - }); - })(); + } ); + } )(); // and here's a valid one. - div = jQuery("<div/>").html("<object height='355' width='425' type='application/x-shockwave-flash' data='http://www.youtube.com/v/3KANI2dpXLw&hl=en'> <param name='movie' value='http://www.youtube.com/v/3KANI2dpXLw&hl=en'> <param name='wmode' value='transparent'> </object>"); + div = jQuery( "<div/>" ).html( "<object height='355' width='425' type='application/x-shockwave-flash' data='http://www.youtube.com/v/3KANI2dpXLw&hl=en'> <param name='movie' value='http://www.youtube.com/v/3KANI2dpXLw&hl=en'> <param name='wmode' value='transparent'> </object>" ); - clone = div.clone(true); + clone = div.clone( true ); equal( clone.length, 1, "One element cloned" ); equal( clone.html(), div.html(), "Element contents cloned" ); equal( clone[ 0 ].nodeName.toUpperCase(), "DIV", "DIV element cloned" ); - div = jQuery("<div/>").data({ "a": true }); + div = jQuery( "<div/>" ).data( { "a": true } ); clone = div.clone( true ); - equal( clone.data("a"), true, "Data cloned." ); + equal( clone.data( "a" ), true, "Data cloned." ); clone.data( "a", false ); - equal( clone.data("a"), false, "Ensure cloned element data object was correctly modified" ); - equal( div.data("a"), true, "Ensure cloned element data object is copied, not referenced" ); + equal( clone.data( "a" ), false, "Ensure cloned element data object was correctly modified" ); + equal( div.data( "a" ), true, "Ensure cloned element data object is copied, not referenced" ); // manually clean up detached elements div.remove(); clone.remove(); - form = document.createElement("form"); + form = document.createElement( "form" ); form.action = "/test/"; - div = document.createElement("div"); - div.appendChild( document.createTextNode("test") ); + div = document.createElement( "div" ); + div.appendChild( document.createTextNode( "test" ) ); form.appendChild( div ); - equal( jQuery(form).clone().children().length, 1, "Make sure we just get the form back." ); + equal( jQuery( form ).clone().children().length, 1, "Make sure we just get the form back." ); - body = jQuery("body").clone(); + body = jQuery( "body" ).clone(); equal( body.children()[ 0 ].id, "qunit", "Make sure cloning body works" ); body.remove(); -}); +} ); test( "clone(script type=non-javascript) (#11359)", function() { expect( 3 ); - var src = jQuery("<script type='text/filler'>Lorem ipsum dolor sit amet</script><q><script type='text/filler'>consectetur adipiscing elit</script></q>"), + var src = jQuery( "<script type='text/filler'>Lorem ipsum dolor sit amet</script><q><script type='text/filler'>consectetur adipiscing elit</script></q>" ), dest = src.clone(); equal( dest[ 0 ].text, "Lorem ipsum dolor sit amet", "Cloning preserves script text" ); equal( dest.last().html(), src.last().html(), "Cloning preserves nested script text" ); ok( /^\s*<scr.pt\s+type=['"]?text\/filler['"]?\s*>consectetur adipiscing elit<\/scr.pt>\s*$/i.test( dest.last().html() ), "Cloning preserves nested script text" ); dest.remove(); -}); +} ); test( "clone(form element) (Bug #3879, #6655)", function() { @@ -1587,49 +1585,49 @@ test( "clone(form element) (Bug #3879, #6655)", function() { var clone, element; - element = jQuery("<select><option>Foo</option><option value='selected' selected>Bar</option></select>"); + element = jQuery( "<select><option>Foo</option><option value='selected' selected>Bar</option></select>" ); - equal( element.clone().find("option").filter(function() { return this.selected; }).val(), "selected", "Selected option cloned correctly" ); + equal( element.clone().find( "option" ).filter( function() { return this.selected; } ).val(), "selected", "Selected option cloned correctly" ); - element = jQuery("<input type='checkbox' value='foo'>").attr( "checked", "checked" ); + element = jQuery( "<input type='checkbox' value='foo'>" ).attr( "checked", "checked" ); clone = element.clone(); - equal( clone.is(":checked"), element.is(":checked"), "Checked input cloned correctly" ); + equal( clone.is( ":checked" ), element.is( ":checked" ), "Checked input cloned correctly" ); equal( clone[ 0 ].defaultValue, "foo", "Checked input defaultValue cloned correctly" ); - element = jQuery("<input type='text' value='foo'>"); + element = jQuery( "<input type='text' value='foo'>" ); clone = element.clone(); equal( clone[ 0 ].defaultValue, "foo", "Text input defaultValue cloned correctly" ); - element = jQuery("<textarea>foo</textarea>"); + element = jQuery( "<textarea>foo</textarea>" ); clone = element.clone(); equal( clone[ 0 ].defaultValue, "foo", "Textarea defaultValue cloned correctly" ); -}); +} ); test( "clone(multiple selected options) (Bug #8129)", function() { expect( 1 ); - var element = jQuery("<select><option>Foo</option><option selected>Bar</option><option selected>Baz</option></select>"); + var element = jQuery( "<select><option>Foo</option><option selected>Bar</option><option selected>Baz</option></select>" ); - equal( element.clone().find("option:selected").length, element.find("option:selected").length, "Multiple selected options cloned correctly" ); + equal( element.clone().find( "option:selected" ).length, element.find( "option:selected" ).length, "Multiple selected options cloned correctly" ); -}); +} ); test( "clone() on XML nodes", function() { expect( 2 ); var xml = createDashboardXML(), - root = jQuery(xml.documentElement).clone(), - origTab = jQuery("tab", xml).eq( 0 ), - cloneTab = jQuery("tab", root).eq( 0 ); + root = jQuery( xml.documentElement ).clone(), + origTab = jQuery( "tab", xml ).eq( 0 ), + cloneTab = jQuery( "tab", root ).eq( 0 ); - origTab.text("origval"); - cloneTab.text("cloneval"); + origTab.text( "origval" ); + cloneTab.text( "cloneval" ); equal( origTab.text(), "origval", "Check original XML node was correctly set" ); equal( cloneTab.text(), "cloneval", "Check cloned XML node was correctly set" ); -}); +} ); test( "clone() on local XML nodes with html5 nodename", function() { @@ -1640,54 +1638,54 @@ test( "clone() on local XML nodes with html5 nodename", function() { equal( $meter[ 0 ].nodeName, "meter", "Check if nodeName was not changed due to cloning" ); equal( $meter[ 0 ].nodeType, 1, "Check if nodeType is not changed due to cloning" ); -}); +} ); test( "html(undefined)", function() { expect( 1 ); - equal( jQuery("#foo").html("<i>test</i>").html(undefined).html().toLowerCase(), "<i>test</i>", ".html(undefined) is chainable (#5571)" ); -}); + equal( jQuery( "#foo" ).html( "<i>test</i>" ).html( undefined ).html().toLowerCase(), "<i>test</i>", ".html(undefined) is chainable (#5571)" ); +} ); test( "html() on empty set", function() { expect( 1 ); strictEqual( jQuery().html(), undefined, ".html() returns undefined for empty sets (#11962)" ); -}); +} ); function childNodeNames( node ) { return jQuery.map( node.childNodes, function( child ) { return child.nodeName.toUpperCase(); - }).join(" "); + } ).join( " " ); } function testHtml( valueObj ) { expect( 39 ); var actual, expected, tmp, - div = jQuery("<div></div>"), - fixture = jQuery("#qunit-fixture"); + div = jQuery( "<div></div>" ), + fixture = jQuery( "#qunit-fixture" ); - div.html( valueObj("<div id='parent_1'><div id='child_1'/></div><div id='parent_2'/>") ); + div.html( valueObj( "<div id='parent_1'><div id='child_1'/></div><div id='parent_2'/>" ) ); equal( div.children().length, 2, "Found children" ); equal( div.children().children().length, 1, "Found grandchild" ); actual = []; expected = []; - tmp = jQuery("<map/>").html( valueObj("<area alt='area'/>") ).each(function() { - expected.push("AREA"); + tmp = jQuery( "<map/>" ).html( valueObj( "<area alt='area'/>" ) ).each( function() { + expected.push( "AREA" ); actual.push( childNodeNames( this ) ); - }); + } ); equal( expected.length, 1, "Expecting one parent" ); deepEqual( actual, expected, "Found the inserted area element" ); - equal( div.html(valueObj(5)).html(), "5", "Setting a number as html" ); - equal( div.html(valueObj(0)).html(), "0", "Setting a zero as html" ); - equal( div.html(valueObj(Infinity)).html(), "Infinity", "Setting Infinity as html" ); - equal( div.html(valueObj(NaN)).html(), "", "Setting NaN as html" ); - equal( div.html(valueObj(1e2)).html(), "100", "Setting exponential number notation as html" ); + equal( div.html( valueObj( 5 ) ).html(), "5", "Setting a number as html" ); + equal( div.html( valueObj( 0 ) ).html(), "0", "Setting a zero as html" ); + equal( div.html( valueObj( Infinity ) ).html(), "Infinity", "Setting Infinity as html" ); + equal( div.html( valueObj( NaN ) ).html(), "", "Setting NaN as html" ); + equal( div.html( valueObj( 1e2 ) ).html(), "100", "Setting exponential number notation as html" ); - div.html( valueObj(" &") ); + div.html( valueObj( " &" ) ); equal( div[ 0 ].innerHTML.replace( /\xA0/, " " ), " &", @@ -1695,46 +1693,46 @@ function testHtml( valueObj ) { ); tmp = "<div>hello1</div>"; - equal( div.html(valueObj(tmp) ).html().replace( />/g, ">" ), tmp, "Escaped html" ); + equal( div.html( valueObj( tmp ) ).html().replace( />/g, ">" ), tmp, "Escaped html" ); tmp = "x" + tmp; - equal( div.html(valueObj( tmp )).html().replace( />/g, ">" ), tmp, "Escaped html, leading x" ); + equal( div.html( valueObj( tmp ) ).html().replace( />/g, ">" ), tmp, "Escaped html, leading x" ); tmp = " " + tmp.slice( 1 ); - equal( div.html(valueObj( tmp )).html().replace( />/g, ">" ), tmp, "Escaped html, leading space" ); + equal( div.html( valueObj( tmp ) ).html().replace( />/g, ">" ), tmp, "Escaped html, leading space" ); actual = []; expected = []; tmp = {}; - jQuery("#nonnodes").contents().html( valueObj("<b>bold</b>") ).each(function() { + jQuery( "#nonnodes" ).contents().html( valueObj( "<b>bold</b>" ) ).each( function() { var html = jQuery( this ).html(); tmp[ this.nodeType ] = true; expected.push( this.nodeType === 1 ? "<b>bold</b>" : undefined ); actual.push( html ? html.toLowerCase() : html ); - }); + } ); deepEqual( actual, expected, "Set containing element, text node, comment" ); ok( tmp[ 1 ], "element" ); ok( tmp[ 3 ], "text node" ); ok( tmp[ 8 ], "comment" ); actual = []; expected = []; - fixture.children("div").html( valueObj("<b>test</b>") ).each(function() { - expected.push("B"); + fixture.children( "div" ).html( valueObj( "<b>test</b>" ) ).each( function() { + expected.push( "B" ); actual.push( childNodeNames( this ) ); - }); + } ); equal( expected.length, 7, "Expecting many parents" ); deepEqual( actual, expected, "Correct childNodes after setting HTML" ); actual = []; expected = []; - fixture.html( valueObj("<style>.foobar{color:green;}</style>") ).each(function() { - expected.push("STYLE"); + fixture.html( valueObj( "<style>.foobar{color:green;}</style>" ) ).each( function() { + expected.push( "STYLE" ); actual.push( childNodeNames( this ) ); - }); + } ); equal( expected.length, 1, "Expecting one parent" ); deepEqual( actual, expected, "Found the inserted style element" ); - fixture.html( valueObj("<select/>") ); - jQuery("#qunit-fixture select").html( valueObj("<option>O1</option><option selected='selected'>O2</option><option>O3</option>") ); - equal( jQuery("#qunit-fixture select").val(), "O2", "Selected option correct" ); + fixture.html( valueObj( "<select/>" ) ); + jQuery( "#qunit-fixture select" ).html( valueObj( "<option>O1</option><option selected='selected'>O2</option><option>O3</option>" ) ); + equal( jQuery( "#qunit-fixture select" ).val(), "O2", "Selected option correct" ); tmp = fixture.html( - valueObj([ + valueObj( [ "<script type='something/else'>ok( false, 'evaluated: non-script' );</script>", "<script type='text/javascript'>ok( true, 'evaluated: text/javascript' );</script>", "<script type='text/ecmascript'>ok( true, 'evaluated: text/ecmascript' );</script>", @@ -1745,53 +1743,53 @@ function testHtml( valueObj ) { "<script type='text/ecmascript'>ok( true, 'evaluated: inner text/ecmascript' );</script>", "<script>ok( true, 'evaluated: inner no type' );</script>", "</div>" - ].join("")) - ).find("script"); + ].join( "" ) ) + ).find( "script" ); equal( tmp.length, 8, "All script tags remain." ); equal( tmp[ 0 ].type, "something/else", "Non-evaluated type." ); equal( tmp[ 1 ].type, "text/javascript", "Evaluated type." ); - fixture.html( valueObj("<script type='text/javascript'>ok( true, 'Injection of identical script' );</script>") ); - fixture.html( valueObj("<script type='text/javascript'>ok( true, 'Injection of identical script' );</script>") ); - fixture.html( valueObj("<script type='text/javascript'>ok( true, 'Injection of identical script' );</script>") ); - fixture.html( valueObj("foo <form><script type='text/javascript'>ok( true, 'Injection of identical script (#975)' );</script></form>") ); + fixture.html( valueObj( "<script type='text/javascript'>ok( true, 'Injection of identical script' );</script>" ) ); + fixture.html( valueObj( "<script type='text/javascript'>ok( true, 'Injection of identical script' );</script>" ) ); + fixture.html( valueObj( "<script type='text/javascript'>ok( true, 'Injection of identical script' );</script>" ) ); + fixture.html( valueObj( "foo <form><script type='text/javascript'>ok( true, 'Injection of identical script (#975)' );</script></form>" ) ); jQuery.scriptorder = 0; - fixture.html( valueObj([ + fixture.html( valueObj( [ "<script>", "equal( jQuery('#scriptorder').length, 1,'Execute after html' );", "equal( jQuery.scriptorder++, 0, 'Script is executed in order' );", "</script>", "<span id='scriptorder'><script>equal( jQuery.scriptorder++, 1, 'Script (nested) is executed in order');</script></span>", "<script>equal( jQuery.scriptorder++, 2, 'Script (unnested) is executed in order' );</script>" - ].join("")) ); + ].join( "" ) ) ); } test( "html(String|Number)", function() { testHtml( manipulationBareObj ); -}); +} ); test( "html(Function)", function() { testHtml( manipulationFunctionReturningObj ); -}); +} ); test( "html( $.text() )", function() { expect( 1 ); - var fixture = jQuery("#qunit-fixture"); + var fixture = jQuery( "#qunit-fixture" ); fixture.html( fixture.text() ); ok( /^[^<]*[^<\s][^<]*$/.test( fixture.html() ), "Replace html with text" ); -}); +} ); test( "html( fn ) returns $.text()", function() { expect( 1 ); - var fixture = jQuery("#qunit-fixture"); + var fixture = jQuery( "#qunit-fixture" ); fixture.html( manipulationFunctionReturningObj( fixture.text() ) ); ok( /^[^<]*[^<\s][^<]*$/.test( fixture.html() ), "Replace html with text" ); -}); +} ); test( "html(Function) with incoming value -- direct selection", function() { @@ -1799,24 +1797,24 @@ test( "html(Function) with incoming value -- direct selection", function() { var els, actualhtml, pass; - els = jQuery("#foo > p"); - actualhtml = els.map(function() { + els = jQuery( "#foo > p" ); + actualhtml = els.map( function() { return jQuery( this ).html(); - }); + } ); - els.html(function( i, val ) { + els.html( function( i, val ) { equal( val, actualhtml[ i ], "Make sure the incoming value is correct." ); return "<b>test</b>"; - }); + } ); pass = true; - els.each(function() { + els.each( function() { if ( this.childNodes.length !== 1 ) { pass = false; } - }); + } ); ok( pass, "Set HTML" ); -}); +} ); test( "html(Function) with incoming value -- jQuery.contents()", function() { @@ -1824,15 +1822,15 @@ test( "html(Function) with incoming value -- jQuery.contents()", function() { var actualhtml, j, $div, $div2, insert; - j = jQuery("#nonnodes").contents(); - actualhtml = j.map(function() { + j = jQuery( "#nonnodes" ).contents(); + actualhtml = j.map( function() { return jQuery( this ).html(); - }); + } ); - j.html(function( i, val ) { + j.html( function( i, val ) { equal( val, actualhtml[ i ], "Make sure the incoming value is correct." ); return "<b>bold</b>"; - }); + } ); // Handle the case where no comment is in the document if ( j.length === 2 ) { @@ -1841,102 +1839,102 @@ test( "html(Function) with incoming value -- jQuery.contents()", function() { equal( j.html().replace( / xmlns="[^"]+"/g, "" ).toLowerCase(), "<b>bold</b>", "Check node,textnode,comment with html()" ); - $div = jQuery("<div />"); + $div = jQuery( "<div />" ); - equal( $div.html(function( i, val ) { + equal( $div.html( function( i, val ) { equal( val, "", "Make sure the incoming value is correct." ); return 5; - }).html(), "5", "Setting a number as html" ); + } ).html(), "5", "Setting a number as html" ); - equal( $div.html(function( i, val ) { + equal( $div.html( function( i, val ) { equal( val, "5", "Make sure the incoming value is correct." ); return 0; - }).html(), "0", "Setting a zero as html" ); + } ).html(), "0", "Setting a zero as html" ); - $div2 = jQuery("<div/>"); + $div2 = jQuery( "<div/>" ); insert = "<div>hello1</div>"; - equal( $div2.html(function( i, val ) { + equal( $div2.html( function( i, val ) { equal( val, "", "Make sure the incoming value is correct." ); return insert; - }).html().replace(/>/g, ">"), insert, "Verify escaped insertion." ); + } ).html().replace( />/g, ">" ), insert, "Verify escaped insertion." ); - equal( $div2.html(function( i, val ) { - equal( val.replace(/>/g, ">"), insert, "Make sure the incoming value is correct." ); + equal( $div2.html( function( i, val ) { + equal( val.replace( />/g, ">" ), insert, "Make sure the incoming value is correct." ); return "x" + insert; - }).html().replace( />/g, ">" ), "x" + insert, "Verify escaped insertion." ); + } ).html().replace( />/g, ">" ), "x" + insert, "Verify escaped insertion." ); - equal( $div2.html(function( i, val ) { + equal( $div2.html( function( i, val ) { equal( val.replace( />/g, ">" ), "x" + insert, "Make sure the incoming value is correct." ); return " " + insert; - }).html().replace( />/g, ">" ), " " + insert, "Verify escaped insertion." ); -}); + } ).html().replace( />/g, ">" ), " " + insert, "Verify escaped insertion." ); +} ); test( "clone()/html() don't expose jQuery/Sizzle expandos (#12858)", function() { expect( 2 ); - var $content = jQuery("<div><b><i>text</i></b></div>").appendTo("#qunit-fixture"), + var $content = jQuery( "<div><b><i>text</i></b></div>" ).appendTo( "#qunit-fixture" ), expected = /^<b><i>text<\/i><\/b>$/i; // Attach jQuery and Sizzle data (the latter with a non-qSA nth-child) try { - $content.find(":nth-child(1):lt(4)").data( "test", true ); + $content.find( ":nth-child(1):lt(4)" ).data( "test", true ); // But don't break on a non-Sizzle build - } catch( e ) { - $content.find("*").data( "test", true ); + } catch ( e ) { + $content.find( "*" ).data( "test", true ); } ok( expected.test( $content.clone( false )[ 0 ].innerHTML ), "clone()" ); ok( expected.test( $content.html() ), "html()" ); -}); +} ); test( "remove() no filters", function() { expect( 3 ); - var first = jQuery("#ap").children().first(); + var first = jQuery( "#ap" ).children().first(); - first.data("foo", "bar"); + first.data( "foo", "bar" ); - jQuery("#ap").children().remove(); - ok( jQuery("#ap").text().length > 10, "Check text is not removed" ); - equal( jQuery("#ap").children().length, 0, "Check remove" ); + jQuery( "#ap" ).children().remove(); + ok( jQuery( "#ap" ).text().length > 10, "Check text is not removed" ); + equal( jQuery( "#ap" ).children().length, 0, "Check remove" ); - equal( first.data("foo"), null, "first data" ); + equal( first.data( "foo" ), null, "first data" ); -}); +} ); test( "remove() with filters", function() { expect( 8 ); var markup, div; - jQuery("#ap").children().remove("a"); - ok( jQuery("#ap").text().length > 10, "Check text is not removed" ); - equal( jQuery("#ap").children().length, 1, "Check filtered remove" ); + jQuery( "#ap" ).children().remove( "a" ); + ok( jQuery( "#ap" ).text().length > 10, "Check text is not removed" ); + equal( jQuery( "#ap" ).children().length, 1, "Check filtered remove" ); - jQuery("#ap").children().remove("a, code"); - equal( jQuery("#ap").children().length, 0, "Check multi-filtered remove" ); + jQuery( "#ap" ).children().remove( "a, code" ); + equal( jQuery( "#ap" ).children().length, 0, "Check multi-filtered remove" ); // Positional and relative selectors markup = "<div><span>1</span><span>2</span><span>3</span><span>4</span></div>"; div = jQuery( markup ); - div.children().remove("span:nth-child(2n)"); + div.children().remove( "span:nth-child(2n)" ); equal( div.text(), "13", "relative selector in remove" ); div = jQuery( markup ); - div.children().remove("span:first"); + div.children().remove( "span:first" ); equal( div.text(), "234", "positional selector in remove" ); div = jQuery( markup ); - div.children().remove("span:last"); + div.children().remove( "span:last" ); equal( div.text(), "123", "positional selector in remove" ); // using contents will get comments regular, text, and comment nodes // Handle the case where no comment is in the document - ok( jQuery("#nonnodes").contents().length >= 2, "Check node,textnode,comment remove works" ); - jQuery("#nonnodes").contents().remove(); - equal( jQuery("#nonnodes").contents().length, 0, "Check node,textnode,comment remove works" ); -}); + ok( jQuery( "#nonnodes" ).contents().length >= 2, "Check node,textnode,comment remove works" ); + jQuery( "#nonnodes" ).contents().remove(); + equal( jQuery( "#nonnodes" ).contents().length, 0, "Check node,textnode,comment remove works" ); +} ); test( "remove() event cleaning ", function() { expect( 1 ); @@ -1944,16 +1942,16 @@ test( "remove() event cleaning ", function() { var count, first, cleanUp; count = 0; - first = jQuery("#ap").children().first(); + first = jQuery( "#ap" ).children().first(); cleanUp = first.on( "click", function() { count++; - }).remove().appendTo("#qunit-fixture").trigger("click"); + } ).remove().appendTo( "#qunit-fixture" ).trigger( "click" ); strictEqual( 0, count, "Event handler has been removed" ); // Clean up detached data cleanUp.remove(); -}); +} ); test( "remove() in document order #13779", function() { expect( 1 ); @@ -1962,11 +1960,11 @@ test( "remove() in document order #13779", function() { cleanData = jQuery.cleanData; jQuery.cleanData = function( nodes ) { - last = jQuery.text( nodes[0] ); + last = jQuery.text( nodes[ 0 ] ); cleanData.call( this, nodes ); }; - jQuery("#qunit-fixture").append( + jQuery( "#qunit-fixture" ).append( jQuery.parseHTML( "<div class='removal-fixture'>1</div>" + "<div class='removal-fixture'>2</div>" + @@ -1974,60 +1972,60 @@ test( "remove() in document order #13779", function() { ) ); - jQuery(".removal-fixture").remove(); + jQuery( ".removal-fixture" ).remove(); equal( last, 3, "The removal fixtures were removed in document order" ); jQuery.cleanData = cleanData; -}); +} ); -test("detach() no filters", function () { +test( "detach() no filters", function() { - expect(3); + expect( 3 ); - var first = jQuery("#ap").children().first(); + var first = jQuery( "#ap" ).children().first(); - first.data("foo", "bar"); + first.data( "foo", "bar" ); - jQuery("#ap").children().detach(); - ok(jQuery("#ap").text().length > 10, "Check text is not removed"); - equal(jQuery("#ap").children().length, 0, "Check remove"); + jQuery( "#ap" ).children().detach(); + ok( jQuery( "#ap" ).text().length > 10, "Check text is not removed" ); + equal( jQuery( "#ap" ).children().length, 0, "Check remove" ); - equal(first.data("foo"), "bar"); + equal( first.data( "foo" ), "bar" ); first.remove(); -}); +} ); -test("detach() with filters", function () { +test( "detach() with filters", function() { - expect(8); + expect( 8 ); var markup, div; - jQuery("#ap").children().detach("a"); - ok(jQuery("#ap").text().length > 10, "Check text is not removed"); - equal(jQuery("#ap").children().length, 1, "Check filtered remove"); + jQuery( "#ap" ).children().detach( "a" ); + ok( jQuery( "#ap" ).text().length > 10, "Check text is not removed" ); + equal( jQuery( "#ap" ).children().length, 1, "Check filtered remove" ); - jQuery("#ap").children().detach("a, code"); - equal(jQuery("#ap").children().length, 0, "Check multi-filtered remove"); + jQuery( "#ap" ).children().detach( "a, code" ); + equal( jQuery( "#ap" ).children().length, 0, "Check multi-filtered remove" ); // Positional and relative selectors markup = "<div><span>1</span><span>2</span><span>3</span><span>4</span></div>"; - div = jQuery(markup); - div.children().detach("span:nth-child(2n)"); - equal(div.text(), "13", "relative selector in detach"); - div = jQuery(markup); - div.children().detach("span:first"); - equal(div.text(), "234", "positional selector in detach"); - div = jQuery(markup); - div.children().detach("span:last"); - equal(div.text(), "123", "positional selector in detach"); + div = jQuery( markup ); + div.children().detach( "span:nth-child(2n)" ); + equal( div.text(), "13", "relative selector in detach" ); + div = jQuery( markup ); + div.children().detach( "span:first" ); + equal( div.text(), "234", "positional selector in detach" ); + div = jQuery( markup ); + div.children().detach( "span:last" ); + equal( div.text(), "123", "positional selector in detach" ); // using contents will get comments regular, text, and comment nodes // Handle the case where no comment is in the document - ok(jQuery("#nonnodes").contents().length >= 2, "Check node,textnode,comment remove works"); - jQuery("#nonnodes").contents().detach(); - equal(jQuery("#nonnodes").contents().length, 0, "Check node,textnode,comment remove works"); -}); + ok( jQuery( "#nonnodes" ).contents().length >= 2, "Check node,textnode,comment remove works" ); + jQuery( "#nonnodes" ).contents().detach(); + equal( jQuery( "#nonnodes" ).contents().length, 0, "Check node,textnode,comment remove works" ); +} ); test( "detach() event cleaning ", function() { expect( 1 ); @@ -2035,35 +2033,35 @@ test( "detach() event cleaning ", function() { var count, first, cleanUp; count = 0; - first = jQuery("#ap").children().first(); + first = jQuery( "#ap" ).children().first(); cleanUp = first.on( "click", function() { count++; - }).detach().appendTo("#qunit-fixture").trigger("click"); + } ).detach().appendTo( "#qunit-fixture" ).trigger( "click" ); strictEqual( 1, count, "Event handler has not been removed" ); // Clean up detached data cleanUp.remove(); -}); +} ); -test("empty()", function() { +test( "empty()", function() { expect( 6 ); - equal( jQuery("#ap").children().empty().text().length, 0, "Check text is removed" ); - equal( jQuery("#ap").children().length, 4, "Check elements are not removed" ); + equal( jQuery( "#ap" ).children().empty().text().length, 0, "Check text is removed" ); + equal( jQuery( "#ap" ).children().length, 4, "Check elements are not removed" ); // using contents will get comments regular, text, and comment nodes - var j = jQuery("#nonnodes").contents(); + var j = jQuery( "#nonnodes" ).contents(); j.empty(); equal( j.html(), "", "Check node,textnode,comment empty works" ); // Ensure oldIE empties selects (#12336) - notEqual( jQuery("#select1").find("option").length, 0, "Have some initial options" ); - jQuery("#select1").empty(); - equal( jQuery("#select1").find("option").length, 0, "No more option elements found" ); - equal( jQuery("#select1")[0].options.length, 0, "options.length cleared as well" ); -}); + notEqual( jQuery( "#select1" ).find( "option" ).length, 0, "Have some initial options" ); + jQuery( "#select1" ).empty(); + equal( jQuery( "#select1" ).find( "option" ).length, 0, "No more option elements found" ); + equal( jQuery( "#select1" )[ 0 ].options.length, 0, "options.length cleared as well" ); +} ); test( "jQuery.cleanData", function() { @@ -2078,10 +2076,10 @@ test( "jQuery.cleanData", function() { // Should both do nothing pos = "Outer"; - div.trigger("click"); + div.trigger( "click" ); pos = "Inner"; - div.children().trigger("click"); + div.children().trigger( "click" ); type = "empty"; div = getDiv(); @@ -2092,11 +2090,11 @@ test( "jQuery.cleanData", function() { // Should trigger 1 pos = "Outer"; - div.trigger("click"); + div.trigger( "click" ); // Should do nothing pos = "Inner"; - child.trigger("click"); + child.trigger( "click" ); // Should trigger 2 div.remove(); @@ -2107,29 +2105,29 @@ test( "jQuery.cleanData", function() { child = div.children(); // Should trigger 2 remove event - div.html("<div></div>"); + div.html( "<div></div>" ); // Should trigger 1 pos = "Outer"; - div.trigger("click"); + div.trigger( "click" ); // Should do nothing pos = "Inner"; - child.trigger("click"); + child.trigger( "click" ); // Should trigger 2 div.remove(); function getDiv() { - var div = jQuery("<div class='outer'><div class='inner'></div></div>").on( "click", function() { + var div = jQuery( "<div class='outer'><div class='inner'></div></div>" ).on( "click", function() { ok( true, type + " " + pos + " Click event fired." ); - }).on( "focus", function() { + } ).on( "focus", function() { ok( true, type + " " + pos + " Focus event fired." ); - }).find("div").on( "click", function() { + } ).find( "div" ).on( "click", function() { ok( false, type + " " + pos + " Click event fired." ); - }).on( "focus", function() { + } ).on( "focus", function() { ok( false, type + " " + pos + " Focus event fired." ); - }).end().appendTo("body"); + } ).end().appendTo( "body" ); div[ 0 ].detachEvent = div[ 0 ].removeEventListener = function( t ) { ok( true, type + " Outer " + t + " event unbound" ); @@ -2141,7 +2139,7 @@ test( "jQuery.cleanData", function() { return div; } -}); +} ); test( "jQuery.cleanData eliminates all private data (gh-2127)", function() { expect( 3 ); @@ -2160,7 +2158,7 @@ test( "jQuery.cleanData eliminates all private data (gh-2127)", function() { "Private data is empty after node is removed" ); div.remove(); -}); +} ); test( "jQuery.cleanData eliminates all public data", function() { expect( 2 ); @@ -2180,7 +2178,7 @@ test( "jQuery.cleanData eliminates all public data", function() { ok( false, "Expando was not removed when there was no more data" ); } } -}); +} ); test( "domManip plain-text caching (trac-6779)", function() { @@ -2195,11 +2193,11 @@ test( "domManip plain-text caching (trac-6779)", function() { try { $f.append( bad[ i ] ); } - catch( e ) {} + catch ( e ) {} } - equal( $f.text(), bad.join(""), "Cached strings that match Object properties" ); + equal( $f.text(), bad.join( "" ), "Cached strings that match Object properties" ); $f.remove(); -}); +} ); test( "domManip executes scripts containing html comments or CDATA (trac-9221)", function() { @@ -2228,7 +2226,7 @@ test( "domManip executes scripts containing html comments or CDATA (trac-9221)", "//--><!]]>", "</script>" ].join( "\n" ) ).appendTo( "#qunit-fixture" ); -}); +} ); testIframeWithCallback( "domManip tolerates window-valued document[0] in IE9/10 (trac-12266)", @@ -2244,12 +2242,12 @@ test( "jQuery.clone - no exceptions for object elements #9587", function() { expect( 1 ); try { - jQuery("#no-clone-exception").clone(); + jQuery( "#no-clone-exception" ).clone(); ok( true, "cloned with no exceptions" ); - } catch( e ) { + } catch ( e ) { ok( false, e.message ); } -}); +} ); test( "Cloned, detached HTML5 elems (#10667,10670)", function() { @@ -2263,9 +2261,11 @@ test( "Cloned, detached HTML5 elems (#10667,10670)", function() { // Infer that the test is being run in IE<=8 if ( $clone[ 0 ].outerHTML && !jQuery.support.opacity ) { + // This branch tests cloning nodes by reading the outerHTML, used only in IE<=8 equal( $clone[ 0 ].outerHTML, "<section></section>", "detached clone outerHTML matches '<section></section>'" ); } else { + // This branch tests a known behaviour in modern browsers that should never fail. // Included for expected test count symmetry (expecting 1) equal( $clone[ 0 ].nodeName, "SECTION", "detached clone nodeName matches 'SECTION' in modern browsers" ); @@ -2274,38 +2274,38 @@ test( "Cloned, detached HTML5 elems (#10667,10670)", function() { // Bind an event $section.on( "click", function() { ok( true, "clone fired event" ); - }); + } ); // Second clone (will have an event bound) $clone = $section.clone( true ); // Trigger an event from the first clone - $clone.trigger("click"); - $clone.off("click"); + $clone.trigger( "click" ); + $clone.off( "click" ); // Add a child node with text to the original - $section.append("<p>Hello</p>"); + $section.append( "<p>Hello</p>" ); // Third clone (will have child node and text) $clone = $section.clone( true ); - equal( $clone.find("p").text(), "Hello", "Assert text in child of clone" ); + equal( $clone.find( "p" ).text(), "Hello", "Assert text in child of clone" ); // Trigger an event from the third clone - $clone.trigger("click"); - $clone.off("click"); + $clone.trigger( "click" ); + $clone.off( "click" ); // Add attributes to copy - $section.attr({ + $section.attr( { "class": "foo bar baz", "title": "This is a title" - }); + } ); // Fourth clone (will have newly added attributes) $clone = $section.clone( true ); - equal( $clone.attr("class"), $section.attr("class"), "clone and element have same class attribute" ); - equal( $clone.attr("title"), $section.attr("title"), "clone and element have same title attribute" ); + equal( $clone.attr( "class" ), $section.attr( "class" ), "clone and element have same class attribute" ); + equal( $clone.attr( "title" ), $section.attr( "title" ), "clone and element have same title attribute" ); // Remove the original $section.remove(); @@ -2317,12 +2317,12 @@ test( "Cloned, detached HTML5 elems (#10667,10670)", function() { $clone.remove(); // Trigger an event from the clone of the clone - $section.trigger("click"); + $section.trigger( "click" ); // Unbind any remaining events - $section.off("click"); - $clone.off("click"); -}); + $section.off( "click" ); + $clone.off( "click" ); +} ); test( "Guard against exceptions when clearing safeChildNodes", function() { @@ -2331,24 +2331,25 @@ test( "Guard against exceptions when clearing safeChildNodes", function() { var div; try { - div = jQuery("<div/><hr/><code/><b/>"); - } catch(e) {} + div = jQuery( "<div/><hr/><code/><b/>" ); + } catch ( e ) {} ok( div && div.jquery, "Created nodes safely, guarded against exceptions on safeChildNodes[ -1 ]" ); -}); +} ); test( "Ensure oldIE creates a new set on appendTo (#8894)", function() { expect( 5 ); - strictEqual( jQuery("<div/>").clone().addClass("test").appendTo("<div/>").end().end().hasClass("test"), false, "Check jQuery.fn.appendTo after jQuery.clone" ); - strictEqual( jQuery("<div/>").find("p").end().addClass("test").appendTo("<div/>").end().end().hasClass("test"), false, "Check jQuery.fn.appendTo after jQuery.fn.find" ); - strictEqual( jQuery("<div/>").text("test").addClass("test").appendTo("<div/>").end().end().hasClass("test"), false, "Check jQuery.fn.appendTo after jQuery.fn.text" ); - strictEqual( jQuery("<bdi/>").clone().addClass("test").appendTo("<div/>").end().end().hasClass("test"), false, "Check jQuery.fn.appendTo after clone html5 element" ); - strictEqual( jQuery("<p/>").appendTo("<div/>").end().length, jQuery("<p>test</p>").appendTo("<div/>").end().length, "Elements created with createElement and with createDocumentFragment should be treated alike" ); -}); + strictEqual( jQuery( "<div/>" ).clone().addClass( "test" ).appendTo( "<div/>" ).end().end().hasClass( "test" ), false, "Check jQuery.fn.appendTo after jQuery.clone" ); + strictEqual( jQuery( "<div/>" ).find( "p" ).end().addClass( "test" ).appendTo( "<div/>" ).end().end().hasClass( "test" ), false, "Check jQuery.fn.appendTo after jQuery.fn.find" ); + strictEqual( jQuery( "<div/>" ).text( "test" ).addClass( "test" ).appendTo( "<div/>" ).end().end().hasClass( "test" ), false, "Check jQuery.fn.appendTo after jQuery.fn.text" ); + strictEqual( jQuery( "<bdi/>" ).clone().addClass( "test" ).appendTo( "<div/>" ).end().end().hasClass( "test" ), false, "Check jQuery.fn.appendTo after clone html5 element" ); + strictEqual( jQuery( "<p/>" ).appendTo( "<div/>" ).end().length, jQuery( "<p>test</p>" ).appendTo( "<div/>" ).end().length, "Elements created with createElement and with createDocumentFragment should be treated alike" ); +} ); asyncTest( "html() - script exceptions bubble (#11743)", 2, function() { + // Support: Android 2.3 only // Android 2.3 doesn't fire the window.onerror handler, just accept the reality there. if ( /android 2\.3/i.test( navigator.userAgent ) ) { @@ -2362,7 +2363,7 @@ asyncTest( "html() - script exceptions bubble (#11743)", 2, function() { var onerror = window.onerror; - setTimeout(function() { + setTimeout( function() { window.onerror = onerror; start(); @@ -2385,46 +2386,46 @@ asyncTest( "html() - script exceptions bubble (#11743)", 2, function() { }; jQuery( "#qunit-fixture" ).html( "<script>undefined();</script>" ); -}); +} ); test( "checked state is cloned with clone()", function() { expect( 2 ); - var elem = jQuery.parseHTML("<input type='checkbox' checked='checked'/>")[ 0 ]; + var elem = jQuery.parseHTML( "<input type='checkbox' checked='checked'/>" )[ 0 ]; elem.checked = false; - equal( jQuery(elem).clone().attr("id","clone")[ 0 ].checked, false, "Checked false state correctly cloned" ); + equal( jQuery( elem ).clone().attr( "id", "clone" )[ 0 ].checked, false, "Checked false state correctly cloned" ); - elem = jQuery.parseHTML("<input type='checkbox'/>")[ 0 ]; + elem = jQuery.parseHTML( "<input type='checkbox'/>" )[ 0 ]; elem.checked = true; - equal( jQuery(elem).clone().attr("id","clone")[ 0 ].checked, true, "Checked true state correctly cloned" ); -}); + equal( jQuery( elem ).clone().attr( "id", "clone" )[ 0 ].checked, true, "Checked true state correctly cloned" ); +} ); test( "manipulate mixed jQuery and text (#12384, #12346)", function() { expect( 2 ); - var div = jQuery("<div>a</div>").append( " ", jQuery("<span>b</span>"), " ", jQuery("<span>c</span>") ), + var div = jQuery( "<div>a</div>" ).append( " ", jQuery( "<span>b</span>" ), " ", jQuery( "<span>c</span>" ) ), nbsp = String.fromCharCode( 160 ); - equal( div.text(), "a" + nbsp + "b" + nbsp+ "c", "Appending mixed jQuery with text nodes" ); + equal( div.text(), "a" + nbsp + "b" + nbsp + "c", "Appending mixed jQuery with text nodes" ); - div = jQuery("<div><div></div></div>") - .find("div") + div = jQuery( "<div><div></div></div>" ) + .find( "div" ) .after( "<p>a</p>", "<p>b</p>" ) .parent(); - equal( div.find("*").length, 3, "added 2 paragraphs after inner div" ); -}); + equal( div.find( "*" ).length, 3, "added 2 paragraphs after inner div" ); +} ); test( "script evaluation (#11795)", function() { expect( 13 ); var scriptsIn, scriptsOut, - fixture = jQuery("#qunit-fixture").empty(), - objGlobal = (function() { + fixture = jQuery( "#qunit-fixture" ).empty(), + objGlobal = ( function() { return this; - })(), + } )(), isOk = objGlobal.ok, notOk = function() { var args = arguments; @@ -2433,7 +2434,7 @@ test( "script evaluation (#11795)", function() { }; objGlobal.ok = notOk; - scriptsIn = jQuery([ + scriptsIn = jQuery( [ "<script type='something/else'>ok( false, 'evaluated: non-script' );</script>", "<script type='text/javascript'>ok( true, 'evaluated: text/javascript' );</script>", "<script type='text/ecmascript'>ok( true, 'evaluated: text/ecmascript' );</script>", @@ -2444,31 +2445,31 @@ test( "script evaluation (#11795)", function() { "<script type='text/ecmascript'>ok( true, 'evaluated: inner text/ecmascript' );</script>", "<script>ok( true, 'evaluated: inner no type' );</script>", "</div>" - ].join("")); - scriptsIn.appendTo( jQuery("<div class='detached'/>") ); + ].join( "" ) ); + scriptsIn.appendTo( jQuery( "<div class='detached'/>" ) ); objGlobal.ok = isOk; - scriptsOut = fixture.append( scriptsIn ).find("script"); + scriptsOut = fixture.append( scriptsIn ).find( "script" ); equal( scriptsOut[ 0 ].type, "something/else", "Non-evaluated type." ); equal( scriptsOut[ 1 ].type, "text/javascript", "Evaluated type." ); - deepEqual( scriptsOut.get(), fixture.find("script").get(), "All script tags remain." ); + deepEqual( scriptsOut.get(), fixture.find( "script" ).get(), "All script tags remain." ); objGlobal.ok = notOk; - scriptsOut = scriptsOut.add( scriptsOut.clone() ).appendTo( fixture.find("div") ); - deepEqual( fixture.find("div script").get(), scriptsOut.get(), "Scripts cloned without reevaluation" ); + scriptsOut = scriptsOut.add( scriptsOut.clone() ).appendTo( fixture.find( "div" ) ); + deepEqual( fixture.find( "div script" ).get(), scriptsOut.get(), "Scripts cloned without reevaluation" ); fixture.append( scriptsOut.detach() ); - deepEqual( fixture.children("script").get(), scriptsOut.get(), "Scripts detached without reevaluation" ); + deepEqual( fixture.children( "script" ).get(), scriptsOut.get(), "Scripts detached without reevaluation" ); objGlobal.ok = isOk; if ( jQuery.ajax ) { - Globals.register("testBar"); - jQuery("#qunit-fixture").append( "<script src='" + url("data/testbar.php") + "'/>" ); - strictEqual( window["testBar"], "bar", "Global script evaluation" ); + Globals.register( "testBar" ); + jQuery( "#qunit-fixture" ).append( "<script src='" + url( "data/testbar.php" ) + "'/>" ); + strictEqual( window[ "testBar" ], "bar", "Global script evaluation" ); } else { ok( true, "No jQuery.ajax" ); ok( true, "No jQuery.ajax" ); } -}); +} ); test( "jQuery._evalUrl (#12838)", function() { @@ -2484,7 +2485,7 @@ test( "jQuery._evalUrl (#12838)", function() { equal( ( input.url || input ).slice( -1 ), expectedArgument, message ); expectedArgument++; }; - jQuery("#qunit-fixture").append("<script src='1'/><script src='2'/>"); + jQuery( "#qunit-fixture" ).append( "<script src='1'/><script src='2'/>" ); equal( expectedArgument, 3, "synchronous execution" ); message = "custom implementation"; @@ -2493,11 +2494,11 @@ test( "jQuery._evalUrl (#12838)", function() { jQuery.ajax = function( options ) { strictEqual( options, {}, "Unexpected call to jQuery.ajax" ); }; - jQuery("#qunit-fixture").append("<script src='3'/><script src='4'/>"); + jQuery( "#qunit-fixture" ).append( "<script src='3'/><script src='4'/>" ); jQuery.ajax = ajax; jQuery._evalUrl = evalUrl; -}); +} ); test( "jQuery.htmlPrefilter (gh-1747)", function( assert ) { @@ -2537,7 +2538,7 @@ test( "jQuery.htmlPrefilter (gh-1747)", function( assert ) { jQuery.htmlPrefilter = htmlPrefilter; done(); }, 100 ); -}); +} ); test( "insertAfter, insertBefore, etc do not work when destination is original element. Element is removed (#4087)", function() { @@ -2545,7 +2546,7 @@ test( "insertAfter, insertBefore, etc do not work when destination is original e var elems; - jQuery.each([ + jQuery.each( [ "appendTo", "prependTo", "insertBefore", @@ -2556,44 +2557,44 @@ test( "insertAfter, insertBefore, etc do not work when destination is original e "<ul id='test4087-complex'><li class='test4087'><div>c1</div>h1</li><li><div>c2</div>h2</li></ul>", "<div id='test4087-simple'><div class='test4087-1'>1<div class='test4087-2'>2</div><div class='test4087-3'>3</div></div></div>", "<div id='test4087-multiple'><div class='test4087-multiple'>1</div><div class='test4087-multiple'>2</div></div>" - ].join("") ).appendTo( "#qunit-fixture" ); + ].join( "" ) ).appendTo( "#qunit-fixture" ); // complex case based on http://jsfiddle.net/pbramos/gZ7vB/ - jQuery("#test4087-complex div")[ name ]("#test4087-complex li:last-child div:last-child"); - equal( jQuery("#test4087-complex li:last-child div").length, name === "replaceAll" ? 1 : 2, name +" a node to itself, complex case." ); + jQuery( "#test4087-complex div" )[ name ]( "#test4087-complex li:last-child div:last-child" ); + equal( jQuery( "#test4087-complex li:last-child div" ).length, name === "replaceAll" ? 1 : 2, name + " a node to itself, complex case." ); // simple case - jQuery( ".test4087-1" )[ name ](".test4087-1"); - equal( jQuery(".test4087-1").length, 1, name +" a node to itself, simple case." ); + jQuery( ".test4087-1" )[ name ]( ".test4087-1" ); + equal( jQuery( ".test4087-1" ).length, 1, name + " a node to itself, simple case." ); // clean for next test - jQuery("#test4087-complex").remove(); - jQuery("#test4087-simple").remove(); - jQuery("#test4087-multiple").remove(); - }); -}); + jQuery( "#test4087-complex" ).remove(); + jQuery( "#test4087-simple" ).remove(); + jQuery( "#test4087-multiple" ).remove(); + } ); +} ); test( "Index for function argument should be received (#13094)", function() { expect( 2 ); var i = 0; - jQuery("<div/><div/>").before(function( index ) { + jQuery( "<div/><div/>" ).before( function( index ) { equal( index, i++, "Index should be correct" ); - }); + } ); -}); +} ); test( "Make sure jQuery.fn.remove can work on elements in documentFragment", function() { expect( 1 ); var fragment = document.createDocumentFragment(), - div = fragment.appendChild( document.createElement("div") ); + div = fragment.appendChild( document.createElement( "div" ) ); jQuery( div ).remove(); equal( fragment.childNodes.length, 0, "div element was removed from documentFragment" ); -}); +} ); test( "Make sure tr element will be appended to tbody element of table when present", function() { expect( 1 ); @@ -2610,7 +2611,7 @@ test( "Make sure tr element will be appended to tbody element of table when pres html = table.innerHTML.toLowerCase().replace( /\s/g, "" ); strictEqual( html, "<tbody><tr><td>test</td></tr></tbody>" ); -}); +} ); test( "Make sure tr elements will be appended to tbody element of table when present", function() { expect( 1 ); @@ -2627,7 +2628,7 @@ test( "Make sure tr elements will be appended to tbody element of table when pre html = table.innerHTML.toLowerCase().replace( /\s/g, "" ); strictEqual( html, "<tbody><tr><td>1</td></tr><tr><td>2</td></tr></tbody>" ); -}); +} ); test( "Make sure tfoot element will not be appended to tbody element of table when present", function() { expect( 1 ); @@ -2644,7 +2645,7 @@ test( "Make sure tfoot element will not be appended to tbody element of table wh html = table.innerHTML.toLowerCase().replace( /\s/g, "" ); strictEqual( html, "<tbody></tbody><tfoot></tfoot>" ); -}); +} ); test( "Make sure document fragment will be appended to tbody element of table when present", function() { expect( 1 ); @@ -2668,7 +2669,7 @@ test( "Make sure document fragment will be appended to tbody element of table wh html = table.innerHTML.toLowerCase().replace( /\s/g, "" ); strictEqual( html, "<tbody><tr><td>test</td></tr></tbody>" ); -}); +} ); test( "Make sure col element is appended correctly", function() { expect( 1 ); @@ -2680,7 +2681,7 @@ test( "Make sure col element is appended correctly", function() { jQuery( "<col width='150'/>" ).prependTo( table ); strictEqual( table.find( "td" ).width(), 150 ); -}); +} ); asyncTest( "Insert script with data-URI (gh-1887)", 1, function() { Globals.register( "testFoo" ); @@ -2695,7 +2696,7 @@ asyncTest( "Insert script with data-URI (gh-1887)", 1, function() { jQuery( fixture ).append( "<script src=\"data:text/javascript,testFoo = 'foo';\"></script>" ); - setTimeout(function() { + setTimeout( function() { if ( window[ "testSrcFoo" ] === "foo" ) { strictEqual( window[ "testFoo" ], window[ "testSrcFoo" ], "data-URI script executed" ); @@ -2705,4 +2706,4 @@ asyncTest( "Insert script with data-URI (gh-1887)", 1, function() { start(); }, 100 ); -}); +} ); diff --git a/test/unit/offset.js b/test/unit/offset.js index e8ba9fb53..7575a001e 100644 --- a/test/unit/offset.js +++ b/test/unit/offset.js @@ -1,39 +1,40 @@ -(function() { +( function() { if ( !jQuery.fn.offset ) { return; } var supportsScroll, supportsFixedPosition, - forceScroll = jQuery("<div/>").css({ width: 2000, height: 2000 }), + forceScroll = jQuery( "<div/>" ).css( { width: 2000, height: 2000 } ), checkSupport = function() { + // Only run once checkSupport = false; - var checkFixed = jQuery("<div/>").css({ position: "fixed", top: "20px" }).appendTo("#qunit-fixture"); + var checkFixed = jQuery( "<div/>" ).css( { position: "fixed", top: "20px" } ).appendTo( "#qunit-fixture" ); // Must append to body because #qunit-fixture is hidden and elements inside it don't have a scrollTop - forceScroll.appendTo("body"); + forceScroll.appendTo( "body" ); window.scrollTo( 200, 200 ); supportsScroll = document.documentElement.scrollTop || document.body.scrollTop; forceScroll.detach(); // Safari subtracts parent border width here (which is 5px) - supportsFixedPosition = checkFixed[0].offsetTop === 20 || checkFixed[0].offsetTop === 15; + supportsFixedPosition = checkFixed[ 0 ].offsetTop === 20 || checkFixed[ 0 ].offsetTop === 15; checkFixed.remove(); }; -module("offset", { setup: function(){ +module( "offset", { setup: function() { if ( typeof checkSupport === "function" ) { checkSupport(); } // Force a scroll value on the main window to ensure incorrect results // if offset is using the scroll offset of the parent window - forceScroll.appendTo("body"); + forceScroll.appendTo( "body" ); window.scrollTo( 1, 1 ); forceScroll.detach(); -}, teardown: moduleTeardown }); +}, teardown: moduleTeardown } ); /* Closure-compiler will roll static methods off of the jQuery object and so they will @@ -42,13 +43,13 @@ module("offset", { setup: function(){ the iframe window and the "jQuery" symbol is used to access any static methods. */ -test("empty set", function() { +test( "empty set", function() { expect( 2 ); strictEqual( jQuery().offset(), undefined, "offset() returns undefined for empty set (#11962)" ); strictEqual( jQuery().position(), undefined, "position() returns undefined for empty set (#11962)" ); -}); +} ); -test("disconnected element", function() { +test( "disconnected element", function() { expect( 2 ); var result = jQuery( document.createElement( "div" ) ).offset(); @@ -58,12 +59,12 @@ test("disconnected element", function() { // valid input, but will return zeros for back-compat equal( result.top, 0, "Retrieving offset on disconnected elements returns zeros (gh-2310)" ); equal( result.left, 0, "Retrieving offset on disconnected elements returns zeros (gh-2310)" ); -}); +} ); -test("hidden (display: none) element", function() { +test( "hidden (display: none) element", function() { expect( 2 ); - var node = jQuery("<div style='display: none' />").appendTo("#qunit-fixture"), + var node = jQuery( "<div style='display: none' />" ).appendTo( "#qunit-fixture" ), result = node.offset(); node.remove(); @@ -73,10 +74,10 @@ test("hidden (display: none) element", function() { // valid input, but will return zeros for back-compat equal( result.top, 0, "Retrieving offset on hidden elements returns zeros (gh-2310)" ); equal( result.left, 0, "Retrieving offset on hidden elements returns zeros (gh-2310)" ); -}); +} ); -testIframe("offset/absolute", "absolute", function($, iframe) { - expect(4); +testIframe( "offset/absolute", "absolute", function( $, iframe ) { + expect( 4 ); var doc = iframe.document, tests; @@ -86,23 +87,22 @@ testIframe("offset/absolute", "absolute", function($, iframe) { { "id": "#absolute-1", "top": 1, "left": 1 } ]; jQuery.each( tests, function() { - equal( jQuery( this["id"], doc ).offset().top, this["top"], "jQuery('" + this["id"] + "').offset().top" ); - equal( jQuery( this["id"], doc ).offset().left, this["left"], "jQuery('" + this["id"] + "').offset().left" ); - }); - + equal( jQuery( this[ "id" ], doc ).offset().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').offset().top" ); + equal( jQuery( this[ "id" ], doc ).offset().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').offset().left" ); + } ); // get position tests = [ { "id": "#absolute-1", "top": 0, "left": 0 } ]; jQuery.each( tests, function() { - equal( jQuery( this["id"], doc ).position().top, this["top"], "jQuery('" + this["id"] + "').position().top" ); - equal( jQuery( this["id"], doc ).position().left, this["left"], "jQuery('" + this["id"] + "').position().left" ); - }); -}); + equal( jQuery( this[ "id" ], doc ).position().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').position().top" ); + equal( jQuery( this[ "id" ], doc ).position().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').position().left" ); + } ); +} ); -testIframe("offset/absolute", "absolute", function( $ ) { - expect(178); +testIframe( "offset/absolute", "absolute", function( $ ) { + expect( 178 ); var tests, offset; @@ -114,10 +114,9 @@ testIframe("offset/absolute", "absolute", function( $ ) { { "id": "#absolute-2", "top": 20, "left": 20 } ]; jQuery.each( tests, function() { - equal( $( this["id"] ).offset().top, this["top"], "jQuery('" + this["id"] + "').offset().top" ); - equal( $( this["id"] ).offset().left, this["left"], "jQuery('" + this["id"] + "').offset().left" ); - }); - + equal( $( this[ "id" ] ).offset().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').offset().top" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').offset().left" ); + } ); // get position tests = [ @@ -127,16 +126,15 @@ testIframe("offset/absolute", "absolute", function( $ ) { { "id": "#absolute-2", "top": 19, "left": 19 } ]; jQuery.each( tests, function() { - equal( $( this["id"] ).position().top, this["top"], "jQuery('" + this["id"] + "').position().top" ); - equal( $( this["id"] ).position().left, this["left"], "jQuery('" + this["id"] + "').position().left" ); - }); + equal( $( this[ "id" ] ).position().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').position().top" ); + equal( $( this[ "id" ] ).position().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').position().left" ); + } ); // test #5781 - offset = $( "#positionTest" ).offset({ "top": 10, "left": 10 }).offset(); + offset = $( "#positionTest" ).offset( { "top": 10, "left": 10 } ).offset(); equal( offset.top, 10, "Setting offset on element with position absolute but 'auto' values." ); equal( offset.left, 10, "Setting offset on element with position absolute but 'auto' values." ); - // set offset tests = [ { "id": "#absolute-2", "top": 30, "left": 30 }, @@ -157,39 +155,39 @@ testIframe("offset/absolute", "absolute", function( $ ) { { "id": "#absolute-1", "top": 1, "left": 1 } ]; jQuery.each( tests, function() { - $( this["id"] ).offset({ "top": this["top"], "left": this["left"] }); - equal( $( this["id"] ).offset().top, this["top"], "jQuery('" + this["id"] + "').offset({ top: " + this["top"] + " })" ); - equal( $( this["id"] ).offset().left, this["left"], "jQuery('" + this["id"] + "').offset({ left: " + this["left"] + " })" ); + $( this[ "id" ] ).offset( { "top": this[ "top" ], "left": this[ "left" ] } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').offset({ top: " + this[ "top" ] + " })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').offset({ left: " + this[ "left" ] + " })" ); - var top = this["top"], left = this["left"]; + var top = this[ "top" ], left = this[ "left" ]; - $( this["id"] ).offset(function(i, val){ + $( this[ "id" ] ).offset( function( i, val ) { equal( val.top, top, "Verify incoming top position." ); equal( val.left, left, "Verify incoming top position." ); return { "top": top + 1, "left": left + 1 }; - }); - equal( $( this["id"] ).offset().top, this["top"] + 1, "jQuery('" + this["id"] + "').offset({ top: " + (this["top"] + 1) + " })" ); - equal( $( this["id"] ).offset().left, this["left"] + 1, "jQuery('" + this["id"] + "').offset({ left: " + (this["left"] + 1) + " })" ); - - $( this["id"] ) - .offset({ "left": this["left"] + 2 }) - .offset({ "top": this["top"] + 2 }); - equal( $( this["id"] ).offset().top, this["top"] + 2, "Setting one property at a time." ); - equal( $( this["id"] ).offset().left, this["left"] + 2, "Setting one property at a time." ); - - $( this["id"] ).offset({ "top": this["top"], "left": this["left"], "using": function( props ) { - $( this ).css({ + } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ top: " + ( this[ "top" ] + 1 ) + " })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ left: " + ( this[ "left" ] + 1 ) + " })" ); + + $( this[ "id" ] ) + .offset( { "left": this[ "left" ] + 2 } ) + .offset( { "top": this[ "top" ] + 2 } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ] + 2, "Setting one property at a time." ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ] + 2, "Setting one property at a time." ); + + $( this[ "id" ] ).offset( { "top": this[ "top" ], "left": this[ "left" ], "using": function( props ) { + $( this ).css( { "top": props.top + 1, "left": props.left + 1 - }); - }}); - equal( $( this["id"] ).offset().top, this["top"] + 1, "jQuery('" + this["id"] + "').offset({ top: " + (this["top"] + 1) + ", using: fn })" ); - equal( $( this["id"] ).offset().left, this["left"] + 1, "jQuery('" + this["id"] + "').offset({ left: " + (this["left"] + 1) + ", using: fn })" ); - }); -}); + } ); + } } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ top: " + ( this[ "top" ] + 1 ) + ", using: fn })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ left: " + ( this[ "left" ] + 1 ) + ", using: fn })" ); + } ); +} ); -testIframe("offset/relative", "relative", function( $ ) { - expect(60); +testIframe( "offset/relative", "relative", function( $ ) { + expect( 60 ); var tests; @@ -200,10 +198,9 @@ testIframe("offset/relative", "relative", function( $ ) { { "id": "#relative-2", "top": 142, "left": 27 } ]; jQuery.each( tests, function() { - equal( $( this["id"] ).offset().top, this["top"], "jQuery('" + this["id"] + "').offset().top" ); - equal( $( this["id"] ).offset().left, this["left"], "jQuery('" + this["id"] + "').offset().left" ); - }); - + equal( $( this[ "id" ] ).offset().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').offset().top" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').offset().left" ); + } ); // get position tests = [ @@ -212,10 +209,9 @@ testIframe("offset/relative", "relative", function( $ ) { { "id": "#relative-2", "top": 141, "left": 26 } ]; jQuery.each( tests, function() { - equal( $( this["id"] ).position().top, this["top"], "jQuery('" + this["id"] + "').position().top" ); - equal( $( this["id"] ).position().left, this["left"], "jQuery('" + this["id"] + "').position().left" ); - }); - + equal( $( this[ "id" ] ).position().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').position().top" ); + equal( $( this[ "id" ] ).position().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').position().left" ); + } ); // set offset tests = [ @@ -233,22 +229,22 @@ testIframe("offset/relative", "relative", function( $ ) { { "id": "#relative-1", "top": 7, "left": 7 } ]; jQuery.each( tests, function() { - $( this["id"] ).offset({ "top": this["top"], "left": this["left"] }); - equal( $( this["id"] ).offset().top, this["top"], "jQuery('" + this["id"] + "').offset({ top: " + this["top"] + " })" ); - equal( $( this["id"] ).offset().left, this["left"], "jQuery('" + this["id"] + "').offset({ left: " + this["left"] + " })" ); + $( this[ "id" ] ).offset( { "top": this[ "top" ], "left": this[ "left" ] } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').offset({ top: " + this[ "top" ] + " })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').offset({ left: " + this[ "left" ] + " })" ); - $( this["id"] ).offset({ "top": this["top"], "left": this["left"], "using": function( props ) { - $( this ).css({ + $( this[ "id" ] ).offset( { "top": this[ "top" ], "left": this[ "left" ], "using": function( props ) { + $( this ).css( { "top": props.top + 1, "left": props.left + 1 - }); - }}); - equal( $( this["id"] ).offset().top, this["top"] + 1, "jQuery('" + this["id"] + "').offset({ top: " + (this["top"] + 1) + ", using: fn })" ); - equal( $( this["id"] ).offset().left, this["left"] + 1, "jQuery('" + this["id"] + "').offset({ left: " + (this["left"] + 1) + ", using: fn })" ); - }); -}); - -testIframe("offset/static", "static", function( $ ) { + } ); + } } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ top: " + ( this[ "top" ] + 1 ) + ", using: fn })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ left: " + ( this[ "left" ] + 1 ) + ", using: fn })" ); + } ); +} ); + +testIframe( "offset/static", "static", function( $ ) { expect( 80 ); var tests; @@ -261,10 +257,9 @@ testIframe("offset/static", "static", function( $ ) { { "id": "#static-2", "top": 122, left: 7 } ]; jQuery.each( tests, function() { - equal( $( this["id"] ).offset().top, this["top"], "jQuery('" + this["id"] + "').offset().top" ); - equal( $( this["id"] ).offset().left, this["left"], "jQuery('" + this["id"] + "').offset().left" ); - }); - + equal( $( this[ "id" ] ).offset().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').offset().top" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').offset().left" ); + } ); // get position tests = [ @@ -274,10 +269,9 @@ testIframe("offset/static", "static", function( $ ) { { "id": "#static-2", "top": 121, "left": 6 } ]; jQuery.each( tests, function() { - equal( $( this["id"] ).position().top, this["top"], "jQuery('" + this["top"] + "').position().top" ); - equal( $( this["id"] ).position().left, this["left"], "jQuery('" + this["left"] +"').position().left" ); - }); - + equal( $( this[ "id" ] ).position().top, this[ "top" ], "jQuery('" + this[ "top" ] + "').position().top" ); + equal( $( this[ "id" ] ).position().left, this[ "left" ], "jQuery('" + this[ "left" ] + "').position().left" ); + } ); // set offset tests = [ @@ -299,23 +293,23 @@ testIframe("offset/static", "static", function( $ ) { { "id": "#static-1", "top": 7, "left": 7 } ]; jQuery.each( tests, function() { - $( this["id"] ).offset({ "top": this["top"], "left": this["left"] }); - equal( $( this["id"] ).offset().top, this["top"], "jQuery('" + this["id"] + "').offset({ top: " + this["top"] + " })" ); - equal( $( this["id"] ).offset().left, this["left"], "jQuery('" + this["id"] + "').offset({ left: " + this["left"] + " })" ); + $( this[ "id" ] ).offset( { "top": this[ "top" ], "left": this[ "left" ] } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').offset({ top: " + this[ "top" ] + " })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').offset({ left: " + this[ "left" ] + " })" ); - $( this["id"] ).offset({ "top": this["top"], "left": this["left"], "using": function( props ) { - $( this ).css({ + $( this[ "id" ] ).offset( { "top": this[ "top" ], "left": this[ "left" ], "using": function( props ) { + $( this ).css( { "top": props.top + 1, "left": props.left + 1 - }); - }}); - equal( $( this["id"] ).offset().top, this["top"] + 1, "jQuery('" + this["id"] + "').offset({ top: " + (this["top"] + 1) + ", using: fn })" ); - equal( $( this["id"] ).offset().left, this["left"] + 1, "jQuery('" + this["id"] + "').offset({ left: " + (this["left"] + 1) + ", using: fn })" ); - }); -}); + } ); + } } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ top: " + ( this[ "top" ] + 1 ) + ", using: fn })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ left: " + ( this[ "left" ] + 1 ) + ", using: fn })" ); + } ); +} ); -testIframe("offset/fixed", "fixed", function( $ ) { - expect(34); +testIframe( "offset/fixed", "fixed", function( $ ) { + expect( 34 ); var tests, $noTopLeft; @@ -344,18 +338,19 @@ testIframe("offset/fixed", "fixed", function( $ ) { ok( true, "Browser doesn't support scroll position." ); } else if ( window.supportsFixedPosition ) { - equal( $( this["id"] ).offset().top, this["offsetTop"], "jQuery('" + this["id"] + "').offset().top" ); - equal( $( this["id"] ).position().top, this["positionTop"], "jQuery('" + this["id"] + "').position().top" ); - equal( $( this["id"] ).offset().left, this["offsetLeft"], "jQuery('" + this["id"] + "').offset().left" ); - equal( $( this["id"] ).position().left, this["positionLeft"], "jQuery('" + this["id"] + "').position().left" ); + equal( $( this[ "id" ] ).offset().top, this[ "offsetTop" ], "jQuery('" + this[ "id" ] + "').offset().top" ); + equal( $( this[ "id" ] ).position().top, this[ "positionTop" ], "jQuery('" + this[ "id" ] + "').position().top" ); + equal( $( this[ "id" ] ).offset().left, this[ "offsetLeft" ], "jQuery('" + this[ "id" ] + "').offset().left" ); + equal( $( this[ "id" ] ).position().left, this[ "positionLeft" ], "jQuery('" + this[ "id" ] + "').position().left" ); } else { + // need to have same number of assertions ok( true, "Fixed position is not supported" ); ok( true, "Fixed position is not supported" ); ok( true, "Fixed position is not supported" ); ok( true, "Fixed position is not supported" ); } - }); + } ); tests = [ { "id": "#fixed-1", "top": 100, "left": 100 }, @@ -368,50 +363,52 @@ testIframe("offset/fixed", "fixed", function( $ ) { jQuery.each( tests, function() { if ( window.supportsFixedPosition ) { - $( this["id"] ).offset({ "top": this["top"], "left": this["left"] }); - equal( $( this["id"] ).offset().top, this["top"], "jQuery('" + this["id"] + "').offset({ top: " + this["top"] + " })" ); - equal( $( this["id"] ).offset().left, this["left"], "jQuery('" + this["id"] + "').offset({ left: " + this["left"] + " })" ); + $( this[ "id" ] ).offset( { "top": this[ "top" ], "left": this[ "left" ] } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ], "jQuery('" + this[ "id" ] + "').offset({ top: " + this[ "top" ] + " })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ], "jQuery('" + this[ "id" ] + "').offset({ left: " + this[ "left" ] + " })" ); - $( this["id"] ).offset({ "top": this["top"], "left": this["left"], "using": function( props ) { - $( this ).css({ + $( this[ "id" ] ).offset( { "top": this[ "top" ], "left": this[ "left" ], "using": function( props ) { + $( this ).css( { "top": props.top + 1, "left": props.left + 1 - }); - }}); - equal( $( this["id"] ).offset().top, this["top"] + 1, "jQuery('" + this["id"] + "').offset({ top: " + (this["top"] + 1) + ", using: fn })" ); - equal( $( this["id"] ).offset().left, this["left"] + 1, "jQuery('" + this["id"] + "').offset({ left: " + (this["left"] + 1) + ", using: fn })" ); + } ); + } } ); + equal( $( this[ "id" ] ).offset().top, this[ "top" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ top: " + ( this[ "top" ] + 1 ) + ", using: fn })" ); + equal( $( this[ "id" ] ).offset().left, this[ "left" ] + 1, "jQuery('" + this[ "id" ] + "').offset({ left: " + ( this[ "left" ] + 1 ) + ", using: fn })" ); } else { + // need to have same number of assertions ok( true, "Fixed position is not supported" ); ok( true, "Fixed position is not supported" ); ok( true, "Fixed position is not supported" ); ok( true, "Fixed position is not supported" ); } - }); + } ); // Bug 8316 - $noTopLeft = $("#fixed-no-top-left"); + $noTopLeft = $( "#fixed-no-top-left" ); if ( window.supportsFixedPosition ) { equal( $noTopLeft.offset().top, 1007, "Check offset top for fixed element with no top set" ); equal( $noTopLeft.offset().left, 1007, "Check offset left for fixed element with no left set" ); } else { + // need to have same number of assertions ok( true, "Fixed position is not supported" ); ok( true, "Fixed position is not supported" ); } -}); +} ); -testIframe("offset/table", "table", function( $ ) { - expect(4); +testIframe( "offset/table", "table", function( $ ) { + expect( 4 ); - equal( $("#table-1").offset().top, 6, "jQuery('#table-1').offset().top" ); - equal( $("#table-1").offset().left, 6, "jQuery('#table-1').offset().left" ); + equal( $( "#table-1" ).offset().top, 6, "jQuery('#table-1').offset().top" ); + equal( $( "#table-1" ).offset().left, 6, "jQuery('#table-1').offset().left" ); - equal( $("#th-1").offset().top, 10, "jQuery('#th-1').offset().top" ); - equal( $("#th-1").offset().left, 10, "jQuery('#th-1').offset().left" ); -}); + equal( $( "#th-1" ).offset().top, 10, "jQuery('#th-1').offset().top" ); + equal( $( "#th-1" ).offset().left, 10, "jQuery('#th-1').offset().left" ); +} ); -testIframe("offset/scroll", "scroll", function( $, win ) { +testIframe( "offset/scroll", "scroll", function( $, win ) { expect( 30 ); // If we're going to bastardize the tests, let's just DO it @@ -420,33 +417,33 @@ testIframe("offset/scroll", "scroll", function( $, win ) { if ( ie ) { ok( true, "TestSwarm's iframe has hosed this test in oldIE, we surrender" ); } else { - equal( $("#scroll-1").offset().top, 7, "jQuery('#scroll-1').offset().top" ); + equal( $( "#scroll-1" ).offset().top, 7, "jQuery('#scroll-1').offset().top" ); } - equal( $("#scroll-1").offset().left, 7, "jQuery('#scroll-1').offset().left" ); + equal( $( "#scroll-1" ).offset().left, 7, "jQuery('#scroll-1').offset().left" ); if ( ie ) { ok( true, "TestSwarm's iframe has hosed this test in oldIE, we surrender" ); } else { - equal( $("#scroll-1-1").offset().top, 11, "jQuery('#scroll-1-1').offset().top" ); + equal( $( "#scroll-1-1" ).offset().top, 11, "jQuery('#scroll-1-1').offset().top" ); } - equal( $("#scroll-1-1").offset().left, 11, "jQuery('#scroll-1-1').offset().left" ); + equal( $( "#scroll-1-1" ).offset().left, 11, "jQuery('#scroll-1-1').offset().left" ); // These tests are solely for master/compat consistency // Retrieving offset on disconnected/hidden elements is not officially // valid input, but will return zeros for back-compat - equal( $("#hidden").offset().top, 0, "Hidden elements do not subtract scroll" ); - equal( $("#hidden").offset().left, 0, "Hidden elements do not subtract scroll" ); + equal( $( "#hidden" ).offset().top, 0, "Hidden elements do not subtract scroll" ); + equal( $( "#hidden" ).offset().left, 0, "Hidden elements do not subtract scroll" ); // scroll offset tests .scrollTop/Left - equal( $("#scroll-1").scrollTop(), 5, "jQuery('#scroll-1').scrollTop()" ); - equal( $("#scroll-1").scrollLeft(), 5, "jQuery('#scroll-1').scrollLeft()" ); + equal( $( "#scroll-1" ).scrollTop(), 5, "jQuery('#scroll-1').scrollTop()" ); + equal( $( "#scroll-1" ).scrollLeft(), 5, "jQuery('#scroll-1').scrollLeft()" ); - equal( $("#scroll-1-1").scrollTop(), 0, "jQuery('#scroll-1-1').scrollTop()" ); - equal( $("#scroll-1-1").scrollLeft(), 0, "jQuery('#scroll-1-1').scrollLeft()" ); + equal( $( "#scroll-1-1" ).scrollTop(), 0, "jQuery('#scroll-1-1').scrollTop()" ); + equal( $( "#scroll-1-1" ).scrollLeft(), 0, "jQuery('#scroll-1-1').scrollLeft()" ); // scroll method chaining - equal( $("#scroll-1").scrollTop(undefined).scrollTop(), 5, ".scrollTop(undefined) is chainable (#5571)" ); - equal( $("#scroll-1").scrollLeft(undefined).scrollLeft(), 5, ".scrollLeft(undefined) is chainable (#5571)" ); + equal( $( "#scroll-1" ).scrollTop( undefined ).scrollTop(), 5, ".scrollTop(undefined) is chainable (#5571)" ); + equal( $( "#scroll-1" ).scrollLeft( undefined ).scrollLeft(), 5, ".scrollLeft(undefined) is chainable (#5571)" ); win.name = "test"; @@ -457,113 +454,113 @@ testIframe("offset/scroll", "scroll", function( $, win ) { ok( true, "Browser doesn't support scroll position." ); ok( true, "Browser doesn't support scroll position." ); } else { - equal( $(win).scrollTop(), 1000, "jQuery(window).scrollTop()" ); - equal( $(win).scrollLeft(), 1000, "jQuery(window).scrollLeft()" ); + equal( $( win ).scrollTop(), 1000, "jQuery(window).scrollTop()" ); + equal( $( win ).scrollLeft(), 1000, "jQuery(window).scrollLeft()" ); - equal( $(win.document).scrollTop(), 1000, "jQuery(document).scrollTop()" ); - equal( $(win.document).scrollLeft(), 1000, "jQuery(document).scrollLeft()" ); + equal( $( win.document ).scrollTop(), 1000, "jQuery(document).scrollTop()" ); + equal( $( win.document ).scrollLeft(), 1000, "jQuery(document).scrollLeft()" ); } // test jQuery using parent window/document // jQuery reference here is in the iframe - window.scrollTo(0,0); - equal( $(window).scrollTop(), 0, "jQuery(window).scrollTop() other window" ); - equal( $(window).scrollLeft(), 0, "jQuery(window).scrollLeft() other window" ); - equal( $(document).scrollTop(), 0, "jQuery(window).scrollTop() other document" ); - equal( $(document).scrollLeft(), 0, "jQuery(window).scrollLeft() other document" ); + window.scrollTo( 0, 0 ); + equal( $( window ).scrollTop(), 0, "jQuery(window).scrollTop() other window" ); + equal( $( window ).scrollLeft(), 0, "jQuery(window).scrollLeft() other window" ); + equal( $( document ).scrollTop(), 0, "jQuery(window).scrollTop() other document" ); + equal( $( document ).scrollLeft(), 0, "jQuery(window).scrollLeft() other document" ); // Tests scrollTop/Left with empty jquery objects - notEqual( $().scrollTop(100), null, "jQuery().scrollTop(100) testing setter on empty jquery object" ); - notEqual( $().scrollLeft(100), null, "jQuery().scrollLeft(100) testing setter on empty jquery object" ); - notEqual( $().scrollTop(null), null, "jQuery().scrollTop(null) testing setter on empty jquery object" ); - notEqual( $().scrollLeft(null), null, "jQuery().scrollLeft(null) testing setter on empty jquery object" ); + notEqual( $().scrollTop( 100 ), null, "jQuery().scrollTop(100) testing setter on empty jquery object" ); + notEqual( $().scrollLeft( 100 ), null, "jQuery().scrollLeft(100) testing setter on empty jquery object" ); + notEqual( $().scrollTop( null ), null, "jQuery().scrollTop(null) testing setter on empty jquery object" ); + notEqual( $().scrollLeft( null ), null, "jQuery().scrollLeft(null) testing setter on empty jquery object" ); strictEqual( $().scrollTop(), null, "jQuery().scrollTop(100) testing setter on empty jquery object" ); strictEqual( $().scrollLeft(), null, "jQuery().scrollLeft(100) testing setter on empty jquery object" ); // Tests position after parent scrolling (#15239) - $("#scroll-1").scrollTop(0); - $("#scroll-1").scrollLeft(0); - equal( $("#scroll-1-1").position().top, 6, "jQuery('#scroll-1-1').position().top unaffected by parent scrolling" ); - equal( $("#scroll-1-1").position().left, 6, "jQuery('#scroll-1-1').position().left unaffected by parent scrolling" ); - - $("#scroll-1").scrollTop(5); - $("#scroll-1").scrollLeft(5); - equal( $("#scroll-1-1").position().top, 6, "jQuery('#scroll-1-1').position().top unaffected by parent scrolling" ); - equal( $("#scroll-1-1").position().left, 6, "jQuery('#scroll-1-1').position().left unaffected by parent scrolling" ); -}); - -testIframe("offset/body", "body", function( $ ) { - expect(4); - - equal( $("body").offset().top, 1, "jQuery('#body').offset().top" ); - equal( $("body").offset().left, 1, "jQuery('#body').offset().left" ); - equal( $("#firstElement").position().left, 5, "$('#firstElement').position().left" ); - equal( $("#firstElement").position().top, 5, "$('#firstElement').position().top" ); -}); - -test("chaining", function() { - expect(3); + $( "#scroll-1" ).scrollTop( 0 ); + $( "#scroll-1" ).scrollLeft( 0 ); + equal( $( "#scroll-1-1" ).position().top, 6, "jQuery('#scroll-1-1').position().top unaffected by parent scrolling" ); + equal( $( "#scroll-1-1" ).position().left, 6, "jQuery('#scroll-1-1').position().left unaffected by parent scrolling" ); + + $( "#scroll-1" ).scrollTop( 5 ); + $( "#scroll-1" ).scrollLeft( 5 ); + equal( $( "#scroll-1-1" ).position().top, 6, "jQuery('#scroll-1-1').position().top unaffected by parent scrolling" ); + equal( $( "#scroll-1-1" ).position().left, 6, "jQuery('#scroll-1-1').position().left unaffected by parent scrolling" ); +} ); + +testIframe( "offset/body", "body", function( $ ) { + expect( 4 ); + + equal( $( "body" ).offset().top, 1, "jQuery('#body').offset().top" ); + equal( $( "body" ).offset().left, 1, "jQuery('#body').offset().left" ); + equal( $( "#firstElement" ).position().left, 5, "$('#firstElement').position().left" ); + equal( $( "#firstElement" ).position().top, 5, "$('#firstElement').position().top" ); +} ); + +test( "chaining", function() { + expect( 3 ); var coords = { "top": 1, "left": 1 }; - equal( jQuery("#absolute-1").offset(coords).jquery, jQuery.fn.jquery, "offset(coords) returns jQuery object" ); - equal( jQuery("#non-existent").offset(coords).jquery, jQuery.fn.jquery, "offset(coords) with empty jQuery set returns jQuery object" ); - equal( jQuery("#absolute-1").offset(undefined).jquery, jQuery.fn.jquery, "offset(undefined) returns jQuery object (#5571)" ); -}); + equal( jQuery( "#absolute-1" ).offset( coords ).jquery, jQuery.fn.jquery, "offset(coords) returns jQuery object" ); + equal( jQuery( "#non-existent" ).offset( coords ).jquery, jQuery.fn.jquery, "offset(coords) with empty jQuery set returns jQuery object" ); + equal( jQuery( "#absolute-1" ).offset( undefined ).jquery, jQuery.fn.jquery, "offset(undefined) returns jQuery object (#5571)" ); +} ); -test("offsetParent", function(){ - expect(13); +test( "offsetParent", function() { + expect( 13 ); var body, header, div, area; - body = jQuery("body").offsetParent(); + body = jQuery( "body" ).offsetParent(); equal( body.length, 1, "Only one offsetParent found." ); - equal( body[0], document.documentElement, "The html element is the offsetParent of the body." ); + equal( body[ 0 ], document.documentElement, "The html element is the offsetParent of the body." ); - header = jQuery("#qunit").offsetParent(); + header = jQuery( "#qunit" ).offsetParent(); equal( header.length, 1, "Only one offsetParent found." ); - equal( header[0], document.documentElement, "The html element is the offsetParent of #qunit." ); + equal( header[ 0 ], document.documentElement, "The html element is the offsetParent of #qunit." ); - div = jQuery("#nothiddendivchild").offsetParent(); + div = jQuery( "#nothiddendivchild" ).offsetParent(); equal( div.length, 1, "Only one offsetParent found." ); - equal( div[0], document.getElementById("qunit-fixture"), "The #qunit-fixture is the offsetParent of #nothiddendivchild." ); + equal( div[ 0 ], document.getElementById( "qunit-fixture" ), "The #qunit-fixture is the offsetParent of #nothiddendivchild." ); - jQuery("#nothiddendiv").css("position", "relative"); + jQuery( "#nothiddendiv" ).css( "position", "relative" ); - div = jQuery("#nothiddendivchild").offsetParent(); + div = jQuery( "#nothiddendivchild" ).offsetParent(); equal( div.length, 1, "Only one offsetParent found." ); - equal( div[0], jQuery("#nothiddendiv")[0], "The div is the offsetParent." ); + equal( div[ 0 ], jQuery( "#nothiddendiv" )[ 0 ], "The div is the offsetParent." ); - div = jQuery("body, #nothiddendivchild").offsetParent(); + div = jQuery( "body, #nothiddendivchild" ).offsetParent(); equal( div.length, 2, "Two offsetParent found." ); - equal( div[0], document.documentElement, "The html element is the offsetParent of the body." ); - equal( div[1], jQuery("#nothiddendiv")[0], "The div is the offsetParent." ); + equal( div[ 0 ], document.documentElement, "The html element is the offsetParent of the body." ); + equal( div[ 1 ], jQuery( "#nothiddendiv" )[ 0 ], "The div is the offsetParent." ); - area = jQuery("#imgmap area").offsetParent(); - equal( area[0], document.documentElement, "The html element is the offsetParent of the body." ); + area = jQuery( "#imgmap area" ).offsetParent(); + equal( area[ 0 ], document.documentElement, "The html element is the offsetParent of the body." ); - div = jQuery("<div>").css({ "position": "absolute" }).appendTo("body"); - equal( div.offsetParent()[0], document.documentElement, "Absolutely positioned div returns html as offset parent, see #12139" ); + div = jQuery( "<div>" ).css( { "position": "absolute" } ).appendTo( "body" ); + equal( div.offsetParent()[ 0 ], document.documentElement, "Absolutely positioned div returns html as offset parent, see #12139" ); div.remove(); -}); +} ); -test("fractions (see #7730 and #7885)", function() { - expect(2); +test( "fractions (see #7730 and #7885)", function() { + expect( 2 ); - jQuery("body").append("<div id='fractions'/>"); + jQuery( "body" ).append( "<div id='fractions'/>" ); var result, expected = { "top": 1000, "left": 1000 }, - div = jQuery("#fractions"); + div = jQuery( "#fractions" ); - div.css({ + div.css( { "position": "absolute", "left": "1000.7432222px", "top": "1000.532325px", "width": 100, "height": 100 - }); + } ); - div.offset(expected); + div.offset( expected ); result = div.offset(); @@ -571,9 +568,9 @@ test("fractions (see #7730 and #7885)", function() { equal( result.left, expected.left, "Check left" ); div.remove(); -}); +} ); -test("iframe scrollTop/Left (see gh-1945)", function() { +test( "iframe scrollTop/Left (see gh-1945)", function() { expect( 2 ); var ifDoc = jQuery( "#iframe" )[ 0 ].contentDocument; @@ -588,6 +585,7 @@ test("iframe scrollTop/Left (see gh-1945)", function() { equal( true, true, "Can't scroll iframes in this environment" ); } else { + // Tests scrollTop/Left with iframes jQuery( "#iframe" ).css( "width", "50px" ).css( "height", "50px" ); @@ -604,6 +602,6 @@ test("iframe scrollTop/Left (see gh-1945)", function() { equal( jQuery( ifDoc ).scrollTop(), 200, "$($('#iframe')[0].contentDocument).scrollTop()" ); equal( jQuery( ifDoc ).scrollLeft(), 500, "$($('#iframe')[0].contentDocument).scrollLeft()" ); } -}); +} ); -})(); +} )(); diff --git a/test/unit/queue.js b/test/unit/queue.js index 1aef8b51c..50a630fb4 100644 --- a/test/unit/queue.js +++ b/test/unit/queue.js @@ -1,232 +1,233 @@ -module( "queue", { teardown: moduleTeardown }); +module( "queue", { teardown: moduleTeardown } ); test( "queue() with other types", function() { expect( 14 ); stop(); - var $div = jQuery({}), + var $div = jQuery( {} ), counter = 0; - $div.promise( "foo" ).done(function() { + $div.promise( "foo" ).done( function() { equal( counter, 0, "Deferred for collection with no queue is automatically resolved" ); - }); + } ); $div - .queue("foo",function(){ + .queue( "foo", function() { equal( ++counter, 1, "Dequeuing" ); - jQuery.dequeue(this,"foo"); - }) - .queue("foo",function(){ + jQuery.dequeue( this, "foo" ); + } ) + .queue( "foo", function() { equal( ++counter, 2, "Dequeuing" ); - jQuery(this).dequeue("foo"); - }) - .queue("foo",function(){ + jQuery( this ).dequeue( "foo" ); + } ) + .queue( "foo", function() { equal( ++counter, 3, "Dequeuing" ); - }) - .queue("foo",function(){ + } ) + .queue( "foo", function() { equal( ++counter, 4, "Dequeuing" ); - }); + } ); - $div.promise("foo").done(function() { + $div.promise( "foo" ).done( function() { equal( counter, 4, "Testing previous call to dequeue in deferred" ); start(); - }); + } ); - equal( $div.queue("foo").length, 4, "Testing queue length" ); + equal( $div.queue( "foo" ).length, 4, "Testing queue length" ); - equal( $div.queue("foo", undefined).queue("foo").length, 4, ".queue('name',undefined) does nothing but is chainable (#5571)"); + equal( $div.queue( "foo", undefined ).queue( "foo" ).length, 4, ".queue('name',undefined) does nothing but is chainable (#5571)" ); - $div.dequeue("foo"); + $div.dequeue( "foo" ); equal( counter, 3, "Testing previous call to dequeue" ); - equal( $div.queue("foo").length, 1, "Testing queue length" ); + equal( $div.queue( "foo" ).length, 1, "Testing queue length" ); - $div.dequeue("foo"); + $div.dequeue( "foo" ); equal( counter, 4, "Testing previous call to dequeue" ); - equal( $div.queue("foo").length, 0, "Testing queue length" ); + equal( $div.queue( "foo" ).length, 0, "Testing queue length" ); - $div.dequeue("foo"); + $div.dequeue( "foo" ); equal( counter, 4, "Testing previous call to dequeue" ); - equal( $div.queue("foo").length, 0, "Testing queue length" ); + equal( $div.queue( "foo" ).length, 0, "Testing queue length" ); -}); +} ); -test("queue(name) passes in the next item in the queue as a parameter", function() { - expect(2); +test( "queue(name) passes in the next item in the queue as a parameter", function() { + expect( 2 ); - var div = jQuery({}), + var div = jQuery( {} ), counter = 0; - div.queue("foo", function(next) { - equal(++counter, 1, "Dequeueing"); + div.queue( "foo", function( next ) { + equal( ++counter, 1, "Dequeueing" ); next(); - }).queue("foo", function(next) { - equal(++counter, 2, "Next was called"); + } ).queue( "foo", function( next ) { + equal( ++counter, 2, "Next was called" ); next(); - }).queue("bar", function() { - equal(++counter, 3, "Other queues are not triggered by next()"); - }); + } ).queue( "bar", function() { + equal( ++counter, 3, "Other queues are not triggered by next()" ); + } ); - div.dequeue("foo"); -}); + div.dequeue( "foo" ); +} ); -test("queue() passes in the next item in the queue as a parameter to fx queues", function() { - expect(3); +test( "queue() passes in the next item in the queue as a parameter to fx queues", function() { + expect( 3 ); stop(); - var div = jQuery({}), + var div = jQuery( {} ), counter = 0; - div.queue(function( next ) { - equal(++counter, 1, "Dequeueing"); - setTimeout(function() { next(); }, 500); - }).queue(function(next) { - equal(++counter, 2, "Next was called"); + div.queue( function( next ) { + equal( ++counter, 1, "Dequeueing" ); + setTimeout( function() { next(); }, 500 ); + } ).queue( function( next ) { + equal( ++counter, 2, "Next was called" ); next(); - }).queue("bar", function() { - equal(++counter, 3, "Other queues are not triggered by next()"); - }); + } ).queue( "bar", function() { + equal( ++counter, 3, "Other queues are not triggered by next()" ); + } ); - jQuery.when( div.promise("fx"), div ).done(function() { - equal(counter, 2, "Deferreds resolved"); + jQuery.when( div.promise( "fx" ), div ).done( function() { + equal( counter, 2, "Deferreds resolved" ); start(); - }); -}); + } ); +} ); -test("callbacks keep their place in the queue", function() { - expect(5); +test( "callbacks keep their place in the queue", function() { + expect( 5 ); stop(); - var div = jQuery("<div>"), + var div = jQuery( "<div>" ), counter = 0; - div.queue(function( next ) { + div.queue( function( next ) { equal( ++counter, 1, "Queue/callback order: first called" ); setTimeout( next, 200 ); - }).delay( 100 ).queue(function( next ) { + } ).delay( 100 ).queue( function( next ) { equal( ++counter, 2, "Queue/callback order: second called" ); - jQuery( this ).delay( 100 ).queue(function( next ) { + jQuery( this ).delay( 100 ).queue( function( next ) { equal( ++counter, 4, "Queue/callback order: fourth called" ); next(); - }); + } ); next(); - }).queue(function( next ) { + } ).queue( function( next ) { equal( ++counter, 3, "Queue/callback order: third called" ); next(); - }); + } ); - div.promise("fx").done(function() { - equal(counter, 4, "Deferreds resolved"); + div.promise( "fx" ).done( function() { + equal( counter, 4, "Deferreds resolved" ); start(); - }); -}); + } ); +} ); -test("delay()", function() { - expect(2); +test( "delay()", function() { + expect( 2 ); stop(); - var foo = jQuery({}), run = 0; + var foo = jQuery( {} ), run = 0; - foo.delay(100).queue(function(){ + foo.delay( 100 ).queue( function() { run = 1; ok( true, "The function was dequeued." ); start(); - }); + } ); equal( run, 0, "The delay delayed the next function from running." ); -}); +} ); -test("clearQueue(name) clears the queue", function() { - expect(2); +test( "clearQueue(name) clears the queue", function() { + expect( 2 ); stop(); - var div = jQuery({}), + var div = jQuery( {} ), counter = 0; - div.queue("foo", function( next ) { + div.queue( "foo", function( next ) { counter++; - jQuery(this).clearQueue("foo"); + jQuery( this ).clearQueue( "foo" ); next(); - }).queue("foo", function() { + } ).queue( "foo", function() { counter++; - }); + } ); - div.promise("foo").done(function() { + div.promise( "foo" ).done( function() { ok( true, "dequeue resolves the deferred" ); start(); - }); + } ); - div.dequeue("foo"); + div.dequeue( "foo" ); - equal(counter, 1, "the queue was cleared"); -}); + equal( counter, 1, "the queue was cleared" ); +} ); -test("clearQueue() clears the fx queue", function() { - expect(1); +test( "clearQueue() clears the fx queue", function() { + expect( 1 ); - var div = jQuery({}), + var div = jQuery( {} ), counter = 0; - div.queue(function( next ) { + div.queue( function( next ) { counter++; var self = this; - setTimeout(function() { jQuery(self).clearQueue(); next(); }, 50); - }).queue(function() { + setTimeout( function() { jQuery( self ).clearQueue(); next(); }, 50 ); + } ).queue( function() { counter++; - }); + } ); - equal(counter, 1, "the queue was cleared"); + equal( counter, 1, "the queue was cleared" ); div.removeData(); -}); +} ); asyncTest( "fn.promise() - called when fx queue is empty", 3, function() { var foo = jQuery( "#foo" ).clone().addBack(), promised = false; foo.queue( function( next ) { + // called twice! ok( !promised, "Promised hasn't been called" ); setTimeout( next, 10 ); - }); + } ); foo.promise().done( function() { ok( promised = true, "Promised" ); start(); - }); -}); + } ); +} ); asyncTest( "fn.promise( \"queue\" ) - called whenever last queue function is dequeued", 5, function() { var foo = jQuery( "#foo" ), test; foo.promise( "queue" ).done( function() { strictEqual( test, undefined, "called immediately when queue was already empty" ); - }); + } ); test = 1; foo.queue( "queue", function( next ) { strictEqual( test++, 1, "step one" ); setTimeout( next, 0 ); - }).queue( "queue", function( next ) { + } ).queue( "queue", function( next ) { strictEqual( test++, 2, "step two" ); setTimeout( function() { next(); strictEqual( test++, 4, "step four" ); start(); }, 10 ); - }).promise( "queue" ).done( function() { + } ).promise( "queue" ).done( function() { strictEqual( test++, 3, "step three" ); - }); + } ); foo.dequeue( "queue" ); -}); +} ); asyncTest( "fn.promise( \"queue\" ) - waits for animation to complete before resolving", 2, function() { var foo = jQuery( "#foo" ), test = 1; - foo.animate({ + foo.animate( { top: 100 }, { duration: 1, @@ -234,43 +235,42 @@ asyncTest( "fn.promise( \"queue\" ) - waits for animation to complete before res complete: function() { strictEqual( test++, 1, "step one" ); } - }).dequeue( "queue" ); + } ).dequeue( "queue" ); foo.promise( "queue" ).done( function() { strictEqual( test++, 2, "step two" ); start(); - }); + } ); -}); +} ); test( ".promise(obj)", function() { - expect(2); + expect( 2 ); var obj = {}, promise = jQuery( "#foo" ).promise( "promise", obj ); ok( jQuery.isFunction( promise.promise ), ".promise(type, obj) returns a promise" ); strictEqual( promise, obj, ".promise(type, obj) returns obj" ); -}); - +} ); if ( jQuery.fn.stop ) { - test("delay() can be stopped", function() { + test( "delay() can be stopped", function() { expect( 3 ); stop(); var done = {}; - jQuery({}) + jQuery( {} ) .queue( "alternate", function( next ) { done.alt1 = true; ok( true, "This first function was dequeued" ); next(); - }) + } ) .delay( 1000, "alternate" ) .queue( "alternate", function() { done.alt2 = true; ok( true, "The function was dequeued immediately, the delay was stopped" ); - }) + } ) .dequeue( "alternate" ) // stop( "alternate", false ) will NOT clear the queue, so it should automatically dequeue the next @@ -278,20 +278,20 @@ if ( jQuery.fn.stop ) { // this test .delay( 1 ) - .queue(function() { + .queue( function() { done.default1 = true; ok( false, "This queue should never run" ); - }) + } ) // stop( clearQueue ) should clear the queue .stop( true, false ); deepEqual( done, { alt1: true, alt2: true }, "Queue ran the proper functions" ); - setTimeout(function() { + setTimeout( function() { start(); }, 1500 ); - }); + } ); asyncTest( "queue stop hooks", 2, function() { var foo = jQuery( "#foo" ); @@ -300,7 +300,7 @@ if ( jQuery.fn.stop ) { hooks.stop = function( gotoEnd ) { equal( !!gotoEnd, false, "Stopped without gotoEnd" ); }; - }); + } ); foo.stop(); foo.queue( function( next, hooks ) { @@ -308,9 +308,9 @@ if ( jQuery.fn.stop ) { equal( gotoEnd, true, "Stopped with gotoEnd" ); start(); }; - }); + } ); foo.stop( false, true ); - }); + } ); } // if ( jQuery.fn.stop ) diff --git a/test/unit/ready.js b/test/unit/ready.js index 27d451936..ee39dec9d 100644 --- a/test/unit/ready.js +++ b/test/unit/ready.js @@ -1,6 +1,6 @@ module( "event" ); -(function() { +( function() { var notYetReady, noEarlyExecution, order = [], args = {}; @@ -12,7 +12,7 @@ module( "event" ); equal( notYetReady, true, "jQuery.isReady should not be true before DOM ready" ); equal( jQuery.isReady, true, "jQuery.isReady should be true once DOM is ready" ); - }); + } ); // Create an event handler. function makeHandler( testId ) { @@ -22,7 +22,7 @@ module( "event" ); // the correct arg is being passed into the event handler. return function( arg ) { order.push( testId ); - args[testId] = arg; + args[ testId ] = arg; }; } @@ -65,6 +65,6 @@ module( "event" ); equal( order.pop(), "h", "Event handler should execute immediately" ); equal( args.h, jQuery, "Argument passed to fn in jQuery(document).ready( fn ) should be jQuery" ); - }); + } ); -})(); +} )(); diff --git a/test/unit/selector.js b/test/unit/selector.js index c290df017..c9afeb0dc 100644 --- a/test/unit/selector.js +++ b/test/unit/selector.js @@ -1,93 +1,93 @@ -module("selector", { teardown: moduleTeardown }); +module( "selector", { teardown: moduleTeardown } ); /** * This test page is for selector tests that require jQuery in order to do the selection */ -test("element - jQuery only", function() { +test( "element - jQuery only", function() { expect( 7 ); - var fixture = document.getElementById("qunit-fixture"); + var fixture = document.getElementById( "qunit-fixture" ); - deepEqual( jQuery("p", fixture).get(), q("firstp","ap","sndp","en","sap","first"), "Finding elements with a Node context." ); - deepEqual( jQuery("p", "#qunit-fixture").get(), q("firstp","ap","sndp","en","sap","first"), "Finding elements with a selector context." ); - deepEqual( jQuery("p", jQuery("#qunit-fixture")).get(), q("firstp","ap","sndp","en","sap","first"), "Finding elements with a jQuery object context." ); - deepEqual( jQuery("#qunit-fixture").find("p").get(), q("firstp","ap","sndp","en","sap","first"), "Finding elements with a context via .find()." ); + deepEqual( jQuery( "p", fixture ).get(), q( "firstp", "ap", "sndp", "en", "sap", "first" ), "Finding elements with a Node context." ); + deepEqual( jQuery( "p", "#qunit-fixture" ).get(), q( "firstp", "ap", "sndp", "en", "sap", "first" ), "Finding elements with a selector context." ); + deepEqual( jQuery( "p", jQuery( "#qunit-fixture" ) ).get(), q( "firstp", "ap", "sndp", "en", "sap", "first" ), "Finding elements with a jQuery object context." ); + deepEqual( jQuery( "#qunit-fixture" ).find( "p" ).get(), q( "firstp", "ap", "sndp", "en", "sap", "first" ), "Finding elements with a context via .find()." ); - ok( jQuery("#length").length, "<input name=\"length\"> cannot be found under IE, see #945" ); - ok( jQuery("#lengthtest input").length, "<input name=\"length\"> cannot be found under IE, see #945" ); + ok( jQuery( "#length" ).length, "<input name=\"length\"> cannot be found under IE, see #945" ); + ok( jQuery( "#lengthtest input" ).length, "<input name=\"length\"> cannot be found under IE, see #945" ); // #7533 - equal( jQuery("<div id=\"A'B~C.D[E]\"><p>foo</p></div>").find("p").length, 1, "Find where context root is a node and has an ID with CSS3 meta characters" ); -}); + equal( jQuery( "<div id=\"A'B~C.D[E]\"><p>foo</p></div>" ).find( "p" ).length, 1, "Find where context root is a node and has an ID with CSS3 meta characters" ); +} ); -test("id", function() { +test( "id", function() { expect( 26 ); var a; - t( "ID Selector", "#body", ["body"] ); - t( "ID Selector w/ Element", "body#body", ["body"] ); + t( "ID Selector", "#body", [ "body" ] ); + t( "ID Selector w/ Element", "body#body", [ "body" ] ); t( "ID Selector w/ Element", "ul#first", [] ); - t( "ID selector with existing ID descendant", "#firstp #simon1", ["simon1"] ); + t( "ID selector with existing ID descendant", "#firstp #simon1", [ "simon1" ] ); t( "ID selector with non-existant descendant", "#firstp #foobar", [] ); - t( "ID selector using UTF8", "#台北Táiběi", ["台北Táiběi"] ); - t( "Multiple ID selectors using UTF8", "#台北Táiběi, #台北", ["台北Táiběi","台北"] ); - t( "Descendant ID selector using UTF8", "div #台北", ["台北"] ); - t( "Child ID selector using UTF8", "form > #台北", ["台北"] ); - - t( "Escaped ID", "#foo\\:bar", ["foo:bar"] ); - t( "Escaped ID", "#test\\.foo\\[5\\]bar", ["test.foo[5]bar"] ); - t( "Descendant escaped ID", "div #foo\\:bar", ["foo:bar"] ); - t( "Descendant escaped ID", "div #test\\.foo\\[5\\]bar", ["test.foo[5]bar"] ); - t( "Child escaped ID", "form > #foo\\:bar", ["foo:bar"] ); - t( "Child escaped ID", "form > #test\\.foo\\[5\\]bar", ["test.foo[5]bar"] ); - - t( "ID Selector, child ID present", "#form > #radio1", ["radio1"] ); // bug #267 + t( "ID selector using UTF8", "#台北Táiběi", [ "台北Táiběi" ] ); + t( "Multiple ID selectors using UTF8", "#台北Táiběi, #台北", [ "台北Táiběi","台北" ] ); + t( "Descendant ID selector using UTF8", "div #台北", [ "台北" ] ); + t( "Child ID selector using UTF8", "form > #台北", [ "台北" ] ); + + t( "Escaped ID", "#foo\\:bar", [ "foo:bar" ] ); + t( "Escaped ID", "#test\\.foo\\[5\\]bar", [ "test.foo[5]bar" ] ); + t( "Descendant escaped ID", "div #foo\\:bar", [ "foo:bar" ] ); + t( "Descendant escaped ID", "div #test\\.foo\\[5\\]bar", [ "test.foo[5]bar" ] ); + t( "Child escaped ID", "form > #foo\\:bar", [ "foo:bar" ] ); + t( "Child escaped ID", "form > #test\\.foo\\[5\\]bar", [ "test.foo[5]bar" ] ); + + t( "ID Selector, child ID present", "#form > #radio1", [ "radio1" ] ); // bug #267 t( "ID Selector, not an ancestor ID", "#form #first", [] ); t( "ID Selector, not a child ID", "#form > #option1a", [] ); - t( "All Children of ID", "#foo > *", ["sndp", "en", "sap"] ); + t( "All Children of ID", "#foo > *", [ "sndp", "en", "sap" ] ); t( "All Children of ID with no children", "#firstUL > *", [] ); - a = jQuery("<a id='backslash\\foo'></a>").appendTo("#qunit-fixture"); - t( "ID Selector contains backslash", "#backslash\\\\foo", ["backslash\\foo"] ); + a = jQuery( "<a id='backslash\\foo'></a>" ).appendTo( "#qunit-fixture" ); + t( "ID Selector contains backslash", "#backslash\\\\foo", [ "backslash\\foo" ] ); - t( "ID Selector on Form with an input that has a name of 'id'", "#lengthtest", ["lengthtest"] ); + t( "ID Selector on Form with an input that has a name of 'id'", "#lengthtest", [ "lengthtest" ] ); t( "ID selector with non-existant ancestor", "#asdfasdf #foobar", [] ); // bug #986 - t( "Underscore ID", "#types_all", ["types_all"] ); - t( "Dash ID", "#qunit-fixture", ["qunit-fixture"] ); + t( "Underscore ID", "#types_all", [ "types_all" ] ); + t( "Dash ID", "#qunit-fixture", [ "qunit-fixture" ] ); - t( "ID with weird characters in it", "#name\\+value", ["name+value"] ); -}); + t( "ID with weird characters in it", "#name\\+value", [ "name+value" ] ); +} ); -test("class - jQuery only", function() { +test( "class - jQuery only", function() { expect( 4 ); - deepEqual( jQuery(".blog", document.getElementsByTagName("p")).get(), q("mark", "simon"), "Finding elements with a context." ); - deepEqual( jQuery(".blog", "p").get(), q("mark", "simon"), "Finding elements with a context." ); - deepEqual( jQuery(".blog", jQuery("p")).get(), q("mark", "simon"), "Finding elements with a context." ); - deepEqual( jQuery("p").find(".blog").get(), q("mark", "simon"), "Finding elements with a context." ); -}); + deepEqual( jQuery( ".blog", document.getElementsByTagName( "p" ) ).get(), q( "mark", "simon" ), "Finding elements with a context." ); + deepEqual( jQuery( ".blog", "p" ).get(), q( "mark", "simon" ), "Finding elements with a context." ); + deepEqual( jQuery( ".blog", jQuery( "p" ) ).get(), q( "mark", "simon" ), "Finding elements with a context." ); + deepEqual( jQuery( "p" ).find( ".blog" ).get(), q( "mark", "simon" ), "Finding elements with a context." ); +} ); -test("name", function() { +test( "name", function() { expect( 5 ); var form; - t( "Name selector", "input[name=action]", ["text1"] ); - t( "Name selector with single quotes", "input[name='action']", ["text1"] ); - t( "Name selector with double quotes", "input[name=\"action\"]", ["text1"] ); + t( "Name selector", "input[name=action]", [ "text1" ] ); + t( "Name selector with single quotes", "input[name='action']", [ "text1" ] ); + t( "Name selector with double quotes", "input[name=\"action\"]", [ "text1" ] ); - t( "Name selector for grouped input", "input[name='types[]']", ["types_all", "types_anime", "types_movie"] ); + t( "Name selector for grouped input", "input[name='types[]']", [ "types_all", "types_anime", "types_movie" ] ); - form = jQuery("<form><input name='id'/></form>").appendTo("body"); - equal( jQuery("input", form[0]).length, 1, "Make sure that rooted queries on forms (with possible expandos) work." ); + form = jQuery( "<form><input name='id'/></form>" ).appendTo( "body" ); + equal( jQuery( "input", form[ 0 ] ).length, 1, "Make sure that rooted queries on forms (with possible expandos) work." ); form.remove(); -}); +} ); test( "selectors with comma", function() { expect( 4 ); @@ -98,108 +98,108 @@ test( "selectors with comma", function() { equal( fixture.find( "h2, div p" ).filter( "h2" ).length, 1, "has to find one <h2>" ); equal( fixture.find( "h2 , div p" ).filter( "p" ).length, 2, "has to find two <p>" ); equal( fixture.find( "h2 , div p" ).filter( "h2" ).length, 1, "has to find one <h2>" ); -}); +} ); test( "child and adjacent", function() { expect( 27 ); var nothiddendiv; - t( "Child", "p > a", ["simon1","google","groups","mark","yahoo","simon"] ); - t( "Child", "p> a", ["simon1","google","groups","mark","yahoo","simon"] ); - t( "Child", "p >a", ["simon1","google","groups","mark","yahoo","simon"] ); - t( "Child", "p>a", ["simon1","google","groups","mark","yahoo","simon"] ); - t( "Child w/ Class", "p > a.blog", ["mark","simon"] ); - t( "All Children", "code > *", ["anchor1","anchor2"] ); - t( "All Grandchildren", "p > * > *", ["anchor1","anchor2"] ); - t( "Adjacent", "p + p", ["ap","en","sap"] ); - t( "Adjacent", "p#firstp + p", ["ap"] ); - t( "Adjacent", "p[lang=en] + p", ["sap"] ); - t( "Adjacent", "a.GROUPS + code + a", ["mark"] ); - t( "Element Preceded By", "#groups ~ a", ["mark"] ); - t( "Element Preceded By", "#length ~ input", ["idTest"] ); - t( "Element Preceded By", "#siblingfirst ~ em", ["siblingnext", "siblingthird"] ); - t( "Element Preceded By (multiple)", "#siblingTest em ~ em ~ em ~ span", ["siblingspan"] ); - t( "Element Preceded By, Containing", "#liveHandlerOrder ~ div em:contains('1')", ["siblingfirst"] ); - - t( "Multiple combinators selects all levels", "#siblingTest em *", ["siblingchild", "siblinggrandchild", "siblinggreatgrandchild"] ); - t( "Multiple combinators selects all levels", "#siblingTest > em *", ["siblingchild", "siblinggrandchild", "siblinggreatgrandchild"] ); - t( "Multiple sibling combinators doesn't miss general siblings", "#siblingTest > em:first-child + em ~ span", ["siblingspan"] ); + t( "Child", "p > a", [ "simon1","google","groups","mark","yahoo","simon" ] ); + t( "Child", "p> a", [ "simon1","google","groups","mark","yahoo","simon" ] ); + t( "Child", "p >a", [ "simon1","google","groups","mark","yahoo","simon" ] ); + t( "Child", "p>a", [ "simon1","google","groups","mark","yahoo","simon" ] ); + t( "Child w/ Class", "p > a.blog", [ "mark","simon" ] ); + t( "All Children", "code > *", [ "anchor1","anchor2" ] ); + t( "All Grandchildren", "p > * > *", [ "anchor1","anchor2" ] ); + t( "Adjacent", "p + p", [ "ap","en","sap" ] ); + t( "Adjacent", "p#firstp + p", [ "ap" ] ); + t( "Adjacent", "p[lang=en] + p", [ "sap" ] ); + t( "Adjacent", "a.GROUPS + code + a", [ "mark" ] ); + t( "Element Preceded By", "#groups ~ a", [ "mark" ] ); + t( "Element Preceded By", "#length ~ input", [ "idTest" ] ); + t( "Element Preceded By", "#siblingfirst ~ em", [ "siblingnext", "siblingthird" ] ); + t( "Element Preceded By (multiple)", "#siblingTest em ~ em ~ em ~ span", [ "siblingspan" ] ); + t( "Element Preceded By, Containing", "#liveHandlerOrder ~ div em:contains('1')", [ "siblingfirst" ] ); + + t( "Multiple combinators selects all levels", "#siblingTest em *", [ "siblingchild", "siblinggrandchild", "siblinggreatgrandchild" ] ); + t( "Multiple combinators selects all levels", "#siblingTest > em *", [ "siblingchild", "siblinggrandchild", "siblinggreatgrandchild" ] ); + t( "Multiple sibling combinators doesn't miss general siblings", "#siblingTest > em:first-child + em ~ span", [ "siblingspan" ] ); t( "Combinators are not skipped when mixing general and specific", "#siblingTest > em:contains('x') + em ~ span", [] ); - equal( jQuery("#listWithTabIndex").length, 1, "Parent div for next test is found via ID (#8310)" ); - equal( jQuery("#listWithTabIndex li:eq(2) ~ li").length, 1, "Find by general sibling combinator (#8310)" ); - equal( jQuery("#__sizzle__").length, 0, "Make sure the temporary id assigned by sizzle is cleared out (#8310)" ); - equal( jQuery("#listWithTabIndex").length, 1, "Parent div for previous test is still found via ID (#8310)" ); + equal( jQuery( "#listWithTabIndex" ).length, 1, "Parent div for next test is found via ID (#8310)" ); + equal( jQuery( "#listWithTabIndex li:eq(2) ~ li" ).length, 1, "Find by general sibling combinator (#8310)" ); + equal( jQuery( "#__sizzle__" ).length, 0, "Make sure the temporary id assigned by sizzle is cleared out (#8310)" ); + equal( jQuery( "#listWithTabIndex" ).length, 1, "Parent div for previous test is still found via ID (#8310)" ); t( "Verify deep class selector", "div.blah > p > a", [] ); t( "No element deep selector", "div.foo > span > a", [] ); - nothiddendiv = document.getElementById("nothiddendiv"); + nothiddendiv = document.getElementById( "nothiddendiv" ); t( "Non-existant ancestors", ".fototab > .thumbnails > a", [] ); -}); +} ); -test("attributes", function() { +test( "attributes", function() { expect( 54 ); var attrbad, div, withScript; - t( "Find elements with a tabindex attribute", "[tabindex]", ["listWithTabIndex", "foodWithNegativeTabIndex", "linkWithTabIndex", "linkWithNegativeTabIndex", "linkWithNoHrefWithTabIndex", "linkWithNoHrefWithNegativeTabIndex"] ); + t( "Find elements with a tabindex attribute", "[tabindex]", [ "listWithTabIndex", "foodWithNegativeTabIndex", "linkWithTabIndex", "linkWithNegativeTabIndex", "linkWithNoHrefWithTabIndex", "linkWithNoHrefWithNegativeTabIndex" ] ); - t( "Attribute Exists", "#qunit-fixture a[title]", ["google"] ); - t( "Attribute Exists (case-insensitive)", "#qunit-fixture a[TITLE]", ["google"] ); - t( "Attribute Exists", "#qunit-fixture *[title]", ["google"] ); - t( "Attribute Exists", "#qunit-fixture [title]", ["google"] ); - t( "Attribute Exists", "#qunit-fixture a[ title ]", ["google"] ); + t( "Attribute Exists", "#qunit-fixture a[title]", [ "google" ] ); + t( "Attribute Exists (case-insensitive)", "#qunit-fixture a[TITLE]", [ "google" ] ); + t( "Attribute Exists", "#qunit-fixture *[title]", [ "google" ] ); + t( "Attribute Exists", "#qunit-fixture [title]", [ "google" ] ); + t( "Attribute Exists", "#qunit-fixture a[ title ]", [ "google" ] ); - t( "Boolean attribute exists", "#select2 option[selected]", ["option2d"]); - t( "Boolean attribute equals", "#select2 option[selected='selected']", ["option2d"]); + t( "Boolean attribute exists", "#select2 option[selected]", [ "option2d" ] ); + t( "Boolean attribute equals", "#select2 option[selected='selected']", [ "option2d" ] ); - t( "Attribute Equals", "#qunit-fixture a[rel='bookmark']", ["simon1"] ); - t( "Attribute Equals", "#qunit-fixture a[rel='bookmark']", ["simon1"] ); - t( "Attribute Equals", "#qunit-fixture a[rel=bookmark]", ["simon1"] ); - t( "Attribute Equals", "#qunit-fixture a[href='http://www.google.com/']", ["google"] ); - t( "Attribute Equals", "#qunit-fixture a[ rel = 'bookmark' ]", ["simon1"] ); - t( "Attribute Equals Number", "#qunit-fixture option[value=1]", ["option1b","option2b","option3b","option4b","option5c"] ); - t( "Attribute Equals Number", "#qunit-fixture li[tabIndex=-1]", ["foodWithNegativeTabIndex"] ); + t( "Attribute Equals", "#qunit-fixture a[rel='bookmark']", [ "simon1" ] ); + t( "Attribute Equals", "#qunit-fixture a[rel='bookmark']", [ "simon1" ] ); + t( "Attribute Equals", "#qunit-fixture a[rel=bookmark]", [ "simon1" ] ); + t( "Attribute Equals", "#qunit-fixture a[href='http://www.google.com/']", [ "google" ] ); + t( "Attribute Equals", "#qunit-fixture a[ rel = 'bookmark' ]", [ "simon1" ] ); + t( "Attribute Equals Number", "#qunit-fixture option[value=1]", [ "option1b","option2b","option3b","option4b","option5c" ] ); + t( "Attribute Equals Number", "#qunit-fixture li[tabIndex=-1]", [ "foodWithNegativeTabIndex" ] ); - document.getElementById("anchor2").href = "#2"; - t( "href Attribute", "p a[href^='#']", ["anchor2"] ); - t( "href Attribute", "p a[href*='#']", ["simon1", "anchor2"] ); + document.getElementById( "anchor2" ).href = "#2"; + t( "href Attribute", "p a[href^='#']", [ "anchor2" ] ); + t( "href Attribute", "p a[href*='#']", [ "simon1", "anchor2" ] ); - t( "for Attribute", "form label[for]", ["label-for"] ); - t( "for Attribute in form", "#form [for=action]", ["label-for"] ); + t( "for Attribute", "form label[for]", [ "label-for" ] ); + t( "for Attribute in form", "#form [for=action]", [ "label-for" ] ); - t( "Attribute containing []", "input[name^='foo[']", ["hidden2"] ); - t( "Attribute containing []", "input[name^='foo[bar]']", ["hidden2"] ); - t( "Attribute containing []", "input[name*='[bar]']", ["hidden2"] ); - t( "Attribute containing []", "input[name$='bar]']", ["hidden2"] ); - t( "Attribute containing []", "input[name$='[bar]']", ["hidden2"] ); - t( "Attribute containing []", "input[name$='foo[bar]']", ["hidden2"] ); - t( "Attribute containing []", "input[name*='foo[bar]']", ["hidden2"] ); + t( "Attribute containing []", "input[name^='foo[']", [ "hidden2" ] ); + t( "Attribute containing []", "input[name^='foo[bar]']", [ "hidden2" ] ); + t( "Attribute containing []", "input[name*='[bar]']", [ "hidden2" ] ); + t( "Attribute containing []", "input[name$='bar]']", [ "hidden2" ] ); + t( "Attribute containing []", "input[name$='[bar]']", [ "hidden2" ] ); + t( "Attribute containing []", "input[name$='foo[bar]']", [ "hidden2" ] ); + t( "Attribute containing []", "input[name*='foo[bar]']", [ "hidden2" ] ); - t( "Multiple Attribute Equals", "#form input[type='radio'], #form input[type='hidden']", ["radio1", "radio2", "hidden1"] ); - t( "Multiple Attribute Equals", "#form input[type='radio'], #form input[type=\"hidden\"]", ["radio1", "radio2", "hidden1"] ); - t( "Multiple Attribute Equals", "#form input[type='radio'], #form input[type=hidden]", ["radio1", "radio2", "hidden1"] ); + t( "Multiple Attribute Equals", "#form input[type='radio'], #form input[type='hidden']", [ "radio1", "radio2", "hidden1" ] ); + t( "Multiple Attribute Equals", "#form input[type='radio'], #form input[type=\"hidden\"]", [ "radio1", "radio2", "hidden1" ] ); + t( "Multiple Attribute Equals", "#form input[type='radio'], #form input[type=hidden]", [ "radio1", "radio2", "hidden1" ] ); - t( "Attribute selector using UTF8", "span[lang=中文]", ["台北"] ); + t( "Attribute selector using UTF8", "span[lang=中文]", [ "台北" ] ); - t( "Attribute Begins With", "a[href ^= 'http://www']", ["google","yahoo"] ); - t( "Attribute Ends With", "a[href $= 'org/']", ["mark"] ); - t( "Attribute Contains", "a[href *= 'google']", ["google","groups"] ); - t( "Attribute Is Not Equal", "#ap a[hreflang!='en']", ["google","groups","anchor1"] ); + t( "Attribute Begins With", "a[href ^= 'http://www']", [ "google","yahoo" ] ); + t( "Attribute Ends With", "a[href $= 'org/']", [ "mark" ] ); + t( "Attribute Contains", "a[href *= 'google']", [ "google","groups" ] ); + t( "Attribute Is Not Equal", "#ap a[hreflang!='en']", [ "google","groups","anchor1" ] ); - t( "Empty values", "#select1 option[value='']", ["option1a"] ); - t( "Empty values", "#select1 option[value!='']", ["option1b","option1c","option1d"] ); + t( "Empty values", "#select1 option[value='']", [ "option1a" ] ); + t( "Empty values", "#select1 option[value!='']", [ "option1b","option1c","option1d" ] ); - t( "Select options via :selected", "#select1 option:selected", ["option1a"] ); - t( "Select options via :selected", "#select2 option:selected", ["option2d"] ); - t( "Select options via :selected", "#select3 option:selected", ["option3b", "option3c"] ); - t( "Select options via :selected", "select[name='select2'] option:selected", ["option2d"] ); + t( "Select options via :selected", "#select1 option:selected", [ "option1a" ] ); + t( "Select options via :selected", "#select2 option:selected", [ "option2d" ] ); + t( "Select options via :selected", "#select3 option:selected", [ "option3b", "option3c" ] ); + t( "Select options via :selected", "select[name='select2'] option:selected", [ "option2d" ] ); - t( "Grouped Form Elements", "input[name='foo[bar]']", ["hidden2"] ); + t( "Grouped Form Elements", "input[name='foo[bar]']", [ "hidden2" ] ); // Make sure attribute value quoting works correctly. See jQuery #6093; #6428; #13894 // Use seeded results to bypass querySelectorAll optimizations @@ -213,65 +213,65 @@ test("attributes", function() { "<input type='hidden' id='attrbad_backslash_quote' data-attr='\''/>" + "<input type='hidden' id='attrbad_backslash_backslash' data-attr='\\'/>" + "<input type='hidden' id='attrbad_unicode' data-attr='一'/>" - ).appendTo("#qunit-fixture").get(); + ).appendTo( "#qunit-fixture" ).get(); - t( "Underscores don't need escaping", "input[id=types_all]", ["types_all"] ); + t( "Underscores don't need escaping", "input[id=types_all]", [ "types_all" ] ); - t( "input[type=text]", "#form input[type=text]", ["text1", "text2", "hidden2", "name"] ); - t( "input[type=search]", "#form input[type=search]", ["search"] ); + t( "input[type=text]", "#form input[type=text]", [ "text1", "text2", "hidden2", "name" ] ); + t( "input[type=search]", "#form input[type=search]", [ "search" ] ); withScript = supportjQuery( "<div><span><script src=''/></span></div>" ); ok( withScript.find( "#moretests script[src]" ).has( "script" ), "script[src] (jQuery #13777)" ); - div = document.getElementById("foo"); + div = document.getElementById( "foo" ); t( "Object.prototype property \"constructor\" (negative)", "[constructor]", [] ); t( "Gecko Object.prototype property \"watch\" (negative)", "[watch]", [] ); div.setAttribute( "constructor", "foo" ); div.setAttribute( "watch", "bar" ); - t( "Object.prototype property \"constructor\"", "[constructor='foo']", ["foo"] ); - t( "Gecko Object.prototype property \"watch\"", "[watch='bar']", ["foo"] ); + t( "Object.prototype property \"constructor\"", "[constructor='foo']", [ "foo" ] ); + t( "Gecko Object.prototype property \"watch\"", "[watch='bar']", [ "foo" ] ); - t( "Value attribute is retrieved correctly", "input[value=Test]", ["text1", "text2"] ); + t( "Value attribute is retrieved correctly", "input[value=Test]", [ "text1", "text2" ] ); // #12600 ok( - jQuery("<select value='12600'><option value='option' selected='selected'></option><option value=''></option></select>") + jQuery( "<select value='12600'><option value='option' selected='selected'></option><option value=''></option></select>" ) .prop( "value", "option" ) - .is(":input[value='12600']"), + .is( ":input[value='12600']" ), ":input[value=foo] selects select by attribute" ); - ok( jQuery("<input type='text' value='12600'/>").prop( "value", "option" ).is(":input[value='12600']"), + ok( jQuery( "<input type='text' value='12600'/>" ).prop( "value", "option" ).is( ":input[value='12600']" ), ":input[value=foo] selects text input by attribute" ); // #11115 - ok( jQuery("<input type='checkbox' checked='checked'/>").prop( "checked", false ).is("[checked]"), + ok( jQuery( "<input type='checkbox' checked='checked'/>" ).prop( "checked", false ).is( "[checked]" ), "[checked] selects by attribute (positive)" ); - ok( !jQuery("<input type='checkbox'/>").prop( "checked", true ).is("[checked]"), + ok( !jQuery( "<input type='checkbox'/>" ).prop( "checked", true ).is( "[checked]" ), "[checked] selects by attribute (negative)" ); -}); +} ); -test("disconnected nodes", function() { +test( "disconnected nodes", function() { expect( 1 ); - var $div = jQuery("<div/>"); - equal( $div.is("div"), true, "Make sure .is('nodeName') works on disconnected nodes." ); -}); + var $div = jQuery( "<div/>" ); + equal( $div.is( "div" ), true, "Make sure .is('nodeName') works on disconnected nodes." ); +} ); -test("disconnected nodes - jQuery only", function() { +test( "disconnected nodes - jQuery only", function() { expect( 3 ); - var $opt = jQuery("<option></option>").attr("value", "whipit").appendTo("#qunit-fixture").detach(); + var $opt = jQuery( "<option></option>" ).attr( "value", "whipit" ).appendTo( "#qunit-fixture" ).detach(); equal( $opt.val(), "whipit", "option value" ); - equal( $opt.is(":selected"), false, "unselected option" ); - $opt.prop("selected", true); - equal( $opt.is(":selected"), true, "selected option" ); -}); + equal( $opt.is( ":selected" ), false, "unselected option" ); + $opt.prop( "selected", true ); + equal( $opt.is( ":selected" ), true, "selected option" ); +} ); -testIframe("selector/html5_selector", "attributes - jQuery.attr", function( jQuery, window, document ) { +testIframe( "selector/html5_selector", "attributes - jQuery.attr", function( jQuery, window, document ) { expect( 37 ); /** @@ -283,7 +283,7 @@ testIframe("selector/html5_selector", "attributes - jQuery.attr", function( jQue i = 0; for ( ; i < arguments.length; i++ ) { - r.push( document.getElementById( arguments[i] ) ); + r.push( document.getElementById( arguments[ i ] ) ); } return r; } @@ -296,15 +296,15 @@ testIframe("selector/html5_selector", "attributes - jQuery.attr", function( jQue * @param {Array} c - Array of ids to construct what is expected */ function t( a, b, c ) { - var f = jQuery(b).get(), + var f = jQuery( b ).get(), s = "", i = 0; for ( ; i < f.length; i++ ) { - s += (s && ",") + "'" + f[i].id + "'"; + s += ( s && "," ) + "'" + f[ i ].id + "'"; } - deepEqual(f, q.apply( q, c ), a + " (" + b + ")"); + deepEqual( f, q.apply( q, c ), a + " (" + b + ")" ); } // ====== All known boolean attributes, including html5 booleans ====== @@ -315,77 +315,77 @@ testIframe("selector/html5_selector", "attributes - jQuery.attr", function( jQue // noshade, nowrap, novalidate, open, pubdate, readonly, required, // reversed, scoped, seamless, selected, truespeed, visible (skipping visible attribute, which is on a barprop object) - t( "Attribute Exists", "[autobuffer]", ["video1"]); - t( "Attribute Exists", "[autofocus]", ["text1"]); - t( "Attribute Exists", "[autoplay]", ["video1"]); - t( "Attribute Exists", "[async]", ["script1"]); - t( "Attribute Exists", "[checked]", ["check1"]); - t( "Attribute Exists", "[compact]", ["dl"]); - t( "Attribute Exists", "[controls]", ["video1"]); - t( "Attribute Exists", "[declare]", ["object1"]); - t( "Attribute Exists", "[defer]", ["script1"]); - t( "Attribute Exists", "[disabled]", ["check1"]); - t( "Attribute Exists", "[formnovalidate]", ["form1"]); - t( "Attribute Exists", "[hidden]", ["div1"]); - t( "Attribute Exists", "[indeterminate]", []); - t( "Attribute Exists", "[ismap]", ["img1"]); - t( "Attribute Exists", "[itemscope]", ["div1"]); - t( "Attribute Exists", "[loop]", ["video1"]); - t( "Attribute Exists", "[multiple]", ["select1"]); - t( "Attribute Exists", "[muted]", ["audio1"]); - t( "Attribute Exists", "[nohref]", ["area1"]); - t( "Attribute Exists", "[noresize]", ["textarea1"]); - t( "Attribute Exists", "[noshade]", ["hr1"]); - t( "Attribute Exists", "[nowrap]", ["td1", "div1"]); - t( "Attribute Exists", "[novalidate]", ["form1"]); - t( "Attribute Exists", "[open]", ["details1"]); - t( "Attribute Exists", "[pubdate]", ["article1"]); - t( "Attribute Exists", "[readonly]", ["text1"]); - t( "Attribute Exists", "[required]", ["text1"]); - t( "Attribute Exists", "[reversed]", ["ol1"]); - t( "Attribute Exists", "[scoped]", ["style1"]); - t( "Attribute Exists", "[seamless]", ["iframe1"]); - t( "Attribute Exists", "[selected]", ["option1"]); - t( "Attribute Exists", "[truespeed]", ["marquee1"]); + t( "Attribute Exists", "[autobuffer]", [ "video1" ] ); + t( "Attribute Exists", "[autofocus]", [ "text1" ] ); + t( "Attribute Exists", "[autoplay]", [ "video1" ] ); + t( "Attribute Exists", "[async]", [ "script1" ] ); + t( "Attribute Exists", "[checked]", [ "check1" ] ); + t( "Attribute Exists", "[compact]", [ "dl" ] ); + t( "Attribute Exists", "[controls]", [ "video1" ] ); + t( "Attribute Exists", "[declare]", [ "object1" ] ); + t( "Attribute Exists", "[defer]", [ "script1" ] ); + t( "Attribute Exists", "[disabled]", [ "check1" ] ); + t( "Attribute Exists", "[formnovalidate]", [ "form1" ] ); + t( "Attribute Exists", "[hidden]", [ "div1" ] ); + t( "Attribute Exists", "[indeterminate]", [] ); + t( "Attribute Exists", "[ismap]", [ "img1" ] ); + t( "Attribute Exists", "[itemscope]", [ "div1" ] ); + t( "Attribute Exists", "[loop]", [ "video1" ] ); + t( "Attribute Exists", "[multiple]", [ "select1" ] ); + t( "Attribute Exists", "[muted]", [ "audio1" ] ); + t( "Attribute Exists", "[nohref]", [ "area1" ] ); + t( "Attribute Exists", "[noresize]", [ "textarea1" ] ); + t( "Attribute Exists", "[noshade]", [ "hr1" ] ); + t( "Attribute Exists", "[nowrap]", [ "td1", "div1" ] ); + t( "Attribute Exists", "[novalidate]", [ "form1" ] ); + t( "Attribute Exists", "[open]", [ "details1" ] ); + t( "Attribute Exists", "[pubdate]", [ "article1" ] ); + t( "Attribute Exists", "[readonly]", [ "text1" ] ); + t( "Attribute Exists", "[required]", [ "text1" ] ); + t( "Attribute Exists", "[reversed]", [ "ol1" ] ); + t( "Attribute Exists", "[scoped]", [ "style1" ] ); + t( "Attribute Exists", "[seamless]", [ "iframe1" ] ); + t( "Attribute Exists", "[selected]", [ "option1" ] ); + t( "Attribute Exists", "[truespeed]", [ "marquee1" ] ); // Enumerated attributes (these are not boolean content attributes) jQuery.expandedEach = jQuery.each; - jQuery.expandedEach([ "draggable", "contenteditable", "aria-disabled" ], function( i, val ) { - t( "Enumerated attribute", "[" + val + "]", ["div1"]); - }); - t( "Enumerated attribute", "[spellcheck]", ["span1"]); + jQuery.expandedEach( [ "draggable", "contenteditable", "aria-disabled" ], function( i, val ) { + t( "Enumerated attribute", "[" + val + "]", [ "div1" ] ); + } ); + t( "Enumerated attribute", "[spellcheck]", [ "span1" ] ); // t( "tabindex selector does not retrieve all elements in IE6/7(#8473)", "form, [tabindex]", ["form1", "text1"] ); // sigh, FF12 QSA mistakenly includes video elements even though they have no tabindex attribute (see https://bugzilla.mozilla.org/show_bug.cgi?id=618737) - t( "Improperly named form elements do not interfere with form selections (#9570)", "form[name='formName']", ["form1"] ); -}); + t( "Improperly named form elements do not interfere with form selections (#9570)", "form[name='formName']", [ "form1" ] ); +} ); test( "jQuery.contains", function() { expect( 16 ); - var container = document.getElementById("nonnodes"), + var container = document.getElementById( "nonnodes" ), element = container.firstChild, text = element.nextSibling, nonContained = container.nextSibling, - detached = document.createElement("a"); + detached = document.createElement( "a" ); ok( element && element.nodeType === 1, "preliminary: found element" ); ok( text && text.nodeType === 3, "preliminary: found text" ); ok( nonContained, "preliminary: found non-descendant" ); - ok( jQuery.contains(container, element), "child" ); - ok( jQuery.contains(container.parentNode, element), "grandchild" ); - ok( jQuery.contains(container, text), "text child" ); - ok( jQuery.contains(container.parentNode, text), "text grandchild" ); - ok( !jQuery.contains(container, container), "self" ); - ok( !jQuery.contains(element, container), "parent" ); - ok( !jQuery.contains(container, nonContained), "non-descendant" ); - ok( !jQuery.contains(container, document), "document" ); - ok( !jQuery.contains(container, document.documentElement), "documentElement (negative)" ); - ok( !jQuery.contains(container, null), "Passing null does not throw an error" ); - ok( jQuery.contains(document, document.documentElement), "documentElement (positive)" ); - ok( jQuery.contains(document, element), "document container (positive)" ); - ok( !jQuery.contains(document, detached), "document container (negative)" ); -}); - -test("jQuery.uniqueSort", function() { + ok( jQuery.contains( container, element ), "child" ); + ok( jQuery.contains( container.parentNode, element ), "grandchild" ); + ok( jQuery.contains( container, text ), "text child" ); + ok( jQuery.contains( container.parentNode, text ), "text grandchild" ); + ok( !jQuery.contains( container, container ), "self" ); + ok( !jQuery.contains( element, container ), "parent" ); + ok( !jQuery.contains( container, nonContained ), "non-descendant" ); + ok( !jQuery.contains( container, document ), "document" ); + ok( !jQuery.contains( container, document.documentElement ), "documentElement (negative)" ); + ok( !jQuery.contains( container, null ), "Passing null does not throw an error" ); + ok( jQuery.contains( document, document.documentElement ), "documentElement (positive)" ); + ok( jQuery.contains( document, element ), "document container (positive)" ); + ok( !jQuery.contains( document, detached ), "document container (negative)" ); +} ); + +test( "jQuery.uniqueSort", function() { expect( 15 ); function Arrayish( arr ) { @@ -403,16 +403,16 @@ test("jQuery.uniqueSort", function() { var i, tests, detached = [], body = document.body, - fixture = document.getElementById("qunit-fixture"), - detached1 = document.createElement("p"), - detached2 = document.createElement("ul"), - detachedChild = detached1.appendChild( document.createElement("a") ), - detachedGrandchild = detachedChild.appendChild( document.createElement("b") ); + fixture = document.getElementById( "qunit-fixture" ), + detached1 = document.createElement( "p" ), + detached2 = document.createElement( "ul" ), + detachedChild = detached1.appendChild( document.createElement( "a" ) ), + detachedGrandchild = detachedChild.appendChild( document.createElement( "b" ) ); for ( i = 0; i < 12; i++ ) { - detached.push( document.createElement("li") ); - detached[i].id = "detached" + i; - detached2.appendChild( document.createElement("li") ).id = "detachedChild" + i; + detached.push( document.createElement( "li" ) ); + detached[ i ].id = "detached" + i; + detached2.appendChild( document.createElement( "li" ) ).id = "detachedChild" + i; } tests = { @@ -438,16 +438,16 @@ test("jQuery.uniqueSort", function() { }, "Detached children": { input: [ - detached2.childNodes[0], - detached2.childNodes[1], - detached2.childNodes[2], - detached2.childNodes[3] + detached2.childNodes[ 0 ], + detached2.childNodes[ 1 ], + detached2.childNodes[ 2 ], + detached2.childNodes[ 3 ] ], expected: [ - detached2.childNodes[0], - detached2.childNodes[1], - detached2.childNodes[2], - detached2.childNodes[3] + detached2.childNodes[ 0 ], + detached2.childNodes[ 1 ], + detached2.childNodes[ 2 ], + detached2.childNodes[ 3 ] ] }, "Attached/detached mixture": { @@ -460,21 +460,21 @@ test("jQuery.uniqueSort", function() { jQuery.each( tests, function( label, test ) { var length = test.length || test.input.length; deepEqual( jQuery.uniqueSort( test.input ).slice( 0, length ), test.expected, label + " (array)" ); - deepEqual( jQuery.uniqueSort( new Arrayish(test.input) ).slice( 0, length ), test.expected, label + " (quasi-array)" ); - }); + deepEqual( jQuery.uniqueSort( new Arrayish( test.input ) ).slice( 0, length ), test.expected, label + " (quasi-array)" ); + } ); strictEqual( jQuery.unique, jQuery.uniqueSort, "jQuery.unique() is an alias for jQuery.uniqueSort()" ); -}); +} ); -testIframe("selector/sizzle_cache", "Sizzle cache collides with multiple Sizzles on a page", function( jQuery, window, document ) { - var $cached = window["$cached"]; +testIframe( "selector/sizzle_cache", "Sizzle cache collides with multiple Sizzles on a page", function( jQuery, window, document ) { + var $cached = window[ "$cached" ]; - expect(4); + expect( 4 ); notStrictEqual( jQuery, $cached, "Loaded two engines" ); - deepEqual( $cached(".test a").get(), [ document.getElementById("collision") ], "Select collision anchor with first sizzle" ); - equal( jQuery(".evil a").length, 0, "Select nothing with second sizzle" ); - equal( jQuery(".evil a").length, 0, "Select nothing again with second sizzle" ); -}); + deepEqual( $cached( ".test a" ).get(), [ document.getElementById( "collision" ) ], "Select collision anchor with first sizzle" ); + equal( jQuery( ".evil a" ).length, 0, "Select nothing with second sizzle" ); + equal( jQuery( ".evil a" ).length, 0, "Select nothing again with second sizzle" ); +} ); asyncTest( "Iframe dispatch should not affect jQuery (#13936)", 1, function() { var loaded = false, @@ -503,9 +503,9 @@ asyncTest( "Iframe dispatch should not affect jQuery (#13936)", 1, function() { loaded = true; form.submit(); } - }); + } ); iframeDoc.open(); iframeDoc.write( "<body><form id='navigate' action='?'></form></body>" ); iframeDoc.close(); -}); +} ); diff --git a/test/unit/serialize.js b/test/unit/serialize.js index 4f1f817f4..d3def19a1 100644 --- a/test/unit/serialize.js +++ b/test/unit/serialize.js @@ -1,43 +1,43 @@ -module("serialize", { teardown: moduleTeardown }); +module( "serialize", { teardown: moduleTeardown } ); -test("jQuery.param()", function() { - expect(22); +test( "jQuery.param()", function() { + expect( 22 ); var params, settings; equal( !( jQuery.ajaxSettings && jQuery.ajaxSettings.traditional ), true, "traditional flag, falsy by default" ); - params = {"foo":"bar", "baz":42, "quux":"All your base are belong to us"}; - equal( jQuery.param(params), "foo=bar&baz=42&quux=All+your+base+are+belong+to+us", "simple" ); + params = { "foo":"bar", "baz":42, "quux":"All your base are belong to us" }; + equal( jQuery.param( params ), "foo=bar&baz=42&quux=All+your+base+are+belong+to+us", "simple" ); - params = {"string":"foo","null":null,"undefined":undefined}; - equal( jQuery.param(params), "string=foo&null=&undefined=", "handle nulls and undefineds properly" ); + params = { "string":"foo","null":null,"undefined":undefined }; + equal( jQuery.param( params ), "string=foo&null=&undefined=", "handle nulls and undefineds properly" ); - params = {"someName": [1, 2, 3], "regularThing": "blah" }; - equal( jQuery.param(params), "someName%5B%5D=1&someName%5B%5D=2&someName%5B%5D=3®ularThing=blah", "with array" ); + params = { "someName": [ 1, 2, 3 ], "regularThing": "blah" }; + equal( jQuery.param( params ), "someName%5B%5D=1&someName%5B%5D=2&someName%5B%5D=3®ularThing=blah", "with array" ); - params = {"foo": ["a", "b", "c"]}; - equal( jQuery.param(params), "foo%5B%5D=a&foo%5B%5D=b&foo%5B%5D=c", "with array of strings" ); + params = { "foo": [ "a", "b", "c" ] }; + equal( jQuery.param( params ), "foo%5B%5D=a&foo%5B%5D=b&foo%5B%5D=c", "with array of strings" ); - params = {"foo": ["baz", 42, "All your base are belong to us"] }; - equal( jQuery.param(params), "foo%5B%5D=baz&foo%5B%5D=42&foo%5B%5D=All+your+base+are+belong+to+us", "more array" ); + params = { "foo": [ "baz", 42, "All your base are belong to us" ] }; + equal( jQuery.param( params ), "foo%5B%5D=baz&foo%5B%5D=42&foo%5B%5D=All+your+base+are+belong+to+us", "more array" ); - params = {"foo": { "bar": "baz", "beep": 42, "quux": "All your base are belong to us" } }; - equal( jQuery.param(params), "foo%5Bbar%5D=baz&foo%5Bbeep%5D=42&foo%5Bquux%5D=All+your+base+are+belong+to+us", "even more arrays" ); + params = { "foo": { "bar": "baz", "beep": 42, "quux": "All your base are belong to us" } }; + equal( jQuery.param( params ), "foo%5Bbar%5D=baz&foo%5Bbeep%5D=42&foo%5Bquux%5D=All+your+base+are+belong+to+us", "even more arrays" ); - params = { a:[1,2], b:{ c:3, d:[4,5], e:{ x:[6], y:7, z:[8,9] }, f:true, g:false, h:undefined }, i:[10,11], j:true, k:false, l:[undefined,0], m:"cowboy hat?" }; - equal( decodeURIComponent( jQuery.param(params) ), "a[]=1&a[]=2&b[c]=3&b[d][]=4&b[d][]=5&b[e][x][]=6&b[e][y]=7&b[e][z][]=8&b[e][z][]=9&b[f]=true&b[g]=false&b[h]=&i[]=10&i[]=11&j=true&k=false&l[]=&l[]=0&m=cowboy+hat?", "huge structure" ); + params = { a:[ 1,2 ], b:{ c:3, d:[ 4,5 ], e:{ x:[ 6 ], y:7, z:[ 8,9 ] }, f:true, g:false, h:undefined }, i:[ 10,11 ], j:true, k:false, l:[ undefined,0 ], m:"cowboy hat?" }; + equal( decodeURIComponent( jQuery.param( params ) ), "a[]=1&a[]=2&b[c]=3&b[d][]=4&b[d][]=5&b[e][x][]=6&b[e][y]=7&b[e][z][]=8&b[e][z][]=9&b[f]=true&b[g]=false&b[h]=&i[]=10&i[]=11&j=true&k=false&l[]=&l[]=0&m=cowboy+hat?", "huge structure" ); params = { "a": [ 0, [ 1, 2 ], [ 3, [ 4, 5 ], [ 6 ] ], { "b": [ 7, [ 8, 9 ], [ { "c": 10, "d": 11 } ], [ [ 12 ] ], [ [ [ 13 ] ] ], { "e": { "f": { "g": [ 14, [ 15 ] ] } } }, 16 ] }, 17 ] }; - equal( decodeURIComponent( jQuery.param(params) ), "a[]=0&a[1][]=1&a[1][]=2&a[2][]=3&a[2][1][]=4&a[2][1][]=5&a[2][2][]=6&a[3][b][]=7&a[3][b][1][]=8&a[3][b][1][]=9&a[3][b][2][0][c]=10&a[3][b][2][0][d]=11&a[3][b][3][0][]=12&a[3][b][4][0][0][]=13&a[3][b][5][e][f][g][]=14&a[3][b][5][e][f][g][1][]=15&a[3][b][]=16&a[]=17", "nested arrays" ); + equal( decodeURIComponent( jQuery.param( params ) ), "a[]=0&a[1][]=1&a[1][]=2&a[2][]=3&a[2][1][]=4&a[2][1][]=5&a[2][2][]=6&a[3][b][]=7&a[3][b][1][]=8&a[3][b][1][]=9&a[3][b][2][0][c]=10&a[3][b][2][0][d]=11&a[3][b][3][0][]=12&a[3][b][4][0][0][]=13&a[3][b][5][e][f][g][]=14&a[3][b][5][e][f][g][1][]=15&a[3][b][]=16&a[]=17", "nested arrays" ); - params = { "a":[1,2], "b":{ "c":3, "d":[4,5], "e":{ "x":[6], "y":7, "z":[8,9] }, "f":true, "g":false, "h":undefined }, "i":[10,11], "j":true, "k":false, "l":[undefined,0], "m":"cowboy hat?" }; - equal( jQuery.param(params,true), "a=1&a=2&b=%5Bobject+Object%5D&i=10&i=11&j=true&k=false&l=&l=0&m=cowboy+hat%3F", "huge structure, forced traditional" ); + params = { "a":[ 1,2 ], "b":{ "c":3, "d":[ 4,5 ], "e":{ "x":[ 6 ], "y":7, "z":[ 8,9 ] }, "f":true, "g":false, "h":undefined }, "i":[ 10,11 ], "j":true, "k":false, "l":[ undefined,0 ], "m":"cowboy hat?" }; + equal( jQuery.param( params, true ), "a=1&a=2&b=%5Bobject+Object%5D&i=10&i=11&j=true&k=false&l=&l=0&m=cowboy+hat%3F", "huge structure, forced traditional" ); - equal( decodeURIComponent( jQuery.param({ "a": [1,2,3], "b[]": [4,5,6], "c[d]": [7,8,9], "e": { "f": [10], "g": [11,12], "h": 13 } }) ), "a[]=1&a[]=2&a[]=3&b[]=4&b[]=5&b[]=6&c[d][]=7&c[d][]=8&c[d][]=9&e[f][]=10&e[g][]=11&e[g][]=12&e[h]=13", "Make sure params are not double-encoded." ); + equal( decodeURIComponent( jQuery.param( { "a": [ 1,2,3 ], "b[]": [ 4,5,6 ], "c[d]": [ 7,8,9 ], "e": { "f": [ 10 ], "g": [ 11,12 ], "h": 13 } } ) ), "a[]=1&a[]=2&a[]=3&b[]=4&b[]=5&b[]=6&c[d][]=7&c[d][]=8&c[d][]=9&e[f][]=10&e[g][]=11&e[g][]=12&e[h]=13", "Make sure params are not double-encoded." ); // #7945 - equal( jQuery.param({"jquery": "1.4.2"}), "jquery=1.4.2", "Check that object with a jQuery property get serialized correctly" ); + equal( jQuery.param( { "jquery": "1.4.2" } ), "jquery=1.4.2", "Check that object with a jQuery property get serialized correctly" ); settings = { traditional: true }; @@ -47,58 +47,58 @@ test("jQuery.param()", function() { jQuery.ajaxSettings = settings; } - params = {"foo":"bar", "baz":42, "quux":"All your base are belong to us"}; - equal( jQuery.param(params), "foo=bar&baz=42&quux=All+your+base+are+belong+to+us", "simple" ); + params = { "foo":"bar", "baz":42, "quux":"All your base are belong to us" }; + equal( jQuery.param( params ), "foo=bar&baz=42&quux=All+your+base+are+belong+to+us", "simple" ); - params = {"someName": [1, 2, 3], "regularThing": "blah" }; - equal( jQuery.param(params), "someName=1&someName=2&someName=3®ularThing=blah", "with array" ); + params = { "someName": [ 1, 2, 3 ], "regularThing": "blah" }; + equal( jQuery.param( params ), "someName=1&someName=2&someName=3®ularThing=blah", "with array" ); - params = {"foo": ["a", "b", "c"]}; - equal( jQuery.param(params), "foo=a&foo=b&foo=c", "with array of strings" ); + params = { "foo": [ "a", "b", "c" ] }; + equal( jQuery.param( params ), "foo=a&foo=b&foo=c", "with array of strings" ); - params = {"foo[]":["baz", 42, "All your base are belong to us"]}; - equal( jQuery.param(params), "foo%5B%5D=baz&foo%5B%5D=42&foo%5B%5D=All+your+base+are+belong+to+us", "more array" ); + params = { "foo[]":[ "baz", 42, "All your base are belong to us" ] }; + equal( jQuery.param( params ), "foo%5B%5D=baz&foo%5B%5D=42&foo%5B%5D=All+your+base+are+belong+to+us", "more array" ); - params = {"foo[bar]":"baz", "foo[beep]":42, "foo[quux]":"All your base are belong to us"}; - equal( jQuery.param(params), "foo%5Bbar%5D=baz&foo%5Bbeep%5D=42&foo%5Bquux%5D=All+your+base+are+belong+to+us", "even more arrays" ); + params = { "foo[bar]":"baz", "foo[beep]":42, "foo[quux]":"All your base are belong to us" }; + equal( jQuery.param( params ), "foo%5Bbar%5D=baz&foo%5Bbeep%5D=42&foo%5Bquux%5D=All+your+base+are+belong+to+us", "even more arrays" ); - params = { a:[1,2], b:{ c:3, d:[4,5], e:{ x:[6], y:7, z:[8,9] }, f:true, g:false, h:undefined }, i:[10,11], j:true, k:false, l:[undefined,0], m:"cowboy hat?" }; - equal( jQuery.param(params), "a=1&a=2&b=%5Bobject+Object%5D&i=10&i=11&j=true&k=false&l=&l=0&m=cowboy+hat%3F", "huge structure" ); + params = { a:[ 1,2 ], b:{ c:3, d:[ 4,5 ], e:{ x:[ 6 ], y:7, z:[ 8,9 ] }, f:true, g:false, h:undefined }, i:[ 10,11 ], j:true, k:false, l:[ undefined,0 ], m:"cowboy hat?" }; + equal( jQuery.param( params ), "a=1&a=2&b=%5Bobject+Object%5D&i=10&i=11&j=true&k=false&l=&l=0&m=cowboy+hat%3F", "huge structure" ); params = { "a": [ 0, [ 1, 2 ], [ 3, [ 4, 5 ], [ 6 ] ], { "b": [ 7, [ 8, 9 ], [ { "c": 10, d: 11 } ], [ [ 12 ] ], [ [ [ 13 ] ] ], { "e": { "f": { "g": [ 14, [ 15 ] ] } } }, 16 ] }, 17 ] }; - equal( jQuery.param(params), "a=0&a=1%2C2&a=3%2C4%2C5%2C6&a=%5Bobject+Object%5D&a=17", "nested arrays (not possible when jQuery.param.traditional == true)" ); + equal( jQuery.param( params ), "a=0&a=1%2C2&a=3%2C4%2C5%2C6&a=%5Bobject+Object%5D&a=17", "nested arrays (not possible when jQuery.param.traditional == true)" ); - params = { a:[1,2], b:{ c:3, d:[4,5], e:{ x:[6], y:7, z:[8,9] }, f:true, g:false, h:undefined }, i:[10,11], j:true, k:false, l:[undefined,0], m:"cowboy hat?" }; - equal( decodeURIComponent( jQuery.param(params,false) ), "a[]=1&a[]=2&b[c]=3&b[d][]=4&b[d][]=5&b[e][x][]=6&b[e][y]=7&b[e][z][]=8&b[e][z][]=9&b[f]=true&b[g]=false&b[h]=&i[]=10&i[]=11&j=true&k=false&l[]=&l[]=0&m=cowboy+hat?", "huge structure, forced not traditional" ); + params = { a:[ 1,2 ], b:{ c:3, d:[ 4,5 ], e:{ x:[ 6 ], y:7, z:[ 8,9 ] }, f:true, g:false, h:undefined }, i:[ 10,11 ], j:true, k:false, l:[ undefined,0 ], m:"cowboy hat?" }; + equal( decodeURIComponent( jQuery.param( params, false ) ), "a[]=1&a[]=2&b[c]=3&b[d][]=4&b[d][]=5&b[e][x][]=6&b[e][y]=7&b[e][z][]=8&b[e][z][]=9&b[f]=true&b[g]=false&b[h]=&i[]=10&i[]=11&j=true&k=false&l[]=&l[]=0&m=cowboy+hat?", "huge structure, forced not traditional" ); params = { "param1": null }; - equal( jQuery.param(params,false), "param1=", "Make sure that null params aren't traversed." ); + equal( jQuery.param( params, false ), "param1=", "Make sure that null params aren't traversed." ); - params = {"test": {"length": 3, "foo": "bar"} }; + params = { "test": { "length": 3, "foo": "bar" } }; equal( jQuery.param( params, false ), "test%5Blength%5D=3&test%5Bfoo%5D=bar", "Sub-object with a length property" ); if ( jQuery.ajaxSettings === settings ) { delete jQuery.ajaxSettings; } else { - jQuery.ajaxSetup({ traditional: false }); + jQuery.ajaxSetup( { traditional: false } ); } -}); +} ); -test("jQuery.param() Constructed prop values", function() { +test( "jQuery.param() Constructed prop values", function() { expect( 4 ); /** @constructor */ function Record() { - this["prop"] = "val"; + this[ "prop" ] = "val"; } var MyString = String, MyNumber = Number, - params = { "test": new MyString("foo") }; + params = { "test": new MyString( "foo" ) }; equal( jQuery.param( params, false ), "test=foo", "Do not mistake new String() for a plain object" ); - params = { "test": new MyNumber(5) }; + params = { "test": new MyNumber( 5 ) }; equal( jQuery.param( params, false ), "test=5", "Do not mistake new Number() for a plain object" ); params = { "test": new Date() }; @@ -106,41 +106,41 @@ test("jQuery.param() Constructed prop values", function() { // should allow non-native constructed objects params = { "test": new Record() }; - equal( jQuery.param( params, false ), jQuery.param({ "test": { "prop": "val" } }), "Allow non-native constructed objects" ); -}); + equal( jQuery.param( params, false ), jQuery.param( { "test": { "prop": "val" } } ), "Allow non-native constructed objects" ); +} ); -test("serialize()", function() { +test( "serialize()", function() { expect( 6 ); // Add html5 elements only for serialize because selector can't yet find them on non-html5 browsers - jQuery("#search").after( + jQuery( "#search" ).after( "<input type='email' id='html5email' name='email' value='dave@jquery.com' />" + "<input type='number' id='html5number' name='number' value='43' />" + "<input type='file' name='fileupload' />" ); - equal( jQuery("#form").serialize(), + equal( jQuery( "#form" ).serialize(), "action=Test&radio2=on&check=on&hidden=&foo%5Bbar%5D=&name=name&search=search&email=dave%40jquery.com&number=43&select1=&select2=3&select3=1&select3=2&select5=3", - "Check form serialization as query string"); + "Check form serialization as query string" ); - equal( jQuery("input,select,textarea,button", "#form").serialize(), + equal( jQuery( "input,select,textarea,button", "#form" ).serialize(), "action=Test&radio2=on&check=on&hidden=&foo%5Bbar%5D=&name=name&search=search&email=dave%40jquery.com&number=43&select1=&select2=3&select3=1&select3=2&select5=3", - "Check input serialization as query string"); + "Check input serialization as query string" ); - equal( jQuery("#testForm").serialize(), + equal( jQuery( "#testForm" ).serialize(), "T3=%3F%0D%0AZ&H1=x&H2=&PWD=&T1=&T2=YES&My+Name=me&S1=abc&S3=YES&S4=", - "Check form serialization as query string"); + "Check form serialization as query string" ); - equal( jQuery("input,select,textarea,button", "#testForm").serialize(), + equal( jQuery( "input,select,textarea,button", "#testForm" ).serialize(), "T3=%3F%0D%0AZ&H1=x&H2=&PWD=&T1=&T2=YES&My+Name=me&S1=abc&S3=YES&S4=", - "Check input serialization as query string"); + "Check input serialization as query string" ); - equal( jQuery("#form, #testForm").serialize(), + equal( jQuery( "#form, #testForm" ).serialize(), "action=Test&radio2=on&check=on&hidden=&foo%5Bbar%5D=&name=name&search=search&email=dave%40jquery.com&number=43&select1=&select2=3&select3=1&select3=2&select5=3&T3=%3F%0D%0AZ&H1=x&H2=&PWD=&T1=&T2=YES&My+Name=me&S1=abc&S3=YES&S4=", - "Multiple form serialization as query string"); + "Multiple form serialization as query string" ); - equal( jQuery("#form, #testForm :input").serialize(), + equal( jQuery( "#form, #testForm :input" ).serialize(), "action=Test&radio2=on&check=on&hidden=&foo%5Bbar%5D=&name=name&search=search&email=dave%40jquery.com&number=43&select1=&select2=3&select3=1&select3=2&select5=3&T3=%3F%0D%0AZ&H1=x&H2=&PWD=&T1=&T2=YES&My+Name=me&S1=abc&S3=YES&S4=", - "Mixed form/input serialization as query string"); - jQuery("#html5email, #html5number").remove(); -}); + "Mixed form/input serialization as query string" ); + jQuery( "#html5email, #html5number" ).remove(); +} ); diff --git a/test/unit/support.js b/test/unit/support.js index 75a3e3071..80242257e 100644 --- a/test/unit/support.js +++ b/test/unit/support.js @@ -1,4 +1,4 @@ -module("support", { teardown: moduleTeardown }); +module( "support", { teardown: moduleTeardown } ); function getComputedSupport( support ) { var prop, @@ -21,7 +21,7 @@ test( "zoom of doom (#13089)", function() { expect( 1 ); ok( !document.body.style.zoom, "No zoom added to the body" ); -}); +} ); if ( jQuery.css ) { testIframeWithCallback( "body background is not lost if set prior to loading jQuery (#9239)", "support/bodyBackground.html", function( color, support ) { @@ -33,19 +33,19 @@ if ( jQuery.css ) { ok( okValue[ color ], "color was not reset (" + color + ")" ); stop(); + // Run doc ready tests as well - jQuery(function() { + jQuery( function() { deepEqual( jQuery.extend( {}, support ), computedSupport, "Same support properties" ); start(); - }); - }); + } ); + } ); } testIframeWithCallback( "A background on the testElement does not cause IE8 to crash (#9823)", "support/testElementCrash.html", function() { expect( 1 ); ok( true, "IE8 does not crash" ); -}); - +} ); // This test checks CSP only for browsers with "Content-Security-Policy" header support // i.e. no old WebKit or old Firefox @@ -57,14 +57,14 @@ testIframeWithCallback( "Check CSP (https://developer.mozilla.org/en-US/docs/Sec stop(); - supportjQuery.get( "data/support/csp.log" ).done(function( data ) { + supportjQuery.get( "data/support/csp.log" ).done( function( data ) { equal( data, "", "No log request should be sent" ); supportjQuery.get( "data/support/csp-clean.php" ).done( start ); - }); + } ); } ); -(function() { +( function() { var expected, userAgent = window.navigator.userAgent; @@ -201,6 +201,7 @@ testIframeWithCallback( "Check CSP (https://developer.mozilla.org/en-US/docs/Sec "submit": false }; } else if ( /chrome/i.test( userAgent ) ) { + // Catches Chrome on Android as well (i.e. the default // Android browser on Android >= 4.4). expected = { @@ -481,14 +482,14 @@ testIframeWithCallback( "Check CSP (https://developer.mozilla.org/en-US/docs/Sec for ( i in expected ) { if ( jQuery.ajax || i !== "ajax" && i !== "cors" ) { - equal( computedSupport[i], expected[i], - "jQuery.support['" + i + "']: " + computedSupport[i] + - ", expected['" + i + "']: " + expected[i]); + equal( computedSupport[ i ], expected[ i ], + "jQuery.support['" + i + "']: " + computedSupport[ i ] + + ", expected['" + i + "']: " + expected[ i ] ); } else { ok( true, "no ajax; skipping jQuery.support['" + i + "']" ); } } - }); + } ); } -})(); +} )(); diff --git a/test/unit/traversing.js b/test/unit/traversing.js index db58beec3..b5ccf6d35 100644 --- a/test/unit/traversing.js +++ b/test/unit/traversing.js @@ -1,46 +1,46 @@ -module("traversing", { teardown: moduleTeardown }); +module( "traversing", { teardown: moduleTeardown } ); test( "find(String)", function() { expect( 1 ); - equal( jQuery("#foo").find(".blogTest").text(), "Yahoo", "Basic selector" ); -}); + equal( jQuery( "#foo" ).find( ".blogTest" ).text(), "Yahoo", "Basic selector" ); +} ); test( "find(String) under non-elements", function() { expect( 2 ); - var j = jQuery("#nonnodes").contents(); - equal( j.find("div").length, 0, "Check node,textnode,comment to find zero divs" ); - equal( j.find("div").addBack().length, 3, "Check node,textnode,comment to find zero divs, but preserves pushStack" ); -}); + var j = jQuery( "#nonnodes" ).contents(); + equal( j.find( "div" ).length, 0, "Check node,textnode,comment to find zero divs" ); + equal( j.find( "div" ).addBack().length, 3, "Check node,textnode,comment to find zero divs, but preserves pushStack" ); +} ); test( "find(leading combinator)", function() { expect( 4 ); - deepEqual( jQuery("#qunit-fixture").find("> div").get(), q( "foo", "nothiddendiv", "moretests", "tabindex-tests", "liveHandlerOrder", "siblingTest", "fx-test-group" ), "find child elements" ); - deepEqual( jQuery("#qunit-fixture").find("> #foo, > #moretests").get(), q( "foo", "moretests" ), "find child elements" ); - deepEqual( jQuery("#qunit-fixture").find("> #foo > p").get(), q( "sndp", "en", "sap" ), "find child elements" ); + deepEqual( jQuery( "#qunit-fixture" ).find( "> div" ).get(), q( "foo", "nothiddendiv", "moretests", "tabindex-tests", "liveHandlerOrder", "siblingTest", "fx-test-group" ), "find child elements" ); + deepEqual( jQuery( "#qunit-fixture" ).find( "> #foo, > #moretests" ).get(), q( "foo", "moretests" ), "find child elements" ); + deepEqual( jQuery( "#qunit-fixture" ).find( "> #foo > p" ).get(), q( "sndp", "en", "sap" ), "find child elements" ); - deepEqual( jQuery("#siblingTest, #siblingfirst").find("+ *").get(), q( "siblingnext", "fx-test-group" ), "ensure document order" ); -}); + deepEqual( jQuery( "#siblingTest, #siblingfirst" ).find( "+ *" ).get(), q( "siblingnext", "fx-test-group" ), "ensure document order" ); +} ); test( "find(node|jQuery object)", function() { expect( 13 ); - var $foo = jQuery("#foo"), - $blog = jQuery(".blogTest"), - $first = jQuery("#first"), + var $foo = jQuery( "#foo" ), + $blog = jQuery( ".blogTest" ), + $first = jQuery( "#first" ), $two = $blog.add( $first ), - $twoMore = jQuery("#ap").add( $blog ), + $twoMore = jQuery( "#ap" ).add( $blog ), $fooTwo = $foo.add( $blog ); equal( $foo.find( $blog ).text(), "Yahoo", "Find with blog jQuery object" ); equal( $foo.find( $blog[ 0 ] ).text(), "Yahoo", "Find with blog node" ); equal( $foo.find( $first ).length, 0, "#first is not in #foo" ); - equal( $foo.find( $first[ 0 ]).length, 0, "#first not in #foo (node)" ); + equal( $foo.find( $first[ 0 ] ).length, 0, "#first not in #foo (node)" ); deepEqual( $foo.find( $two ).get(), $blog.get(), "Find returns only nodes within #foo" ); deepEqual( $foo.find( $twoMore ).get(), $blog.get(), "...regardless of order" ); - ok( $fooTwo.find( $blog ).is(".blogTest"), "Blog is part of the collection, but also within foo" ); - ok( $fooTwo.find( $blog[ 0 ] ).is(".blogTest"), "Blog is part of the collection, but also within foo(node)" ); + ok( $fooTwo.find( $blog ).is( ".blogTest" ), "Blog is part of the collection, but also within foo" ); + ok( $fooTwo.find( $blog[ 0 ] ).is( ".blogTest" ), "Blog is part of the collection, but also within foo(node)" ); equal( $two.find( $foo ).length, 0, "Foo is not in two elements" ); equal( $two.find( $foo[ 0 ] ).length, 0, "Foo is not in two elements(node)" ); @@ -48,47 +48,47 @@ test( "find(node|jQuery object)", function() { equal( $two.find( $first ).length, 0, "first is in the collection and not within two(node)" ); equal( $two.find( $foo[ 0 ] ).addBack().length, 2, "find preserves the pushStack, see #12009" ); -}); - -test("is(String|undefined)", function() { - expect(23); - ok( jQuery("#form").is("form"), "Check for element: A form must be a form" ); - ok( !jQuery("#form").is("div"), "Check for element: A form is not a div" ); - ok( jQuery("#mark").is(".blog"), "Check for class: Expected class 'blog'" ); - ok( !jQuery("#mark").is(".link"), "Check for class: Did not expect class 'link'" ); - ok( jQuery("#simon").is(".blog.link"), "Check for multiple classes: Expected classes 'blog' and 'link'" ); - ok( !jQuery("#simon").is(".blogTest"), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); - ok( jQuery("#en").is("[lang=\"en\"]"), "Check for attribute: Expected attribute lang to be 'en'" ); - ok( !jQuery("#en").is("[lang=\"de\"]"), "Check for attribute: Expected attribute lang to be 'en', not 'de'" ); - ok( jQuery("#text1").is("[type=\"text\"]"), "Check for attribute: Expected attribute type to be 'text'" ); - ok( !jQuery("#text1").is("[type=\"radio\"]"), "Check for attribute: Expected attribute type to be 'text', not 'radio'" ); - ok( jQuery("#text2").is(":disabled"), "Check for pseudoclass: Expected to be disabled" ); - ok( !jQuery("#text1").is(":disabled"), "Check for pseudoclass: Expected not disabled" ); - ok( jQuery("#radio2").is(":checked"), "Check for pseudoclass: Expected to be checked" ); - ok( !jQuery("#radio1").is(":checked"), "Check for pseudoclass: Expected not checked" ); - - ok( !jQuery("#foo").is(0), "Expected false for an invalid expression - 0" ); - ok( !jQuery("#foo").is(null), "Expected false for an invalid expression - null" ); - ok( !jQuery("#foo").is(""), "Expected false for an invalid expression - \"\"" ); - ok( !jQuery("#foo").is(undefined), "Expected false for an invalid expression - undefined" ); - ok( !jQuery("#foo").is({ plain: "object" }), "Check passing invalid object" ); +} ); + +test( "is(String|undefined)", function() { + expect( 23 ); + ok( jQuery( "#form" ).is( "form" ), "Check for element: A form must be a form" ); + ok( !jQuery( "#form" ).is( "div" ), "Check for element: A form is not a div" ); + ok( jQuery( "#mark" ).is( ".blog" ), "Check for class: Expected class 'blog'" ); + ok( !jQuery( "#mark" ).is( ".link" ), "Check for class: Did not expect class 'link'" ); + ok( jQuery( "#simon" ).is( ".blog.link" ), "Check for multiple classes: Expected classes 'blog' and 'link'" ); + ok( !jQuery( "#simon" ).is( ".blogTest" ), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); + ok( jQuery( "#en" ).is( "[lang=\"en\"]" ), "Check for attribute: Expected attribute lang to be 'en'" ); + ok( !jQuery( "#en" ).is( "[lang=\"de\"]" ), "Check for attribute: Expected attribute lang to be 'en', not 'de'" ); + ok( jQuery( "#text1" ).is( "[type=\"text\"]" ), "Check for attribute: Expected attribute type to be 'text'" ); + ok( !jQuery( "#text1" ).is( "[type=\"radio\"]" ), "Check for attribute: Expected attribute type to be 'text', not 'radio'" ); + ok( jQuery( "#text2" ).is( ":disabled" ), "Check for pseudoclass: Expected to be disabled" ); + ok( !jQuery( "#text1" ).is( ":disabled" ), "Check for pseudoclass: Expected not disabled" ); + ok( jQuery( "#radio2" ).is( ":checked" ), "Check for pseudoclass: Expected to be checked" ); + ok( !jQuery( "#radio1" ).is( ":checked" ), "Check for pseudoclass: Expected not checked" ); + + ok( !jQuery( "#foo" ).is( 0 ), "Expected false for an invalid expression - 0" ); + ok( !jQuery( "#foo" ).is( null ), "Expected false for an invalid expression - null" ); + ok( !jQuery( "#foo" ).is( "" ), "Expected false for an invalid expression - \"\"" ); + ok( !jQuery( "#foo" ).is( undefined ), "Expected false for an invalid expression - undefined" ); + ok( !jQuery( "#foo" ).is( { plain: "object" } ), "Check passing invalid object" ); // test is() with comma-separated expressions - ok( jQuery("#en").is("[lang=\"en\"],[lang=\"de\"]"), "Comma-separated; Check for lang attribute: Expect en or de" ); - ok( jQuery("#en").is("[lang=\"de\"],[lang=\"en\"]"), "Comma-separated; Check for lang attribute: Expect en or de" ); - ok( jQuery("#en").is("[lang=\"en\"] , [lang=\"de\"]"), "Comma-separated; Check for lang attribute: Expect en or de" ); - ok( jQuery("#en").is("[lang=\"de\"] , [lang=\"en\"]"), "Comma-separated; Check for lang attribute: Expect en or de" ); -}); + ok( jQuery( "#en" ).is( "[lang=\"en\"],[lang=\"de\"]" ), "Comma-separated; Check for lang attribute: Expect en or de" ); + ok( jQuery( "#en" ).is( "[lang=\"de\"],[lang=\"en\"]" ), "Comma-separated; Check for lang attribute: Expect en or de" ); + ok( jQuery( "#en" ).is( "[lang=\"en\"] , [lang=\"de\"]" ), "Comma-separated; Check for lang attribute: Expect en or de" ); + ok( jQuery( "#en" ).is( "[lang=\"de\"] , [lang=\"en\"]" ), "Comma-separated; Check for lang attribute: Expect en or de" ); +} ); -test("is() against non-elements (#10178)", function() { - expect(14); +test( "is() against non-elements (#10178)", function() { + expect( 14 ); var label, i, test, collection = jQuery( document ), tests = [ "a", "*" ], nonelements = { - text: document.createTextNode(""), - comment: document.createComment(""), + text: document.createTextNode( "" ), + comment: document.createComment( "" ), document: document, window: window, array: [], @@ -103,47 +103,47 @@ test("is() against non-elements (#10178)", function() { ok( !collection.is( test ), label + " does not match \"" + test + "\"" ); } } -}); - -test("is(jQuery)", function() { - expect(19); - ok( jQuery("#form").is( jQuery("form") ), "Check for element: A form is a form" ); - ok( !jQuery("#form").is( jQuery("div") ), "Check for element: A form is not a div" ); - ok( jQuery("#mark").is( jQuery(".blog") ), "Check for class: Expected class 'blog'" ); - ok( !jQuery("#mark").is( jQuery(".link") ), "Check for class: Did not expect class 'link'" ); - ok( jQuery("#simon").is( jQuery(".blog.link") ), "Check for multiple classes: Expected classes 'blog' and 'link'" ); - ok( !jQuery("#simon").is( jQuery(".blogTest") ), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); - ok( jQuery("#en").is( jQuery("[lang=\"en\"]") ), "Check for attribute: Expected attribute lang to be 'en'" ); - ok( !jQuery("#en").is( jQuery("[lang=\"de\"]") ), "Check for attribute: Expected attribute lang to be 'en', not 'de'" ); - ok( jQuery("#text1").is( jQuery("[type=\"text\"]") ), "Check for attribute: Expected attribute type to be 'text'" ); - ok( !jQuery("#text1").is( jQuery("[type=\"radio\"]") ), "Check for attribute: Expected attribute type to be 'text', not 'radio'" ); - ok( !jQuery("#text1").is( jQuery("input:disabled") ), "Check for pseudoclass: Expected not disabled" ); - ok( jQuery("#radio2").is( jQuery("input:checked") ), "Check for pseudoclass: Expected to be checked" ); - ok( !jQuery("#radio1").is( jQuery("input:checked") ), "Check for pseudoclass: Expected not checked" ); +} ); + +test( "is(jQuery)", function() { + expect( 19 ); + ok( jQuery( "#form" ).is( jQuery( "form" ) ), "Check for element: A form is a form" ); + ok( !jQuery( "#form" ).is( jQuery( "div" ) ), "Check for element: A form is not a div" ); + ok( jQuery( "#mark" ).is( jQuery( ".blog" ) ), "Check for class: Expected class 'blog'" ); + ok( !jQuery( "#mark" ).is( jQuery( ".link" ) ), "Check for class: Did not expect class 'link'" ); + ok( jQuery( "#simon" ).is( jQuery( ".blog.link" ) ), "Check for multiple classes: Expected classes 'blog' and 'link'" ); + ok( !jQuery( "#simon" ).is( jQuery( ".blogTest" ) ), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); + ok( jQuery( "#en" ).is( jQuery( "[lang=\"en\"]" ) ), "Check for attribute: Expected attribute lang to be 'en'" ); + ok( !jQuery( "#en" ).is( jQuery( "[lang=\"de\"]" ) ), "Check for attribute: Expected attribute lang to be 'en', not 'de'" ); + ok( jQuery( "#text1" ).is( jQuery( "[type=\"text\"]" ) ), "Check for attribute: Expected attribute type to be 'text'" ); + ok( !jQuery( "#text1" ).is( jQuery( "[type=\"radio\"]" ) ), "Check for attribute: Expected attribute type to be 'text', not 'radio'" ); + ok( !jQuery( "#text1" ).is( jQuery( "input:disabled" ) ), "Check for pseudoclass: Expected not disabled" ); + ok( jQuery( "#radio2" ).is( jQuery( "input:checked" ) ), "Check for pseudoclass: Expected to be checked" ); + ok( !jQuery( "#radio1" ).is( jQuery( "input:checked" ) ), "Check for pseudoclass: Expected not checked" ); // Some raw elements - ok( jQuery("#form").is( jQuery("#qunit-fixture form")[0] ), "Check for element: A form is a form" ); - ok( !jQuery("#form").is( jQuery("div")[0] ), "Check for element: A form is not a div" ); - ok( jQuery("#mark").is( jQuery(".blog")[0] ), "Check for class: Expected class 'blog'" ); - ok( !jQuery("#mark").is( jQuery(".link")[0] ), "Check for class: Did not expect class 'link'" ); - ok( jQuery("#simon").is( jQuery(".blog.link")[0] ), "Check for multiple classes: Expected classes 'blog' and 'link'" ); - ok( !jQuery("#simon").is( jQuery(".blogTest")[0] ), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); -}); + ok( jQuery( "#form" ).is( jQuery( "#qunit-fixture form" )[ 0 ] ), "Check for element: A form is a form" ); + ok( !jQuery( "#form" ).is( jQuery( "div" )[ 0 ] ), "Check for element: A form is not a div" ); + ok( jQuery( "#mark" ).is( jQuery( ".blog" )[ 0 ] ), "Check for class: Expected class 'blog'" ); + ok( !jQuery( "#mark" ).is( jQuery( ".link" )[ 0 ] ), "Check for class: Did not expect class 'link'" ); + ok( jQuery( "#simon" ).is( jQuery( ".blog.link" )[ 0 ] ), "Check for multiple classes: Expected classes 'blog' and 'link'" ); + ok( !jQuery( "#simon" ).is( jQuery( ".blogTest" )[ 0 ] ), "Check for multiple classes: Expected classes 'blog' and 'link', but not 'blogTest'" ); +} ); -test("is() with :has() selectors", function() { - expect(6); +test( "is() with :has() selectors", function() { + expect( 6 ); - ok( jQuery("#foo").is(":has(p)"), "Check for child: Expected a child 'p' element" ); - ok( !jQuery("#foo").is(":has(ul)"), "Check for child: Did not expect 'ul' element" ); - ok( jQuery("#foo").is(":has(p):has(a):has(code)"), "Check for childs: Expected 'p', 'a' and 'code' child elements" ); - ok( !jQuery("#foo").is(":has(p):has(a):has(code):has(ol)"), "Check for childs: Expected 'p', 'a' and 'code' child elements, but no 'ol'" ); + ok( jQuery( "#foo" ).is( ":has(p)" ), "Check for child: Expected a child 'p' element" ); + ok( !jQuery( "#foo" ).is( ":has(ul)" ), "Check for child: Did not expect 'ul' element" ); + ok( jQuery( "#foo" ).is( ":has(p):has(a):has(code)" ), "Check for childs: Expected 'p', 'a' and 'code' child elements" ); + ok( !jQuery( "#foo" ).is( ":has(p):has(a):has(code):has(ol)" ), "Check for childs: Expected 'p', 'a' and 'code' child elements, but no 'ol'" ); - ok( jQuery("#foo").is( jQuery("div:has(p)") ), "Check for child: Expected a child 'p' element" ); - ok( !jQuery("#foo").is( jQuery("div:has(ul)") ), "Check for child: Did not expect 'ul' element" ); -}); + ok( jQuery( "#foo" ).is( jQuery( "div:has(p)" ) ), "Check for child: Expected a child 'p' element" ); + ok( !jQuery( "#foo" ).is( jQuery( "div:has(ul)" ) ), "Check for child: Did not expect 'ul' element" ); +} ); -test("is() with positional selectors", function() { - expect(27); +test( "is() with positional selectors", function() { + expect( 27 ); var posp = jQuery( @@ -186,104 +186,103 @@ test("is() with positional selectors", function() { isit( "#posp em", "#posp a em:last", true ); isit( "#posp em", "#posp a em:eq(2)", false ); - ok( jQuery("#option1b").is("#select1 option:not(:first)"), "POS inside of :not() (#10970)" ); + ok( jQuery( "#option1b" ).is( "#select1 option:not(:first)" ), "POS inside of :not() (#10970)" ); - ok( jQuery( posp[0] ).is("p:last"), "context constructed from a single node (#13797)" ); - ok( !jQuery( posp[0] ).find("#firsta").is("a:first"), "context derived from a single node (#13797)" ); -}); + ok( jQuery( posp[ 0 ] ).is( "p:last" ), "context constructed from a single node (#13797)" ); + ok( !jQuery( posp[ 0 ] ).find( "#firsta" ).is( "a:first" ), "context derived from a single node (#13797)" ); +} ); -test("index()", function() { +test( "index()", function() { expect( 2 ); - equal( jQuery("#text2").index(), 2, "Returns the index of a child amongst its siblings" ); + equal( jQuery( "#text2" ).index(), 2, "Returns the index of a child amongst its siblings" ); - equal( jQuery("<div/>").index(), -1, "Node without parent returns -1" ); -}); + equal( jQuery( "<div/>" ).index(), -1, "Node without parent returns -1" ); +} ); -test("index(Object|String|undefined)", function() { - expect(16); +test( "index(Object|String|undefined)", function() { + expect( 16 ); - var elements = jQuery([window, document]), - inputElements = jQuery("#radio1,#radio2,#check1,#check2"); + var elements = jQuery( [ window, document ] ), + inputElements = jQuery( "#radio1,#radio2,#check1,#check2" ); // Passing a node - equal( elements.index(window), 0, "Check for index of elements" ); - equal( elements.index(document), 1, "Check for index of elements" ); - equal( inputElements.index(document.getElementById("radio1")), 0, "Check for index of elements" ); - equal( inputElements.index(document.getElementById("radio2")), 1, "Check for index of elements" ); - equal( inputElements.index(document.getElementById("check1")), 2, "Check for index of elements" ); - equal( inputElements.index(document.getElementById("check2")), 3, "Check for index of elements" ); - equal( inputElements.index(window), -1, "Check for not found index" ); - equal( inputElements.index(document), -1, "Check for not found index" ); + equal( elements.index( window ), 0, "Check for index of elements" ); + equal( elements.index( document ), 1, "Check for index of elements" ); + equal( inputElements.index( document.getElementById( "radio1" ) ), 0, "Check for index of elements" ); + equal( inputElements.index( document.getElementById( "radio2" ) ), 1, "Check for index of elements" ); + equal( inputElements.index( document.getElementById( "check1" ) ), 2, "Check for index of elements" ); + equal( inputElements.index( document.getElementById( "check2" ) ), 3, "Check for index of elements" ); + equal( inputElements.index( window ), -1, "Check for not found index" ); + equal( inputElements.index( document ), -1, "Check for not found index" ); // Passing a jQuery object // enabled since [5500] equal( elements.index( elements ), 0, "Pass in a jQuery object" ); - equal( elements.index( elements.eq(1) ), 1, "Pass in a jQuery object" ); - equal( jQuery("#form input[type='radio']").index( jQuery("#radio2") ), 1, "Pass in a jQuery object" ); + equal( elements.index( elements.eq( 1 ) ), 1, "Pass in a jQuery object" ); + equal( jQuery( "#form input[type='radio']" ).index( jQuery( "#radio2" ) ), 1, "Pass in a jQuery object" ); // Passing a selector or nothing // enabled since [6330] - equal( jQuery("#text2").index(), 2, "Check for index amongst siblings" ); - equal( jQuery("#form").children().eq(4).index(), 4, "Check for index amongst siblings" ); - equal( jQuery("#radio2").index("#form input[type='radio']") , 1, "Check for index within a selector" ); - equal( jQuery("#form input[type='radio']").index( jQuery("#radio2") ), 1, "Check for index within a selector" ); - equal( jQuery("#radio2").index("#form input[type='text']") , -1, "Check for index not found within a selector" ); -}); - -test("filter(Selector|undefined)", function() { - expect(9); - deepEqual( jQuery("#form input").filter(":checked").get(), q("radio2", "check1"), "filter(String)" ); - deepEqual( jQuery("p").filter("#ap, #sndp").get(), q("ap", "sndp"), "filter('String, String')" ); - deepEqual( jQuery("p").filter("#ap,#sndp").get(), q("ap", "sndp"), "filter('String,String')" ); - - deepEqual( jQuery("p").filter(null).get(), [], "filter(null) should return an empty jQuery object"); - deepEqual( jQuery("p").filter(undefined).get(), [], "filter(undefined) should return an empty jQuery object"); - deepEqual( jQuery("p").filter(0).get(), [], "filter(0) should return an empty jQuery object"); - deepEqual( jQuery("p").filter("").get(), [], "filter('') should return an empty jQuery object"); + equal( jQuery( "#text2" ).index(), 2, "Check for index amongst siblings" ); + equal( jQuery( "#form" ).children().eq( 4 ).index(), 4, "Check for index amongst siblings" ); + equal( jQuery( "#radio2" ).index( "#form input[type='radio']" ), 1, "Check for index within a selector" ); + equal( jQuery( "#form input[type='radio']" ).index( jQuery( "#radio2" ) ), 1, "Check for index within a selector" ); + equal( jQuery( "#radio2" ).index( "#form input[type='text']" ), -1, "Check for index not found within a selector" ); +} ); + +test( "filter(Selector|undefined)", function() { + expect( 9 ); + deepEqual( jQuery( "#form input" ).filter( ":checked" ).get(), q( "radio2", "check1" ), "filter(String)" ); + deepEqual( jQuery( "p" ).filter( "#ap, #sndp" ).get(), q( "ap", "sndp" ), "filter('String, String')" ); + deepEqual( jQuery( "p" ).filter( "#ap,#sndp" ).get(), q( "ap", "sndp" ), "filter('String,String')" ); + + deepEqual( jQuery( "p" ).filter( null ).get(), [], "filter(null) should return an empty jQuery object" ); + deepEqual( jQuery( "p" ).filter( undefined ).get(), [], "filter(undefined) should return an empty jQuery object" ); + deepEqual( jQuery( "p" ).filter( 0 ).get(), [], "filter(0) should return an empty jQuery object" ); + deepEqual( jQuery( "p" ).filter( "" ).get(), [], "filter('') should return an empty jQuery object" ); // using contents will get comments regular, text, and comment nodes - var j = jQuery("#nonnodes").contents(); - equal( j.filter("span").length, 1, "Check node,textnode,comment to filter the one span" ); - equal( j.filter("[name]").length, 0, "Check node,textnode,comment to filter the one span" ); -}); + var j = jQuery( "#nonnodes" ).contents(); + equal( j.filter( "span" ).length, 1, "Check node,textnode,comment to filter the one span" ); + equal( j.filter( "[name]" ).length, 0, "Check node,textnode,comment to filter the one span" ); +} ); -test("filter(Function)", function() { - expect(2); - - deepEqual( jQuery("#qunit-fixture p").filter(function() { - return !jQuery("a", this).length; - }).get(), q("sndp", "first"), "filter(Function)" ); +test( "filter(Function)", function() { + expect( 2 ); - deepEqual( jQuery("#qunit-fixture p").filter(function(i, elem) { return !jQuery("a", elem).length; }).get(), q("sndp", "first"), "filter(Function) using arg" ); -}); + deepEqual( jQuery( "#qunit-fixture p" ).filter( function() { + return !jQuery( "a", this ).length; + } ).get(), q( "sndp", "first" ), "filter(Function)" ); -test("filter(Element)", function() { - expect(1); + deepEqual( jQuery( "#qunit-fixture p" ).filter( function( i, elem ) { return !jQuery( "a", elem ).length; } ).get(), q( "sndp", "first" ), "filter(Function) using arg" ); +} ); - var element = document.getElementById("text1"); - deepEqual( jQuery("#form input").filter(element).get(), q("text1"), "filter(Element)" ); -}); +test( "filter(Element)", function() { + expect( 1 ); -test("filter(Array)", function() { - expect(1); + var element = document.getElementById( "text1" ); + deepEqual( jQuery( "#form input" ).filter( element ).get(), q( "text1" ), "filter(Element)" ); +} ); - var elements = [ document.getElementById("text1") ]; - deepEqual( jQuery("#form input").filter(elements).get(), q("text1"), "filter(Element)" ); -}); +test( "filter(Array)", function() { + expect( 1 ); -test("filter(jQuery)", function() { - expect(1); + var elements = [ document.getElementById( "text1" ) ]; + deepEqual( jQuery( "#form input" ).filter( elements ).get(), q( "text1" ), "filter(Element)" ); +} ); - var elements = jQuery("#text1"); - deepEqual( jQuery("#form input").filter(elements).get(), q("text1"), "filter(Element)" ); -}); +test( "filter(jQuery)", function() { + expect( 1 ); + var elements = jQuery( "#text1" ); + deepEqual( jQuery( "#form input" ).filter( elements ).get(), q( "text1" ), "filter(Element)" ); +} ); -test("filter() with positional selectors", function() { - expect(19); +test( "filter() with positional selectors", function() { + expect( 19 ); - var filterit = function(sel, filter, length) { + var filterit = function( sel, filter, length ) { equal( jQuery( sel ).filter( filter ).length, length, "jQuery( " + sel + " ).filter( " + filter + " )" ); }; @@ -298,7 +297,7 @@ test("filter() with positional selectors", function() { "<em></em>" + "</p>" ).appendTo( "#qunit-fixture" ); - filterit( "#posp", "#posp:first", 1); + filterit( "#posp", "#posp:first", 1 ); filterit( "#posp", "#posp:eq(2)", 0 ); filterit( "#posp", "#posp a:first", 0 ); @@ -321,364 +320,364 @@ test("filter() with positional selectors", function() { filterit( "#posp .seconda", "#posp a:gt(0)", 0 ); filterit( "#posp .seconda", "#posp a:lt(5)", 1 ); filterit( "#posp .seconda", "#posp a:lt(1)", 1 ); -}); +} ); -test("closest()", function() { +test( "closest()", function() { expect( 13 ); var jq; - deepEqual( jQuery("body").closest("body").get(), q("body"), "closest(body)" ); - deepEqual( jQuery("body").closest("html").get(), q("html"), "closest(html)" ); - deepEqual( jQuery("body").closest("div").get(), [], "closest(div)" ); - deepEqual( jQuery("#qunit-fixture").closest("span,#html").get(), q("html"), "closest(span,#html)" ); + deepEqual( jQuery( "body" ).closest( "body" ).get(), q( "body" ), "closest(body)" ); + deepEqual( jQuery( "body" ).closest( "html" ).get(), q( "html" ), "closest(html)" ); + deepEqual( jQuery( "body" ).closest( "div" ).get(), [], "closest(div)" ); + deepEqual( jQuery( "#qunit-fixture" ).closest( "span,#html" ).get(), q( "html" ), "closest(span,#html)" ); // Test .closest() limited by the context - jq = jQuery("#nothiddendivchild"); - deepEqual( jq.closest("html", document.body).get(), [], "Context limited." ); - deepEqual( jq.closest("body", document.body).get(), [], "Context limited." ); - deepEqual( jq.closest("#nothiddendiv", document.body).get(), q("nothiddendiv"), "Context not reached." ); + jq = jQuery( "#nothiddendivchild" ); + deepEqual( jq.closest( "html", document.body ).get(), [], "Context limited." ); + deepEqual( jq.closest( "body", document.body ).get(), [], "Context limited." ); + deepEqual( jq.closest( "#nothiddendiv", document.body ).get(), q( "nothiddendiv" ), "Context not reached." ); //Test that .closest() returns unique'd set - equal( jQuery("#qunit-fixture p").closest("#qunit-fixture").length, 1, "Closest should return a unique set" ); + equal( jQuery( "#qunit-fixture p" ).closest( "#qunit-fixture" ).length, 1, "Closest should return a unique set" ); // Test on disconnected node - equal( jQuery("<div><p></p></div>").find("p").closest("table").length, 0, "Make sure disconnected closest work." ); + equal( jQuery( "<div><p></p></div>" ).find( "p" ).closest( "table" ).length, 0, "Make sure disconnected closest work." ); // Bug #7369 - equal( jQuery("<div foo='bar'></div>").closest("[foo]").length, 1, "Disconnected nodes with attribute selector" ); - equal( jQuery("<div>text</div>").closest("[lang]").length, 0, "Disconnected nodes with text and non-existent attribute selector" ); + equal( jQuery( "<div foo='bar'></div>" ).closest( "[foo]" ).length, 1, "Disconnected nodes with attribute selector" ); + equal( jQuery( "<div>text</div>" ).closest( "[lang]" ).length, 0, "Disconnected nodes with text and non-existent attribute selector" ); - ok( !jQuery(document).closest("#foo").length, "Calling closest on a document fails silently" ); + ok( !jQuery( document ).closest( "#foo" ).length, "Calling closest on a document fails silently" ); - jq = jQuery("<div>text</div>"); - deepEqual( jq.contents().closest("*").get(), jq.get(), "Text node input (#13332)" ); -}); + jq = jQuery( "<div>text</div>" ); + deepEqual( jq.contents().closest( "*" ).get(), jq.get(), "Text node input (#13332)" ); +} ); -test("closest() with positional selectors", function() { +test( "closest() with positional selectors", function() { expect( 2 ); - deepEqual( jQuery("#qunit-fixture").closest("div:first").get(), [], "closest(div:first)" ); - deepEqual( jQuery("#qunit-fixture div").closest("body:first div:last").get(), q("fx-tests"), "closest(body:first div:last)" ); -}); - -test("closest(jQuery)", function() { - expect(8); - var $child = jQuery("#nothiddendivchild"), - $parent = jQuery("#nothiddendiv"), - $sibling = jQuery("#foo"), - $body = jQuery("body"); - ok( $child.closest( $parent ).is("#nothiddendiv"), "closest( jQuery('#nothiddendiv') )" ); - ok( $child.closest( $parent[0] ).is("#nothiddendiv"), "closest( jQuery('#nothiddendiv') ) :: node" ); - ok( $child.closest( $child ).is("#nothiddendivchild"), "child is included" ); - ok( $child.closest( $child[0] ).is("#nothiddendivchild"), "child is included :: node" ); - equal( $child.closest( document.createElement("div") ).length, 0, "created element is not related" ); + deepEqual( jQuery( "#qunit-fixture" ).closest( "div:first" ).get(), [], "closest(div:first)" ); + deepEqual( jQuery( "#qunit-fixture div" ).closest( "body:first div:last" ).get(), q( "fx-tests" ), "closest(body:first div:last)" ); +} ); + +test( "closest(jQuery)", function() { + expect( 8 ); + var $child = jQuery( "#nothiddendivchild" ), + $parent = jQuery( "#nothiddendiv" ), + $sibling = jQuery( "#foo" ), + $body = jQuery( "body" ); + ok( $child.closest( $parent ).is( "#nothiddendiv" ), "closest( jQuery('#nothiddendiv') )" ); + ok( $child.closest( $parent[ 0 ] ).is( "#nothiddendiv" ), "closest( jQuery('#nothiddendiv') ) :: node" ); + ok( $child.closest( $child ).is( "#nothiddendivchild" ), "child is included" ); + ok( $child.closest( $child[ 0 ] ).is( "#nothiddendivchild" ), "child is included :: node" ); + equal( $child.closest( document.createElement( "div" ) ).length, 0, "created element is not related" ); equal( $child.closest( $sibling ).length, 0, "Sibling not a parent of child" ); - equal( $child.closest( $sibling[0] ).length, 0, "Sibling not a parent of child :: node" ); - ok( $child.closest( $body.add($parent) ).is("#nothiddendiv"), "Closest ancestor retrieved." ); -}); - -test("not(Selector|undefined)", function() { - expect(11); - equal( jQuery("#qunit-fixture > p#ap > a").not("#google").length, 2, "not('selector')" ); - deepEqual( jQuery("p").not(".result").get(), q("firstp", "ap", "sndp", "en", "sap", "first"), "not('.class')" ); - deepEqual( jQuery("p").not("#ap, #sndp, .result").get(), q("firstp", "en", "sap", "first"), "not('selector, selector')" ); - - deepEqual( jQuery("#ap *").not("code").get(), q("google", "groups", "anchor1", "mark"), "not('tag selector')" ); - deepEqual( jQuery("#ap *").not("code, #mark").get(), q("google", "groups", "anchor1"), "not('tag, ID selector')" ); - deepEqual( jQuery("#ap *").not("#mark, code").get(), q("google", "groups", "anchor1"), "not('ID, tag selector')"); - - var all = jQuery("p").get(); - deepEqual( jQuery("p").not(null).get(), all, "not(null) should have no effect"); - deepEqual( jQuery("p").not(undefined).get(), all, "not(undefined) should have no effect"); - deepEqual( jQuery("p").not(0).get(), all, "not(0) should have no effect"); - deepEqual( jQuery("p").not("").get(), all, "not('') should have no effect"); + equal( $child.closest( $sibling[ 0 ] ).length, 0, "Sibling not a parent of child :: node" ); + ok( $child.closest( $body.add( $parent ) ).is( "#nothiddendiv" ), "Closest ancestor retrieved." ); +} ); + +test( "not(Selector|undefined)", function() { + expect( 11 ); + equal( jQuery( "#qunit-fixture > p#ap > a" ).not( "#google" ).length, 2, "not('selector')" ); + deepEqual( jQuery( "p" ).not( ".result" ).get(), q( "firstp", "ap", "sndp", "en", "sap", "first" ), "not('.class')" ); + deepEqual( jQuery( "p" ).not( "#ap, #sndp, .result" ).get(), q( "firstp", "en", "sap", "first" ), "not('selector, selector')" ); + + deepEqual( jQuery( "#ap *" ).not( "code" ).get(), q( "google", "groups", "anchor1", "mark" ), "not('tag selector')" ); + deepEqual( jQuery( "#ap *" ).not( "code, #mark" ).get(), q( "google", "groups", "anchor1" ), "not('tag, ID selector')" ); + deepEqual( jQuery( "#ap *" ).not( "#mark, code" ).get(), q( "google", "groups", "anchor1" ), "not('ID, tag selector')" ); + + var all = jQuery( "p" ).get(); + deepEqual( jQuery( "p" ).not( null ).get(), all, "not(null) should have no effect" ); + deepEqual( jQuery( "p" ).not( undefined ).get(), all, "not(undefined) should have no effect" ); + deepEqual( jQuery( "p" ).not( 0 ).get(), all, "not(0) should have no effect" ); + deepEqual( jQuery( "p" ).not( "" ).get(), all, "not('') should have no effect" ); deepEqual( - jQuery("#form option").not("option.emptyopt:contains('Nothing'),optgroup *,[value='1']").get(), - q("option1c", "option1d", "option2c", "option2d", "option3c", "option3d", "option3e", "option4d", "option4e", "option5a", "option5b"), + jQuery( "#form option" ).not( "option.emptyopt:contains('Nothing'),optgroup *,[value='1']" ).get(), + q( "option1c", "option1d", "option2c", "option2d", "option3c", "option3d", "option3e", "option4d", "option4e", "option5a", "option5b" ), "not('complex selector')" ); -}); +} ); -test("not(Element)", function() { - expect(1); +test( "not(Element)", function() { + expect( 1 ); - var selects = jQuery("#form select"); - deepEqual( selects.not( selects[1] ).get(), q("select1", "select3", "select4", "select5"), "filter out DOM element"); -}); + var selects = jQuery( "#form select" ); + deepEqual( selects.not( selects[ 1 ] ).get(), q( "select1", "select3", "select4", "select5" ), "filter out DOM element" ); +} ); -test("not(Function)", function() { - expect(1); +test( "not(Function)", function() { + expect( 1 ); - deepEqual( jQuery("#qunit-fixture p").not(function() { return jQuery("a", this).length; }).get(), q("sndp", "first"), "not(Function)" ); -}); + deepEqual( jQuery( "#qunit-fixture p" ).not( function() { return jQuery( "a", this ).length; } ).get(), q( "sndp", "first" ), "not(Function)" ); +} ); -test("not(Array)", function() { - expect(2); +test( "not(Array)", function() { + expect( 2 ); - equal( jQuery("#qunit-fixture > p#ap > a").not(document.getElementById("google")).length, 2, "not(DOMElement)" ); - equal( jQuery("p").not(document.getElementsByTagName("p")).length, 0, "not(Array-like DOM collection)" ); -}); + equal( jQuery( "#qunit-fixture > p#ap > a" ).not( document.getElementById( "google" ) ).length, 2, "not(DOMElement)" ); + equal( jQuery( "p" ).not( document.getElementsByTagName( "p" ) ).length, 0, "not(Array-like DOM collection)" ); +} ); -test("not(jQuery)", function() { +test( "not(jQuery)", function() { expect( 1 ); - deepEqual( jQuery("p").not(jQuery("#ap, #sndp, .result")).get(), q("firstp", "en", "sap", "first"), "not(jQuery)" ); -}); + deepEqual( jQuery( "p" ).not( jQuery( "#ap, #sndp, .result" ) ).get(), q( "firstp", "en", "sap", "first" ), "not(jQuery)" ); +} ); -test("has(Element)", function() { - expect(3); +test( "has(Element)", function() { + expect( 3 ); var obj, detached, multipleParent; - obj = jQuery("#qunit-fixture").has(jQuery("#sndp")[0]); - deepEqual( obj.get(), q("qunit-fixture"), "Keeps elements that have the element as a descendant" ); + obj = jQuery( "#qunit-fixture" ).has( jQuery( "#sndp" )[ 0 ] ); + deepEqual( obj.get(), q( "qunit-fixture" ), "Keeps elements that have the element as a descendant" ); - detached = jQuery("<a><b><i/></b></a>"); - deepEqual( detached.has( detached.find("i")[0] ).get(), detached.get(), "...Even when detached" ); + detached = jQuery( "<a><b><i/></b></a>" ); + deepEqual( detached.has( detached.find( "i" )[ 0 ] ).get(), detached.get(), "...Even when detached" ); - multipleParent = jQuery("#qunit-fixture, #header").has(jQuery("#sndp")[0]); - deepEqual( multipleParent.get(), q("qunit-fixture"), "Does not include elements that do not have the element as a descendant" ); -}); + multipleParent = jQuery( "#qunit-fixture, #header" ).has( jQuery( "#sndp" )[ 0 ] ); + deepEqual( multipleParent.get(), q( "qunit-fixture" ), "Does not include elements that do not have the element as a descendant" ); +} ); -test("has(Selector)", function() { +test( "has(Selector)", function() { expect( 5 ); var obj, detached, multipleParent, multipleHas; - obj = jQuery("#qunit-fixture").has("#sndp"); - deepEqual( obj.get(), q("qunit-fixture"), "Keeps elements that have any element matching the selector as a descendant" ); + obj = jQuery( "#qunit-fixture" ).has( "#sndp" ); + deepEqual( obj.get(), q( "qunit-fixture" ), "Keeps elements that have any element matching the selector as a descendant" ); - detached = jQuery("<a><b><i/></b></a>"); - deepEqual( detached.has("i").get(), detached.get(), "...Even when detached" ); + detached = jQuery( "<a><b><i/></b></a>" ); + deepEqual( detached.has( "i" ).get(), detached.get(), "...Even when detached" ); - multipleParent = jQuery("#qunit-fixture, #header").has("#sndp"); - deepEqual( multipleParent.get(), q("qunit-fixture"), "Does not include elements that do not have the element as a descendant" ); + multipleParent = jQuery( "#qunit-fixture, #header" ).has( "#sndp" ); + deepEqual( multipleParent.get(), q( "qunit-fixture" ), "Does not include elements that do not have the element as a descendant" ); - multipleParent = jQuery("#select1, #select2, #select3").has("#option1a, #option3a"); - deepEqual( multipleParent.get(), q("select1", "select3"), "Multiple contexts are checks correctly" ); + multipleParent = jQuery( "#select1, #select2, #select3" ).has( "#option1a, #option3a" ); + deepEqual( multipleParent.get(), q( "select1", "select3" ), "Multiple contexts are checks correctly" ); - multipleHas = jQuery("#qunit-fixture").has("#sndp, #first"); - deepEqual( multipleHas.get(), q("qunit-fixture"), "Only adds elements once" ); -}); + multipleHas = jQuery( "#qunit-fixture" ).has( "#sndp, #first" ); + deepEqual( multipleHas.get(), q( "qunit-fixture" ), "Only adds elements once" ); +} ); -test("has(Arrayish)", function() { - expect(4); +test( "has(Arrayish)", function() { + expect( 4 ); var simple, detached, multipleParent, multipleHas; - simple = jQuery("#qunit-fixture").has(jQuery("#sndp")); - deepEqual( simple.get(), q("qunit-fixture"), "Keeps elements that have any element in the jQuery list as a descendant" ); - - detached = jQuery("<a><b><i/></b></a>"); - deepEqual( detached.has( detached.find("i") ).get(), detached.get(), "...Even when detached" ); - - multipleParent = jQuery("#qunit-fixture, #header").has(jQuery("#sndp")); - deepEqual( multipleParent.get(), q("qunit-fixture"), "Does not include elements that do not have an element in the jQuery list as a descendant" ); - - multipleHas = jQuery("#qunit-fixture").has(jQuery("#sndp, #first")); - deepEqual( multipleHas.get(), q("qunit-fixture"), "Only adds elements once" ); -}); - -test("addBack()", function() { - expect(5); - deepEqual( jQuery("#en").siblings().addBack().get(), q("sndp", "en", "sap"), "Check for siblings and self" ); - deepEqual( jQuery("#foo").children().addBack().get(), q("foo", "sndp", "en", "sap"), "Check for children and self" ); - deepEqual( jQuery("#sndp, #en").parent().addBack().get(), q("foo","sndp","en"), "Check for parent and self" ); - deepEqual( jQuery("#groups").parents("p, div").addBack().get(), q("qunit-fixture", "ap", "groups"), "Check for parents and self" ); - deepEqual( jQuery("#select1 > option").filter(":first-child").addBack(":last-child").get(), q("option1a", "option1d"), "Should contain the last elems plus the *filtered* prior set elements" ); -}); - -test("siblings([String])", function() { - expect(6); - deepEqual( jQuery("#en").siblings().get(), q("sndp", "sap"), "Check for siblings" ); - deepEqual( jQuery("#nonnodes").contents().eq(1).siblings().get(), q("nonnodesElement"), "Check for text node siblings" ); - deepEqual( jQuery("#foo").siblings("form, b").get(), q("form", "floatTest", "lengthtest", "name-tests", "testForm"), "Check for multiple filters" ); - - var set = q("sndp", "en", "sap"); - deepEqual( jQuery("#en, #sndp").siblings().get(), set, "Check for unique results from siblings" ); - deepEqual( jQuery("#option5a").siblings("option[data-attr]").get(), q("option5c"), "Has attribute selector in siblings (#9261)" ); - equal( jQuery("<a/>").siblings().length, 0, "Detached elements have no siblings (#11370)" ); -}); - -test("siblings([String]) - jQuery only", function() { - expect(2); - deepEqual( jQuery("#sndp").siblings(":has(code)").get(), q("sap"), "Check for filtered siblings (has code child element)" ); - deepEqual( jQuery("#sndp").siblings(":has(a)").get(), q("en", "sap"), "Check for filtered siblings (has anchor child element)" ); -}); - -test("children([String])", function() { - expect(2); - deepEqual( jQuery("#foo").children().get(), q("sndp", "en", "sap"), "Check for children" ); - deepEqual( jQuery("#foo").children("#en, #sap").get(), q("en", "sap"), "Check for multiple filters" ); -}); - -test("children([String]) - jQuery only", function() { - expect(1); - deepEqual( jQuery("#foo").children(":has(code)").get(), q("sndp", "sap"), "Check for filtered children" ); -}); - -test("parent([String])", function() { - expect(6); + simple = jQuery( "#qunit-fixture" ).has( jQuery( "#sndp" ) ); + deepEqual( simple.get(), q( "qunit-fixture" ), "Keeps elements that have any element in the jQuery list as a descendant" ); + + detached = jQuery( "<a><b><i/></b></a>" ); + deepEqual( detached.has( detached.find( "i" ) ).get(), detached.get(), "...Even when detached" ); + + multipleParent = jQuery( "#qunit-fixture, #header" ).has( jQuery( "#sndp" ) ); + deepEqual( multipleParent.get(), q( "qunit-fixture" ), "Does not include elements that do not have an element in the jQuery list as a descendant" ); + + multipleHas = jQuery( "#qunit-fixture" ).has( jQuery( "#sndp, #first" ) ); + deepEqual( multipleHas.get(), q( "qunit-fixture" ), "Only adds elements once" ); +} ); + +test( "addBack()", function() { + expect( 5 ); + deepEqual( jQuery( "#en" ).siblings().addBack().get(), q( "sndp", "en", "sap" ), "Check for siblings and self" ); + deepEqual( jQuery( "#foo" ).children().addBack().get(), q( "foo", "sndp", "en", "sap" ), "Check for children and self" ); + deepEqual( jQuery( "#sndp, #en" ).parent().addBack().get(), q( "foo", "sndp", "en" ), "Check for parent and self" ); + deepEqual( jQuery( "#groups" ).parents( "p, div" ).addBack().get(), q( "qunit-fixture", "ap", "groups" ), "Check for parents and self" ); + deepEqual( jQuery( "#select1 > option" ).filter( ":first-child" ).addBack( ":last-child" ).get(), q( "option1a", "option1d" ), "Should contain the last elems plus the *filtered* prior set elements" ); +} ); + +test( "siblings([String])", function() { + expect( 6 ); + deepEqual( jQuery( "#en" ).siblings().get(), q( "sndp", "sap" ), "Check for siblings" ); + deepEqual( jQuery( "#nonnodes" ).contents().eq( 1 ).siblings().get(), q( "nonnodesElement" ), "Check for text node siblings" ); + deepEqual( jQuery( "#foo" ).siblings( "form, b" ).get(), q( "form", "floatTest", "lengthtest", "name-tests", "testForm" ), "Check for multiple filters" ); + + var set = q( "sndp", "en", "sap" ); + deepEqual( jQuery( "#en, #sndp" ).siblings().get(), set, "Check for unique results from siblings" ); + deepEqual( jQuery( "#option5a" ).siblings( "option[data-attr]" ).get(), q( "option5c" ), "Has attribute selector in siblings (#9261)" ); + equal( jQuery( "<a/>" ).siblings().length, 0, "Detached elements have no siblings (#11370)" ); +} ); + +test( "siblings([String]) - jQuery only", function() { + expect( 2 ); + deepEqual( jQuery( "#sndp" ).siblings( ":has(code)" ).get(), q( "sap" ), "Check for filtered siblings (has code child element)" ); + deepEqual( jQuery( "#sndp" ).siblings( ":has(a)" ).get(), q( "en", "sap" ), "Check for filtered siblings (has anchor child element)" ); +} ); + +test( "children([String])", function() { + expect( 2 ); + deepEqual( jQuery( "#foo" ).children().get(), q( "sndp", "en", "sap" ), "Check for children" ); + deepEqual( jQuery( "#foo" ).children( "#en, #sap" ).get(), q( "en", "sap" ), "Check for multiple filters" ); +} ); + +test( "children([String]) - jQuery only", function() { + expect( 1 ); + deepEqual( jQuery( "#foo" ).children( ":has(code)" ).get(), q( "sndp", "sap" ), "Check for filtered children" ); +} ); + +test( "parent([String])", function() { + expect( 6 ); var $el; - equal( jQuery("#groups").parent()[0].id, "ap", "Simple parent check" ); - equal( jQuery("#groups").parent("p")[0].id, "ap", "Filtered parent check" ); - equal( jQuery("#groups").parent("div").length, 0, "Filtered parent check, no match" ); - equal( jQuery("#groups").parent("div, p")[0].id, "ap", "Check for multiple filters" ); - deepEqual( jQuery("#en, #sndp").parent().get(), q("foo"), "Check for unique results from parent" ); - - $el = jQuery("<div>text</div>"); - strictEqual( $el.contents().parent()[0], $el[0], "Check for parent of text node (#13265)" ); -}); - -test("parents([String])", function() { - expect(6); - equal( jQuery("#groups").parents()[0].id, "ap", "Simple parents check" ); - deepEqual( jQuery("#nonnodes").contents().eq(1).parents().eq(0).get(), q("nonnodes"), "Text node parents check" ); - equal( jQuery("#groups").parents("p")[0].id, "ap", "Filtered parents check" ); - equal( jQuery("#groups").parents("div")[0].id, "qunit-fixture", "Filtered parents check2" ); - deepEqual( jQuery("#groups").parents("p, div").get(), q("ap", "qunit-fixture"), "Check for multiple filters" ); - deepEqual( jQuery("#en, #sndp").parents().get(), q("foo", "qunit-fixture", "dl", "body", "html"), "Check for unique results from parents" ); -}); - -test("parentsUntil([String])", function() { - expect(10); - - var parents = jQuery("#groups").parents(); - - deepEqual( jQuery("#groups").parentsUntil().get(), parents.get(), "parentsUntil with no selector (nextAll)" ); - deepEqual( jQuery("#groups").parentsUntil(".foo").get(), parents.get(), "parentsUntil with invalid selector (nextAll)" ); - deepEqual( jQuery("#groups").parentsUntil("#html").get(), parents.slice(0, -1).get(), "Simple parentsUntil check" ); - equal( jQuery("#groups").parentsUntil("#ap").length, 0, "Simple parentsUntil check" ); - deepEqual( jQuery("#nonnodes").contents().eq(1).parentsUntil("#html").eq(0).get(), q("nonnodes"), "Text node parentsUntil check" ); - deepEqual( jQuery("#groups").parentsUntil("#html, #body").get(), parents.slice( 0, 3 ).get(), "Less simple parentsUntil check" ); - deepEqual( jQuery("#groups").parentsUntil("#html", "div").get(), jQuery("#qunit-fixture").get(), "Filtered parentsUntil check" ); - deepEqual( jQuery("#groups").parentsUntil("#html", "p,div,dl").get(), parents.slice( 0, 3 ).get(), "Multiple-filtered parentsUntil check" ); - equal( jQuery("#groups").parentsUntil("#html", "span").length, 0, "Filtered parentsUntil check, no match" ); - deepEqual( jQuery("#groups, #ap").parentsUntil("#html", "p,div,dl").get(), parents.slice( 0, 3 ).get(), "Multi-source, multiple-filtered parentsUntil check" ); -}); - -test("next([String])", function() { - expect(6); - equal( jQuery("#ap").next()[0].id, "foo", "Simple next check" ); - equal( jQuery("<div>text<a id='element'></a></div>").contents().eq(0).next().attr("id"), "element", "Text node next check" ); - equal( jQuery("#ap").next("div")[0].id, "foo", "Filtered next check" ); - equal( jQuery("#ap").next("p").length, 0, "Filtered next check, no match" ); - equal( jQuery("#ap").next("div, p")[0].id, "foo", "Multiple filters" ); - equal( jQuery("body").next().length, 0, "Simple next check, no match" ); -}); - -test("prev([String])", function() { - expect(5); - equal( jQuery("#foo").prev()[0].id, "ap", "Simple prev check" ); - deepEqual( jQuery("#nonnodes").contents().eq(1).prev().get(), q("nonnodesElement"), "Text node prev check" ); - equal( jQuery("#foo").prev("p")[0].id, "ap", "Filtered prev check" ); - equal( jQuery("#foo").prev("div").length, 0, "Filtered prev check, no match" ); - equal( jQuery("#foo").prev("p, div")[0].id, "ap", "Multiple filters" ); -}); - -test("nextAll([String])", function() { - expect(5); - - var elems = jQuery("#form").children(); - - deepEqual( jQuery("#label-for").nextAll().get(), elems.slice(1).get(), "Simple nextAll check" ); - equal( jQuery("<div>text<a id='element'></a></div>").contents().eq(0).nextAll().attr("id"), "element", "Text node nextAll check" ); - deepEqual( jQuery("#label-for").nextAll("input").get(), elems.slice(1).filter("input").get(), "Filtered nextAll check" ); - deepEqual( jQuery("#label-for").nextAll("input,select").get(), elems.slice(1).filter("input,select").get(), "Multiple-filtered nextAll check" ); - deepEqual( jQuery("#label-for, #hidden1").nextAll("input,select").get(), elems.slice(1).filter("input,select").get(), "Multi-source, multiple-filtered nextAll check" ); -}); - -test("prevAll([String])", function() { - expect(5); - - var elems = jQuery( jQuery("#form").children().slice(0, 12).get().reverse() ); - - deepEqual( jQuery("#area1").prevAll().get(), elems.get(), "Simple prevAll check" ); - deepEqual( jQuery("#nonnodes").contents().eq(1).prevAll().get(), q("nonnodesElement"), "Text node prevAll check" ); - deepEqual( jQuery("#area1").prevAll("input").get(), elems.filter("input").get(), "Filtered prevAll check" ); - deepEqual( jQuery("#area1").prevAll("input,select").get(), elems.filter("input,select").get(), "Multiple-filtered prevAll check" ); - deepEqual( jQuery("#area1, #hidden1").prevAll("input,select").get(), elems.filter("input,select").get(), "Multi-source, multiple-filtered prevAll check" ); -}); - -test("nextUntil([String])", function() { - expect(12); - - var elems = jQuery("#form").children().slice( 2, 12 ); - - deepEqual( jQuery("#text1").nextUntil().get(), jQuery("#text1").nextAll().get(), "nextUntil with no selector (nextAll)" ); - equal( jQuery("<div>text<a id='element'></a></div>").contents().eq(0).nextUntil().attr("id"), "element", "Text node nextUntil with no selector (nextAll)" ); - deepEqual( jQuery("#text1").nextUntil(".foo").get(), jQuery("#text1").nextAll().get(), "nextUntil with invalid selector (nextAll)" ); - deepEqual( jQuery("#text1").nextUntil("#area1").get(), elems.get(), "Simple nextUntil check" ); - equal( jQuery("#text1").nextUntil("#text2").length, 0, "Simple nextUntil check" ); - deepEqual( jQuery("#text1").nextUntil("#area1, #radio1").get(), jQuery("#text1").next().get(), "Less simple nextUntil check" ); - deepEqual( jQuery("#text1").nextUntil("#area1", "input").get(), elems.not("button").get(), "Filtered nextUntil check" ); - deepEqual( jQuery("#text1").nextUntil("#area1", "button").get(), elems.not("input").get(), "Filtered nextUntil check" ); - deepEqual( jQuery("#text1").nextUntil("#area1", "button,input").get(), elems.get(), "Multiple-filtered nextUntil check" ); - equal( jQuery("#text1").nextUntil("#area1", "div").length, 0, "Filtered nextUntil check, no match" ); - deepEqual( jQuery("#text1, #hidden1").nextUntil("#area1", "button,input").get(), elems.get(), "Multi-source, multiple-filtered nextUntil check" ); - - deepEqual( jQuery("#text1").nextUntil("[class=foo]").get(), jQuery("#text1").nextAll().get(), "Non-element nodes must be skipped, since they have no attributes" ); -}); - -test("prevUntil([String])", function() { - expect(11); - - var elems = jQuery("#area1").prevAll(); - - deepEqual( jQuery("#area1").prevUntil().get(), elems.get(), "prevUntil with no selector (prevAll)" ); - deepEqual( jQuery("#nonnodes").contents().eq(1).prevUntil().get(), q("nonnodesElement"), "Text node prevUntil with no selector (prevAll)" ); - deepEqual( jQuery("#area1").prevUntil(".foo").get(), elems.get(), "prevUntil with invalid selector (prevAll)" ); - deepEqual( jQuery("#area1").prevUntil("label").get(), elems.slice(0, -1).get(), "Simple prevUntil check" ); - equal( jQuery("#area1").prevUntil("#button").length, 0, "Simple prevUntil check" ); - deepEqual( jQuery("#area1").prevUntil("label, #search").get(), jQuery("#area1").prev().get(), "Less simple prevUntil check" ); - deepEqual( jQuery("#area1").prevUntil("label", "input").get(), elems.slice(0, -1).not("button").get(), "Filtered prevUntil check" ); - deepEqual( jQuery("#area1").prevUntil("label", "button").get(), elems.slice(0, -1).not("input").get(), "Filtered prevUntil check" ); - deepEqual( jQuery("#area1").prevUntil("label", "button,input").get(), elems.slice(0, -1).get(), "Multiple-filtered prevUntil check" ); - equal( jQuery("#area1").prevUntil("label", "div").length, 0, "Filtered prevUntil check, no match" ); - deepEqual( jQuery("#area1, #hidden1").prevUntil("label", "button,input").get(), elems.slice(0, -1).get(), "Multi-source, multiple-filtered prevUntil check" ); -}); - -test("contents()", function() { - expect(12); + equal( jQuery( "#groups" ).parent()[ 0 ].id, "ap", "Simple parent check" ); + equal( jQuery( "#groups" ).parent( "p" )[ 0 ].id, "ap", "Filtered parent check" ); + equal( jQuery( "#groups" ).parent( "div" ).length, 0, "Filtered parent check, no match" ); + equal( jQuery( "#groups" ).parent( "div, p" )[ 0 ].id, "ap", "Check for multiple filters" ); + deepEqual( jQuery( "#en, #sndp" ).parent().get(), q( "foo" ), "Check for unique results from parent" ); + + $el = jQuery( "<div>text</div>" ); + strictEqual( $el.contents().parent()[ 0 ], $el[ 0 ], "Check for parent of text node (#13265)" ); +} ); + +test( "parents([String])", function() { + expect( 6 ); + equal( jQuery( "#groups" ).parents()[ 0 ].id, "ap", "Simple parents check" ); + deepEqual( jQuery( "#nonnodes" ).contents().eq( 1 ).parents().eq( 0 ).get(), q( "nonnodes" ), "Text node parents check" ); + equal( jQuery( "#groups" ).parents( "p" )[ 0 ].id, "ap", "Filtered parents check" ); + equal( jQuery( "#groups" ).parents( "div" )[ 0 ].id, "qunit-fixture", "Filtered parents check2" ); + deepEqual( jQuery( "#groups" ).parents( "p, div" ).get(), q( "ap", "qunit-fixture" ), "Check for multiple filters" ); + deepEqual( jQuery( "#en, #sndp" ).parents().get(), q( "foo", "qunit-fixture", "dl", "body", "html" ), "Check for unique results from parents" ); +} ); + +test( "parentsUntil([String])", function() { + expect( 10 ); + + var parents = jQuery( "#groups" ).parents(); + + deepEqual( jQuery( "#groups" ).parentsUntil().get(), parents.get(), "parentsUntil with no selector (nextAll)" ); + deepEqual( jQuery( "#groups" ).parentsUntil( ".foo" ).get(), parents.get(), "parentsUntil with invalid selector (nextAll)" ); + deepEqual( jQuery( "#groups" ).parentsUntil( "#html" ).get(), parents.slice( 0, -1 ).get(), "Simple parentsUntil check" ); + equal( jQuery( "#groups" ).parentsUntil( "#ap" ).length, 0, "Simple parentsUntil check" ); + deepEqual( jQuery( "#nonnodes" ).contents().eq( 1 ).parentsUntil( "#html" ).eq( 0 ).get(), q( "nonnodes" ), "Text node parentsUntil check" ); + deepEqual( jQuery( "#groups" ).parentsUntil( "#html, #body" ).get(), parents.slice( 0, 3 ).get(), "Less simple parentsUntil check" ); + deepEqual( jQuery( "#groups" ).parentsUntil( "#html", "div" ).get(), jQuery( "#qunit-fixture" ).get(), "Filtered parentsUntil check" ); + deepEqual( jQuery( "#groups" ).parentsUntil( "#html", "p,div,dl" ).get(), parents.slice( 0, 3 ).get(), "Multiple-filtered parentsUntil check" ); + equal( jQuery( "#groups" ).parentsUntil( "#html", "span" ).length, 0, "Filtered parentsUntil check, no match" ); + deepEqual( jQuery( "#groups, #ap" ).parentsUntil( "#html", "p,div,dl" ).get(), parents.slice( 0, 3 ).get(), "Multi-source, multiple-filtered parentsUntil check" ); +} ); + +test( "next([String])", function() { + expect( 6 ); + equal( jQuery( "#ap" ).next()[ 0 ].id, "foo", "Simple next check" ); + equal( jQuery( "<div>text<a id='element'></a></div>" ).contents().eq( 0 ).next().attr( "id" ), "element", "Text node next check" ); + equal( jQuery( "#ap" ).next( "div" )[ 0 ].id, "foo", "Filtered next check" ); + equal( jQuery( "#ap" ).next( "p" ).length, 0, "Filtered next check, no match" ); + equal( jQuery( "#ap" ).next( "div, p" )[ 0 ].id, "foo", "Multiple filters" ); + equal( jQuery( "body" ).next().length, 0, "Simple next check, no match" ); +} ); + +test( "prev([String])", function() { + expect( 5 ); + equal( jQuery( "#foo" ).prev()[ 0 ].id, "ap", "Simple prev check" ); + deepEqual( jQuery( "#nonnodes" ).contents().eq( 1 ).prev().get(), q( "nonnodesElement" ), "Text node prev check" ); + equal( jQuery( "#foo" ).prev( "p" )[ 0 ].id, "ap", "Filtered prev check" ); + equal( jQuery( "#foo" ).prev( "div" ).length, 0, "Filtered prev check, no match" ); + equal( jQuery( "#foo" ).prev( "p, div" )[ 0 ].id, "ap", "Multiple filters" ); +} ); + +test( "nextAll([String])", function() { + expect( 5 ); + + var elems = jQuery( "#form" ).children(); + + deepEqual( jQuery( "#label-for" ).nextAll().get(), elems.slice( 1 ).get(), "Simple nextAll check" ); + equal( jQuery( "<div>text<a id='element'></a></div>" ).contents().eq( 0 ).nextAll().attr( "id" ), "element", "Text node nextAll check" ); + deepEqual( jQuery( "#label-for" ).nextAll( "input" ).get(), elems.slice( 1 ).filter( "input" ).get(), "Filtered nextAll check" ); + deepEqual( jQuery( "#label-for" ).nextAll( "input,select" ).get(), elems.slice( 1 ).filter( "input,select" ).get(), "Multiple-filtered nextAll check" ); + deepEqual( jQuery( "#label-for, #hidden1" ).nextAll( "input,select" ).get(), elems.slice( 1 ).filter( "input,select" ).get(), "Multi-source, multiple-filtered nextAll check" ); +} ); + +test( "prevAll([String])", function() { + expect( 5 ); + + var elems = jQuery( jQuery( "#form" ).children().slice( 0, 12 ).get().reverse() ); + + deepEqual( jQuery( "#area1" ).prevAll().get(), elems.get(), "Simple prevAll check" ); + deepEqual( jQuery( "#nonnodes" ).contents().eq( 1 ).prevAll().get(), q( "nonnodesElement" ), "Text node prevAll check" ); + deepEqual( jQuery( "#area1" ).prevAll( "input" ).get(), elems.filter( "input" ).get(), "Filtered prevAll check" ); + deepEqual( jQuery( "#area1" ).prevAll( "input,select" ).get(), elems.filter( "input,select" ).get(), "Multiple-filtered prevAll check" ); + deepEqual( jQuery( "#area1, #hidden1" ).prevAll( "input,select" ).get(), elems.filter( "input,select" ).get(), "Multi-source, multiple-filtered prevAll check" ); +} ); + +test( "nextUntil([String])", function() { + expect( 12 ); + + var elems = jQuery( "#form" ).children().slice( 2, 12 ); + + deepEqual( jQuery( "#text1" ).nextUntil().get(), jQuery( "#text1" ).nextAll().get(), "nextUntil with no selector (nextAll)" ); + equal( jQuery( "<div>text<a id='element'></a></div>" ).contents().eq( 0 ).nextUntil().attr( "id" ), "element", "Text node nextUntil with no selector (nextAll)" ); + deepEqual( jQuery( "#text1" ).nextUntil( ".foo" ).get(), jQuery( "#text1" ).nextAll().get(), "nextUntil with invalid selector (nextAll)" ); + deepEqual( jQuery( "#text1" ).nextUntil( "#area1" ).get(), elems.get(), "Simple nextUntil check" ); + equal( jQuery( "#text1" ).nextUntil( "#text2" ).length, 0, "Simple nextUntil check" ); + deepEqual( jQuery( "#text1" ).nextUntil( "#area1, #radio1" ).get(), jQuery( "#text1" ).next().get(), "Less simple nextUntil check" ); + deepEqual( jQuery( "#text1" ).nextUntil( "#area1", "input" ).get(), elems.not( "button" ).get(), "Filtered nextUntil check" ); + deepEqual( jQuery( "#text1" ).nextUntil( "#area1", "button" ).get(), elems.not( "input" ).get(), "Filtered nextUntil check" ); + deepEqual( jQuery( "#text1" ).nextUntil( "#area1", "button,input" ).get(), elems.get(), "Multiple-filtered nextUntil check" ); + equal( jQuery( "#text1" ).nextUntil( "#area1", "div" ).length, 0, "Filtered nextUntil check, no match" ); + deepEqual( jQuery( "#text1, #hidden1" ).nextUntil( "#area1", "button,input" ).get(), elems.get(), "Multi-source, multiple-filtered nextUntil check" ); + + deepEqual( jQuery( "#text1" ).nextUntil( "[class=foo]" ).get(), jQuery( "#text1" ).nextAll().get(), "Non-element nodes must be skipped, since they have no attributes" ); +} ); + +test( "prevUntil([String])", function() { + expect( 11 ); + + var elems = jQuery( "#area1" ).prevAll(); + + deepEqual( jQuery( "#area1" ).prevUntil().get(), elems.get(), "prevUntil with no selector (prevAll)" ); + deepEqual( jQuery( "#nonnodes" ).contents().eq( 1 ).prevUntil().get(), q( "nonnodesElement" ), "Text node prevUntil with no selector (prevAll)" ); + deepEqual( jQuery( "#area1" ).prevUntil( ".foo" ).get(), elems.get(), "prevUntil with invalid selector (prevAll)" ); + deepEqual( jQuery( "#area1" ).prevUntil( "label" ).get(), elems.slice( 0, -1 ).get(), "Simple prevUntil check" ); + equal( jQuery( "#area1" ).prevUntil( "#button" ).length, 0, "Simple prevUntil check" ); + deepEqual( jQuery( "#area1" ).prevUntil( "label, #search" ).get(), jQuery( "#area1" ).prev().get(), "Less simple prevUntil check" ); + deepEqual( jQuery( "#area1" ).prevUntil( "label", "input" ).get(), elems.slice( 0, -1 ).not( "button" ).get(), "Filtered prevUntil check" ); + deepEqual( jQuery( "#area1" ).prevUntil( "label", "button" ).get(), elems.slice( 0, -1 ).not( "input" ).get(), "Filtered prevUntil check" ); + deepEqual( jQuery( "#area1" ).prevUntil( "label", "button,input" ).get(), elems.slice( 0, -1 ).get(), "Multiple-filtered prevUntil check" ); + equal( jQuery( "#area1" ).prevUntil( "label", "div" ).length, 0, "Filtered prevUntil check, no match" ); + deepEqual( jQuery( "#area1, #hidden1" ).prevUntil( "label", "button,input" ).get(), elems.slice( 0, -1 ).get(), "Multi-source, multiple-filtered prevUntil check" ); +} ); + +test( "contents()", function() { + expect( 12 ); var ibody, c; - equal( jQuery("#ap").contents().length, 9, "Check element contents" ); - ok( jQuery("#iframe").contents()[0], "Check existence of IFrame document" ); - ibody = jQuery("#loadediframe").contents()[0].body; + equal( jQuery( "#ap" ).contents().length, 9, "Check element contents" ); + ok( jQuery( "#iframe" ).contents()[ 0 ], "Check existence of IFrame document" ); + ibody = jQuery( "#loadediframe" ).contents()[ 0 ].body; ok( ibody, "Check existence of IFrame body" ); - equal( jQuery("span", ibody).text(), "span text", "Find span in IFrame and check its text" ); + equal( jQuery( "span", ibody ).text(), "span text", "Find span in IFrame and check its text" ); - jQuery(ibody).append("<div>init text</div>"); - equal( jQuery("div", ibody).length, 2, "Check the original div and the new div are in IFrame" ); + jQuery( ibody ).append( "<div>init text</div>" ); + equal( jQuery( "div", ibody ).length, 2, "Check the original div and the new div are in IFrame" ); - equal( jQuery("div", ibody).last().text(), "init text", "Add text to div in IFrame" ); + equal( jQuery( "div", ibody ).last().text(), "init text", "Add text to div in IFrame" ); - jQuery("div", ibody).last().text("div text"); - equal( jQuery("div", ibody).last().text(), "div text", "Add text to div in IFrame" ); + jQuery( "div", ibody ).last().text( "div text" ); + equal( jQuery( "div", ibody ).last().text(), "div text", "Add text to div in IFrame" ); - jQuery("div", ibody).last().remove(); - equal( jQuery("div", ibody).length, 1, "Delete the div and check only one div left in IFrame" ); + jQuery( "div", ibody ).last().remove(); + equal( jQuery( "div", ibody ).length, 1, "Delete the div and check only one div left in IFrame" ); - equal( jQuery("div", ibody).text(), "span text", "Make sure the correct div is still left after deletion in IFrame" ); + equal( jQuery( "div", ibody ).text(), "span text", "Make sure the correct div is still left after deletion in IFrame" ); - jQuery("<table/>", ibody).append("<tr><td>cell</td></tr>").appendTo(ibody); - jQuery("table", ibody).remove(); - equal( jQuery("div", ibody).length, 1, "Check for JS error on add and delete of a table in IFrame" ); + jQuery( "<table/>", ibody ).append( "<tr><td>cell</td></tr>" ).appendTo( ibody ); + jQuery( "table", ibody ).remove(); + equal( jQuery( "div", ibody ).length, 1, "Check for JS error on add and delete of a table in IFrame" ); // using contents will get comments regular, text, and comment nodes - c = jQuery("#nonnodes").contents().contents(); + c = jQuery( "#nonnodes" ).contents().contents(); equal( c.length, 1, "Check node,textnode,comment contents is just one" ); - equal( c[0].nodeValue, "hi", "Check node,textnode,comment contents is just the one from span" ); -}); + equal( c[ 0 ].nodeValue, "hi", "Check node,textnode,comment contents is just the one from span" ); +} ); -test("sort direction", function() { +test( "sort direction", function() { expect( 12 ); - var elems = jQuery("#ap, #select1 > *, #moretests > form"), + var elems = jQuery( "#ap, #select1 > *, #moretests > form" ), methodDirections = { parent: false, parents: true, @@ -698,99 +697,98 @@ test("sort direction", function() { var actual = elems[ method ]().get(), forward = jQuery.uniqueSort( [].concat( actual ) ); deepEqual( actual, reversed ? forward.reverse() : forward, "Correct sort direction for " + method ); - }); -}); + } ); +} ); -test("add(String selector)", function() { +test( "add(String selector)", function() { expect( 2 ); var divs; deepEqual( - jQuery("#sndp").add("#en").add("#sap").toArray(), - q("sndp", "en", "sap"), + jQuery( "#sndp" ).add( "#en" ).add( "#sap" ).toArray(), + q( "sndp", "en", "sap" ), "Check elements from document" ); - divs = jQuery("<div/>").add("#sndp"); - ok( divs[0].parentNode, "Sort with the disconnected node last (started with disconnected first)." ); -}); + divs = jQuery( "<div/>" ).add( "#sndp" ); + ok( divs[ 0 ].parentNode, "Sort with the disconnected node last (started with disconnected first)." ); +} ); -test("add(String selector, String context)", function() { +test( "add(String selector, String context)", function() { expect( 1 ); deepEqual( - jQuery([]).add("div", "#nothiddendiv").toArray(), - q("nothiddendivchild"), + jQuery( [] ).add( "div", "#nothiddendiv" ).toArray(), + q( "nothiddendivchild" ), "Check elements from document" ); -}); +} ); -test("add(String html)", function() { +test( "add(String html)", function() { expect( 3 ); var x, - divs = jQuery("#sndp").add("<div/>"); + divs = jQuery( "#sndp" ).add( "<div/>" ); - ok( !divs[1].parentNode, "Sort with the disconnected node last." ); + ok( !divs[ 1 ].parentNode, "Sort with the disconnected node last." ); + x = jQuery( [] ).add( "<p id='x1'>xxx</p>" ).add( "<p id='x2'>xxx</p>" ); + equal( x[ 0 ].id, "x1", "Check detached element1" ); + equal( x[ 1 ].id, "x2", "Check detached element2" ); +} ); - x = jQuery([]).add("<p id='x1'>xxx</p>").add("<p id='x2'>xxx</p>"); - equal( x[0].id, "x1", "Check detached element1" ); - equal( x[1].id, "x2", "Check detached element2" ); -}); - -test("add(jQuery)", function() { +test( "add(jQuery)", function() { expect( 4 ); var x, - tmp = jQuery("<div/>"); + tmp = jQuery( "<div/>" ); - x = jQuery([]) + x = jQuery( [] ) .add( - jQuery("<p id='x1'>xxx</p>").appendTo(tmp) + jQuery( "<p id='x1'>xxx</p>" ).appendTo( tmp ) ) .add( - jQuery("<p id='x2'>xxx</p>").appendTo(tmp) + jQuery( "<p id='x2'>xxx</p>" ).appendTo( tmp ) ); - equal( x[0].id, "x1", "Check element1 in detached parent" ); - equal( x[1].id, "x2", "Check element2 in detached parent" ); + equal( x[ 0 ].id, "x1", "Check element1 in detached parent" ); + equal( x[ 1 ].id, "x2", "Check element2 in detached parent" ); - x = jQuery([]) + x = jQuery( [] ) .add( - jQuery("<p id='x1'>xxx</p>") + jQuery( "<p id='x1'>xxx</p>" ) ) .add( - jQuery("<p id='x2'>xxx</p>") + jQuery( "<p id='x2'>xxx</p>" ) ); - equal( x[0].id, "x1", "Check detached element1" ); - equal( x[1].id, "x2", "Check detached element2" ); -}); + equal( x[ 0 ].id, "x1", "Check detached element1" ); + equal( x[ 1 ].id, "x2", "Check detached element2" ); +} ); -test("add(Element)", function() { +test( "add(Element)", function() { expect( 2 ); var x, - tmp = jQuery("<div/>"); + tmp = jQuery( "<div/>" ); - x = jQuery([]).add(jQuery("<p id='x1'>xxx</p>").appendTo(tmp)[0]).add(jQuery("<p id='x2'>xxx</p>").appendTo(tmp)[0]); - equal( x[0].id, "x1", "Check on-the-fly element1" ); - equal( x[1].id, "x2", "Check on-the-fly element2" ); -}); + x = jQuery( [] ).add( jQuery( "<p id='x1'>xxx</p>" ).appendTo( tmp )[ 0 ] ).add( jQuery( "<p id='x2'>xxx</p>" ).appendTo( tmp )[ 0 ] ); + equal( x[ 0 ].id, "x1", "Check on-the-fly element1" ); + equal( x[ 1 ].id, "x2", "Check on-the-fly element2" ); +} ); -test("add(Array elements)", function() { +test( "add(Array elements)", function() { expect( 1 ); deepEqual( - jQuery("#sndp").add( jQuery("#en")[0] ).add( jQuery("#sap") ).toArray(), - q("sndp", "en", "sap"), + jQuery( "#sndp" ).add( jQuery( "#en" )[ 0 ] ).add( jQuery( "#sap" ) ).toArray(), + q( "sndp", "en", "sap" ), "Check elements from document" ); -}); +} ); -test("add(Window)", function() { +test( "add(Window)", function() { expect( 1 ); var frame1 = document.createElement( "iframe" ), @@ -802,25 +800,25 @@ test("add(Window)", function() { // Window is tricky because it is a lot like an array, even Array#slice will // turn it into a multi-item array. - equal( jQuery([]).add( window ).length, 1, "Add a window" ); + equal( jQuery( [] ).add( window ).length, 1, "Add a window" ); document.body.removeChild( frame1 ); document.body.removeChild( frame2 ); -}); +} ); -test("add(NodeList|undefined|HTMLFormElement|HTMLSelectElement)", function() { +test( "add(NodeList|undefined|HTMLFormElement|HTMLSelectElement)", function() { expect( 4 ); var ps, notDefined; - ps = document.getElementsByTagName("p"); + ps = document.getElementsByTagName( "p" ); - equal( jQuery([]).add(ps).length, ps.length, "Add a NodeList" ); + equal( jQuery( [] ).add( ps ).length, ps.length, "Add a NodeList" ); - equal( jQuery([]).add(notDefined).length, 0, "Adding undefined adds nothing" ); + equal( jQuery( [] ).add( notDefined ).length, 0, "Adding undefined adds nothing" ); - equal( jQuery([]).add( document.getElementById("form") ).length, 1, "Add a form" ); - equal( jQuery([]).add( document.getElementById("select1") ).length, 1, "Add a select" ); + equal( jQuery( [] ).add( document.getElementById( "form" ) ).length, 1, "Add a form" ); + equal( jQuery( [] ).add( document.getElementById( "select1" ) ).length, 1, "Add a select" ); // We no longer support .add(form.elements), unfortunately. // There is no way, in browsers, to reliably determine the difference @@ -831,53 +829,53 @@ test("add(NodeList|undefined|HTMLFormElement|HTMLSelectElement)", function() { // For the time being, we're discontinuing support for jQuery(form.elements) since it's ambiguous in IE // use jQuery([]).add(form.elements) instead. //equal( jQuery([]).add(jQuery("#form")[0].elements).length, jQuery(jQuery("#form")[0].elements).length, "Array in constructor must equals array in add()" ); -}); +} ); -test("add(String, Context)", function() { - expect(6); +test( "add(String, Context)", function() { + expect( 6 ); deepEqual( jQuery( "#firstp" ).add( "#ap" ).get(), q( "firstp", "ap" ), "Add selector to selector " ); - deepEqual( jQuery( document.getElementById("firstp") ).add( "#ap" ).get(), q( "firstp", "ap" ), "Add gEBId to selector" ); - deepEqual( jQuery( document.getElementById("firstp") ).add( document.getElementById("ap") ).get(), q( "firstp", "ap" ), "Add gEBId to gEBId" ); + deepEqual( jQuery( document.getElementById( "firstp" ) ).add( "#ap" ).get(), q( "firstp", "ap" ), "Add gEBId to selector" ); + deepEqual( jQuery( document.getElementById( "firstp" ) ).add( document.getElementById( "ap" ) ).get(), q( "firstp", "ap" ), "Add gEBId to gEBId" ); - var ctx = document.getElementById("firstp"); + var ctx = document.getElementById( "firstp" ); deepEqual( jQuery( "#firstp" ).add( "#ap", ctx ).get(), q( "firstp" ), "Add selector to selector " ); - deepEqual( jQuery( document.getElementById("firstp") ).add( "#ap", ctx ).get(), q( "firstp" ), "Add gEBId to selector, not in context" ); - deepEqual( jQuery( document.getElementById("firstp") ).add( "#ap", document.getElementsByTagName("body")[0] ).get(), q( "firstp", "ap" ), "Add gEBId to selector, in context" ); -}); + deepEqual( jQuery( document.getElementById( "firstp" ) ).add( "#ap", ctx ).get(), q( "firstp" ), "Add gEBId to selector, not in context" ); + deepEqual( jQuery( document.getElementById( "firstp" ) ).add( "#ap", document.getElementsByTagName( "body" )[ 0 ] ).get(), q( "firstp", "ap" ), "Add gEBId to selector, in context" ); +} ); -test("eq('-1') #10616", function() { - expect(3); +test( "eq('-1') #10616", function() { + expect( 3 ); var $divs = jQuery( "div" ); equal( $divs.eq( -1 ).length, 1, "The number -1 returns a selection that has length 1" ); equal( $divs.eq( "-1" ).length, 1, "The string '-1' returns a selection that has length 1" ); deepEqual( $divs.eq( "-1" ), $divs.eq( -1 ), "String and number -1 match" ); -}); +} ); -test("index(no arg) #10977", function() { - expect(2); +test( "index(no arg) #10977", function() { + expect( 2 ); var $list, fragment, div; - $list = jQuery("<ul id='indextest'><li class='zero'>THIS ONE</li><li class='one'>a</li><li class='two'>b</li><li class='three'>c</li></ul>"); - jQuery("#qunit-fixture").append( $list ); - strictEqual ( jQuery( "#indextest li.zero" ).first().index() , 0, "No Argument Index Check" ); + $list = jQuery( "<ul id='indextest'><li class='zero'>THIS ONE</li><li class='one'>a</li><li class='two'>b</li><li class='three'>c</li></ul>" ); + jQuery( "#qunit-fixture" ).append( $list ); + strictEqual ( jQuery( "#indextest li.zero" ).first().index(), 0, "No Argument Index Check" ); $list.remove(); fragment = document.createDocumentFragment(); - div = fragment.appendChild( document.createElement("div") ); + div = fragment.appendChild( document.createElement( "div" ) ); equal( jQuery( div ).index(), 0, "If jQuery#index called on element whose parent is fragment, it still should work correctly" ); -}); +} ); -test("traversing non-elements with attribute filters (#12523)", function() { - expect(5); +test( "traversing non-elements with attribute filters (#12523)", function() { + expect( 5 ); - var nonnodes = jQuery("#nonnodes").contents(); + var nonnodes = jQuery( "#nonnodes" ).contents(); - equal( nonnodes.filter("[id]").length, 1, ".filter" ); - equal( nonnodes.find("[id]").length, 0, ".find" ); - strictEqual( nonnodes.is("[id]"), true, ".is" ); - deepEqual( nonnodes.closest("[id='nonnodes']").get(), q("nonnodes"), ".closest" ); - deepEqual( nonnodes.parents("[id='nonnodes']").get(), q("nonnodes"), ".parents" ); -}); + equal( nonnodes.filter( "[id]" ).length, 1, ".filter" ); + equal( nonnodes.find( "[id]" ).length, 0, ".find" ); + strictEqual( nonnodes.is( "[id]" ), true, ".is" ); + deepEqual( nonnodes.closest( "[id='nonnodes']" ).get(), q( "nonnodes" ), ".closest" ); + deepEqual( nonnodes.parents( "[id='nonnodes']" ).get(), q( "nonnodes" ), ".parents" ); +} ); diff --git a/test/unit/wrap.js b/test/unit/wrap.js index 3e0d1f8ea..6d0760f1d 100644 --- a/test/unit/wrap.js +++ b/test/unit/wrap.js @@ -1,4 +1,4 @@ -(function() { +( function() { if ( !jQuery.fn.wrap ) { // no wrap module return; @@ -6,7 +6,7 @@ if ( !jQuery.fn.wrap ) { // no wrap module module( "wrap", { teardown: moduleTeardown -}); +} ); // See test/unit/manipulation.js for explanation about these 2 functions function manipulationBareObj( value ) { @@ -26,29 +26,39 @@ function testWrap( val ) { var defaultText, result, j, i, cacheLength; defaultText = "Try them out:"; - result = jQuery("#first").wrap( val("<div class='red'><span></span></div>") ).text(); + result = jQuery( "#first" ).wrap( val( "<div class='red'><span></span></div>" ) ).text(); - equal( defaultText, result, "Check for wrapping of on-the-fly html" ); - ok( jQuery("#first").parent().parent().is(".red"), "Check if wrapper has class 'red'" ); + equal( + defaultText, result, "Check for wrapping of on-the-fly html" + ); + ok( jQuery( "#first" ).parent().parent().is( ".red" ), "Check if wrapper has class 'red'" ); - result = jQuery("#first").wrap( val(document.getElementById("empty")) ).parent(); - ok( result.is("ol"), "Check for element wrapping" ); - equal( result.text(), defaultText, "Check for element wrapping" ); + result = jQuery( "#first" ).wrap( val( document.getElementById( "empty" ) ) ).parent(); + ok( result.is( "ol" ), "Check for element wrapping" ); + equal( + result.text(), defaultText, "Check for element wrapping" + ); - jQuery("#check1").on( "click", function() { + jQuery( "#check1" ).on( "click", function() { var checkbox = this; ok( checkbox.checked, "Checkbox's state is erased after wrap() action, see #769" ); - jQuery( checkbox ).wrap( val("<div id='c1' style='display:none;'></div>") ); + jQuery( checkbox ).wrap( val( "<div id='c1' style='display:none;'></div>" ) ); ok( checkbox.checked, "Checkbox's state is erased after wrap() action, see #769" ); - }).prop( "checked", false )[ 0 ].click(); + } ).prop( "checked", false )[ 0 ].click(); // using contents will get comments regular, text, and comment nodes - j = jQuery("#nonnodes").contents(); - j.wrap( val("<i></i>") ); - - equal( jQuery("#nonnodes > i").length, 3, "Check node,textnode,comment wraps ok" ); - equal( jQuery("#nonnodes > i").text(), j.text(), "Check node,textnode,comment wraps doesn't hurt text" ); + j = jQuery( "#nonnodes" ).contents(); + j.wrap( val( "<i></i>" ) ); + + equal( + jQuery( "#nonnodes > i" ).length, 3, "Check node,textnode,comment wraps ok" + ); + equal( + jQuery( "#nonnodes > i" ).text(), + j.text(), + "Check node,textnode,comment wraps doesn't hurt text" + ); // Try wrapping a disconnected node cacheLength = 0; @@ -56,80 +66,108 @@ function testWrap( val ) { cacheLength++; } - j = jQuery("<label/>").wrap( val("<li/>") ); - equal( j[ 0 ] .nodeName.toUpperCase(), "LABEL", "Element is a label" ); - equal( j[ 0 ].parentNode.nodeName.toUpperCase(), "LI", "Element has been wrapped" ); + j = jQuery( "<label/>" ).wrap( val( "<li/>" ) ); + equal( + j[ 0 ] .nodeName.toUpperCase(), "LABEL", "Element is a label" + ); + equal( + j[ 0 ].parentNode.nodeName.toUpperCase(), "LI", "Element has been wrapped" + ); for ( i in jQuery.cache ) { cacheLength--; } - equal( cacheLength, 0, "No memory leak in jQuery.cache (bug #7165)" ); + equal( + cacheLength, 0, "No memory leak in jQuery.cache (bug #7165)" + ); // Wrap an element containing a text node - j = jQuery("<span/>").wrap("<div>test</div>"); - equal( j[ 0 ].previousSibling.nodeType, 3, "Make sure the previous node is a text element" ); - equal( j[ 0 ].parentNode.nodeName.toUpperCase(), "DIV", "And that we're in the div element." ); + j = jQuery( "<span/>" ).wrap( "<div>test</div>" ); + equal( + j[ 0 ].previousSibling.nodeType, 3, "Make sure the previous node is a text element" + ); + equal( + j[ 0 ].parentNode.nodeName.toUpperCase(), "DIV", "And that we're in the div element." + ); // Try to wrap an element with multiple elements (should fail) - j = jQuery("<div><span></span></div>").children().wrap("<p></p><div></div>"); - equal( j[ 0 ].parentNode.parentNode.childNodes.length, 1, "There should only be one element wrapping." ); - equal( j.length, 1, "There should only be one element (no cloning)." ); - equal( j[ 0 ].parentNode.nodeName.toUpperCase(), "P", "The span should be in the paragraph." ); + j = jQuery( "<div><span></span></div>" ).children().wrap( "<p></p><div></div>" ); + equal( + j[ 0 ].parentNode.parentNode.childNodes.length, + 1, + "There should only be one element wrapping." + ); + equal( + j.length, 1, "There should only be one element (no cloning)." + ); + equal( + j[ 0 ].parentNode.nodeName.toUpperCase(), "P", "The span should be in the paragraph." + ); // Wrap an element with a jQuery set - j = jQuery("<span/>").wrap( jQuery("<div></div>") ); - equal( j[ 0 ].parentNode.nodeName.toLowerCase(), "div", "Wrapping works." ); + j = jQuery( "<span/>" ).wrap( jQuery( "<div></div>" ) ); + equal( + j[ 0 ].parentNode.nodeName.toLowerCase(), "div", "Wrapping works." + ); // Wrap an element with a jQuery set and event - result = jQuery("<div></div>").on( "click", function() { + result = jQuery( "<div></div>" ).on( "click", function() { ok( true, "Event triggered." ); // Remove handlers on detached elements result.off(); - jQuery(this).off(); - }); + jQuery( this ).off(); + } ); - j = jQuery("<span/>").wrap( result ); - equal( j[ 0 ].parentNode.nodeName.toLowerCase(), "div", "Wrapping works." ); + j = jQuery( "<span/>" ).wrap( result ); + equal( + j[ 0 ].parentNode.nodeName.toLowerCase(), "div", "Wrapping works." + ); - j.parent().trigger("click"); + j.parent().trigger( "click" ); } test( "wrap(String|Element)", function() { testWrap( manipulationBareObj ); -}); +} ); test( "wrap(Function)", function() { testWrap( manipulationFunctionReturningObj ); -}); +} ); test( "wrap(Function) with index (#10177)", function() { var expectedIndex = 0, - targets = jQuery("#qunit-fixture p"); + targets = jQuery( "#qunit-fixture p" ); expect( targets.length ); - targets.wrap(function(i) { - equal( i, expectedIndex, "Check if the provided index (" + i + ") is as expected (" + expectedIndex + ")" ); + targets.wrap( function( i ) { + equal( + i, + expectedIndex, + "Check if the provided index (" + i + ") is as expected (" + expectedIndex + ")" + ); expectedIndex++; return "<div id='wrap_index_'" + i + "'></div>"; - }); -}); + } ); +} ); test( "wrap(String) consecutive elements (#10177)", function() { - var targets = jQuery("#qunit-fixture p"); + var targets = jQuery( "#qunit-fixture p" ); expect( targets.length * 2 ); - targets.wrap("<div class='wrapper'></div>"); + targets.wrap( "<div class='wrapper'></div>" ); - targets.each(function() { - var $this = jQuery(this); + targets.each( function() { + var $this = jQuery( this ); - ok( $this.parent().is(".wrapper"), "Check each elements parent is correct (.wrapper)" ); - equal( $this.siblings().length, 0, "Each element should be wrapped individually" ); - }); -}); + ok( $this.parent().is( ".wrapper" ), "Check each elements parent is correct (.wrapper)" ); + equal( + $this.siblings().length, 0, "Each element should be wrapped individually" + ); + } ); +} ); test( "wrapAll(String)", function() { @@ -137,85 +175,107 @@ test( "wrapAll(String)", function() { var prev, p, result; - prev = jQuery("#firstp")[ 0 ].previousSibling; - p = jQuery("#firstp,#first")[ 0 ].parentNode; - result = jQuery("#firstp,#first").wrapAll( "<div class='red'><div class='tmp'></div></div>" ); + prev = jQuery( "#firstp" )[ 0 ].previousSibling; + p = jQuery( "#firstp,#first" )[ 0 ].parentNode; + result = jQuery( "#firstp,#first" ).wrapAll( "<div class='red'><div class='tmp'></div></div>" ); - equal( result.parent().length, 1, "Check for wrapping of on-the-fly html" ); - ok( jQuery("#first").parent().parent().is(".red"), "Check if wrapper has class 'red'" ); - ok( jQuery("#firstp").parent().parent().is(".red"), "Check if wrapper has class 'red'" ); - equal( jQuery("#first").parent().parent()[ 0 ].previousSibling, prev, "Correct Previous Sibling" ); - equal( jQuery("#first").parent().parent()[ 0 ].parentNode, p, "Correct Parent" ); + equal( + result.parent().length, 1, "Check for wrapping of on-the-fly html" + ); + ok( jQuery( "#first" ).parent().parent().is( ".red" ), "Check if wrapper has class 'red'" ); + ok( jQuery( "#firstp" ).parent().parent().is( ".red" ), "Check if wrapper has class 'red'" ); + equal( + jQuery( "#first" ).parent().parent()[ 0 ].previousSibling, prev, "Correct Previous Sibling" + ); + equal( + jQuery( "#first" ).parent().parent()[ 0 ].parentNode, p, "Correct Parent" + ); -}); +} ); test( "wrapAll(Function)", function() { expect( 5 ); var prev = jQuery( "#firstp" )[ 0 ].previousSibling, p = jQuery( "#firstp,#first" )[ 0 ].parentNode, - result = jQuery( "#firstp,#first" ).wrapAll(function() { + result = jQuery( "#firstp,#first" ).wrapAll( function() { return "<div class='red'><div class='tmp'></div></div>"; - }); + } ); - equal( result.parent().length, 1, "Check for wrapping of on-the-fly html" ); + equal( + result.parent().length, 1, "Check for wrapping of on-the-fly html" + ); ok( jQuery( "#first" ).parent().parent().is( ".red" ), "Check if wrapper has class 'red'" ); ok( jQuery( "#firstp" ).parent().parent().is( ".red" ), "Check if wrapper has class 'red'" ); ok( jQuery( "#first" ).parent().parent().parent().is( p ), "Correct Parent" ); - strictEqual( jQuery( "#first" ).parent().parent()[ 0 ].previousSibling, prev, "Correct Previous Sibling" ); -}); + strictEqual( + jQuery( "#first" ).parent().parent()[ 0 ].previousSibling, prev, "Correct Previous Sibling" + ); +} ); test( "wrapAll(Function) check execution characteristics", function() { expect( 3 ); var i = 0; - jQuery( "non-existent" ).wrapAll(function() { + jQuery( "non-existent" ).wrapAll( function() { i++; return ""; - }); + } ); ok( !i, "should not execute function argument if target element does not exist" ); - jQuery( "#firstp" ).wrapAll(function( index ) { - strictEqual( this, jQuery( "#firstp" )[ 0 ], "context must be the first found element" ); - strictEqual( index, undefined, "index argument should not be included in function execution" ); - }); -}); + jQuery( "#firstp" ).wrapAll( function( index ) { + strictEqual( + this, jQuery( "#firstp" )[ 0 ], "context must be the first found element" + ); + strictEqual( + index, undefined, "index argument should not be included in function execution" + ); + } ); +} ); test( "wrapAll(Function)", function() { expect( 5 ); var prev = jQuery( "#firstp" )[ 0 ].previousSibling, p = jQuery( "#firstp,#first" )[ 0 ].parentNode, - result = jQuery( "#firstp,#first" ).wrapAll(function() { + result = jQuery( "#firstp,#first" ).wrapAll( function() { return "<div class='red'><div class='tmp'></div></div>"; - }); + } ); - equal( result.parent().length, 1, "Check for wrapping of on-the-fly html" ); + equal( + result.parent().length, 1, "Check for wrapping of on-the-fly html" + ); ok( jQuery( "#first" ).parent().parent().is( ".red" ), "Check if wrapper has class 'red'" ); ok( jQuery( "#firstp" ).parent().parent().is( ".red" ), "Check if wrapper has class 'red'" ); ok( jQuery( "#first" ).parent().parent().parent().is( p ), "Correct Parent" ); - strictEqual( jQuery( "#first" ).parent().parent()[ 0 ].previousSibling, prev, "Correct Previous Sibling" ); -}); + strictEqual( + jQuery( "#first" ).parent().parent()[ 0 ].previousSibling, prev, "Correct Previous Sibling" + ); +} ); test( "wrapAll(Function) check execution characteristics", function() { expect( 3 ); var i = 0; - jQuery( "non-existent" ).wrapAll(function() { + jQuery( "non-existent" ).wrapAll( function() { i++; return ""; - }); + } ); ok( !i, "should not execute function argument if target element does not exist" ); - jQuery( "#firstp" ).wrapAll(function( index ) { - strictEqual( this, jQuery( "#firstp" )[ 0 ], "context must be the first found element" ); - strictEqual( index, undefined, "index argument should not be included in function execution" ); - }); -}); + jQuery( "#firstp" ).wrapAll( function( index ) { + strictEqual( + this, jQuery( "#firstp" )[ 0 ], "context must be the first found element" + ); + strictEqual( + index, undefined, "index argument should not be included in function execution" + ); + } ); +} ); test( "wrapAll(Element)", function() { @@ -223,14 +283,20 @@ test( "wrapAll(Element)", function() { var prev, p; - prev = jQuery("#firstp")[ 0 ].previousSibling; - p = jQuery("#first")[ 0 ].parentNode; - jQuery("#firstp,#first").wrapAll( document.getElementById("empty") ); - - equal( jQuery("#first").parent()[ 0 ], jQuery("#firstp").parent()[ 0 ], "Same Parent" ); - equal( jQuery("#first").parent()[ 0 ].previousSibling, prev, "Correct Previous Sibling" ); - equal( jQuery("#first").parent()[ 0 ].parentNode, p, "Correct Parent" ); -}); + prev = jQuery( "#firstp" )[ 0 ].previousSibling; + p = jQuery( "#first" )[ 0 ].parentNode; + jQuery( "#firstp,#first" ).wrapAll( document.getElementById( "empty" ) ); + + equal( + jQuery( "#first" ).parent()[ 0 ], jQuery( "#firstp" ).parent()[ 0 ], "Same Parent" + ); + equal( + jQuery( "#first" ).parent()[ 0 ].previousSibling, prev, "Correct Previous Sibling" + ); + equal( + jQuery( "#first" ).parent()[ 0 ].parentNode, p, "Correct Parent" + ); +} ); test( "wrapInner(String)", function() { @@ -238,37 +304,53 @@ test( "wrapInner(String)", function() { var num; - num = jQuery("#first").children().length; - jQuery("#first").wrapInner( "<div class='red'><div id='tmp'></div></div>" ); - - equal( jQuery("#first").children().length, 1, "Only one child" ); - ok( jQuery("#first").children().is(".red"), "Verify Right Element" ); - equal( jQuery("#first").children().children().children().length, num, "Verify Elements Intact" ); - - num = jQuery("#first").html("foo<div>test</div><div>test2</div>").children().length; - jQuery("#first").wrapInner( "<div class='red'><div id='tmp'></div></div>" ); - equal( jQuery("#first").children().length, 1, "Only one child" ); - ok( jQuery("#first").children().is(".red"), "Verify Right Element" ); - equal( jQuery("#first").children().children().children().length, num, "Verify Elements Intact" ); -}); + num = jQuery( "#first" ).children().length; + jQuery( "#first" ).wrapInner( "<div class='red'><div id='tmp'></div></div>" ); + + equal( + jQuery( "#first" ).children().length, 1, "Only one child" + ); + ok( jQuery( "#first" ).children().is( ".red" ), "Verify Right Element" ); + equal( + jQuery( "#first" ).children().children().children().length, num, "Verify Elements Intact" + ); + + num = jQuery( "#first" ).html( "foo<div>test</div><div>test2</div>" ).children().length; + jQuery( "#first" ).wrapInner( "<div class='red'><div id='tmp'></div></div>" ); + equal( + jQuery( "#first" ).children().length, 1, "Only one child" + ); + ok( jQuery( "#first" ).children().is( ".red" ), "Verify Right Element" ); + equal( + jQuery( "#first" ).children().children().children().length, num, "Verify Elements Intact" + ); +} ); test( "wrapInner(Element)", function() { expect( 5 ); var num, - div = jQuery("<div/>"); - - num = jQuery("#first").children().length; - jQuery("#first").wrapInner( document.getElementById("empty") ); - equal( jQuery("#first").children().length, 1, "Only one child" ); - ok( jQuery("#first").children().is("#empty"), "Verify Right Element" ); - equal( jQuery("#first").children().children().length, num, "Verify Elements Intact" ); + div = jQuery( "<div/>" ); + + num = jQuery( "#first" ).children().length; + jQuery( "#first" ).wrapInner( document.getElementById( "empty" ) ); + equal( + jQuery( "#first" ).children().length, 1, "Only one child" + ); + ok( jQuery( "#first" ).children().is( "#empty" ), "Verify Right Element" ); + equal( + jQuery( "#first" ).children().children().length, num, "Verify Elements Intact" + ); div.wrapInner( "<span></span>" ); - equal( div.children().length, 1, "The contents were wrapped." ); - equal( div.children()[ 0 ].nodeName.toLowerCase(), "span", "A span was inserted." ); -}); + equal( + div.children().length, 1, "The contents were wrapped." + ); + equal( + div.children()[ 0 ].nodeName.toLowerCase(), "span", "A span was inserted." + ); +} ); test( "wrapInner(Function) returns String", function() { @@ -277,19 +359,27 @@ test( "wrapInner(Function) returns String", function() { var num, val = manipulationFunctionReturningObj; - num = jQuery("#first").children().length; - jQuery("#first").wrapInner( val("<div class='red'><div id='tmp'></div></div>") ); - - equal( jQuery("#first").children().length, 1, "Only one child" ); - ok( jQuery("#first").children().is(".red"), "Verify Right Element" ); - equal( jQuery("#first").children().children().children().length, num, "Verify Elements Intact" ); - - num = jQuery("#first").html("foo<div>test</div><div>test2</div>").children().length; - jQuery("#first").wrapInner( val("<div class='red'><div id='tmp'></div></div>") ); - equal( jQuery("#first").children().length, 1, "Only one child" ); - ok( jQuery("#first").children().is(".red"), "Verify Right Element" ); - equal( jQuery("#first").children().children().children().length, num, "Verify Elements Intact" ); -}); + num = jQuery( "#first" ).children().length; + jQuery( "#first" ).wrapInner( val( "<div class='red'><div id='tmp'></div></div>" ) ); + + equal( + jQuery( "#first" ).children().length, 1, "Only one child" + ); + ok( jQuery( "#first" ).children().is( ".red" ), "Verify Right Element" ); + equal( + jQuery( "#first" ).children().children().children().length, num, "Verify Elements Intact" + ); + + num = jQuery( "#first" ).html( "foo<div>test</div><div>test2</div>" ).children().length; + jQuery( "#first" ).wrapInner( val( "<div class='red'><div id='tmp'></div></div>" ) ); + equal( + jQuery( "#first" ).children().length, 1, "Only one child" + ); + ok( jQuery( "#first" ).children().is( ".red" ), "Verify Right Element" ); + equal( + jQuery( "#first" ).children().children().children().length, num, "Verify Elements Intact" + ); +} ); test( "wrapInner(Function) returns Element", function() { @@ -297,71 +387,134 @@ test( "wrapInner(Function) returns Element", function() { var num, val = manipulationFunctionReturningObj, - div = jQuery("<div/>"); - - num = jQuery("#first").children().length; - jQuery("#first").wrapInner( val(document.getElementById("empty")) ); - equal( jQuery("#first").children().length, 1, "Only one child" ); - ok( jQuery("#first").children().is("#empty"), "Verify Right Element" ); - equal( jQuery("#first").children().children().length, num, "Verify Elements Intact" ); - - div.wrapInner( val("<span></span>") ); - equal( div.children().length, 1, "The contents were wrapped." ); - equal( div.children()[ 0 ].nodeName.toLowerCase(), "span", "A span was inserted." ); -}); + div = jQuery( "<div/>" ); + + num = jQuery( "#first" ).children().length; + jQuery( "#first" ).wrapInner( val( document.getElementById( "empty" ) ) ); + equal( + jQuery( "#first" ).children().length, 1, "Only one child" + ); + ok( jQuery( "#first" ).children().is( "#empty" ), "Verify Right Element" ); + equal( + jQuery( "#first" ).children().children().length, num, "Verify Elements Intact" + ); + + div.wrapInner( val( "<span></span>" ) ); + equal( + div.children().length, 1, "The contents were wrapped." + ); + equal( + div.children()[ 0 ].nodeName.toLowerCase(), "span", "A span was inserted." + ); +} ); test( "unwrap()", function() { expect( 9 ); - jQuery("body").append(" <div id='unwrap' style='display: none;'> <div id='unwrap1'> <span class='unwrap'>a</span> <span class='unwrap'>b</span> </div> <div id='unwrap2'> <span class='unwrap'>c</span> <span class='unwrap'>d</span> </div> <div id='unwrap3'> <b><span class='unwrap unwrap3'>e</span></b> <b><span class='unwrap unwrap3'>f</span></b> </div> </div>"); - - var abcd = jQuery("#unwrap1 > span, #unwrap2 > span").get(), - abcdef = jQuery("#unwrap span").get(); - - equal( jQuery("#unwrap1 span").add("#unwrap2 span:first-child").unwrap().length, 3, "make #unwrap1 and #unwrap2 go away" ); - deepEqual( jQuery("#unwrap > span").get(), abcd, "all four spans should still exist" ); - - deepEqual( jQuery("#unwrap3 span").unwrap().get(), jQuery("#unwrap3 > span").get(), "make all b in #unwrap3 go away" ); - - deepEqual( jQuery("#unwrap3 span").unwrap().get(), jQuery("#unwrap > span.unwrap3").get(), "make #unwrap3 go away" ); - - deepEqual( jQuery("#unwrap").children().get(), abcdef, "#unwrap only contains 6 child spans" ); - - deepEqual( jQuery("#unwrap > span").unwrap().get(), jQuery("body > span.unwrap").get(), "make the 6 spans become children of body" ); - - deepEqual( jQuery("body > span.unwrap").unwrap().get(), jQuery("body > span.unwrap").get(), "can't unwrap children of body" ); - deepEqual( jQuery("body > span.unwrap").unwrap().get(), abcdef, "can't unwrap children of body" ); - - deepEqual( jQuery("body > span.unwrap").get(), abcdef, "body contains 6 .unwrap child spans" ); - - jQuery("body > span.unwrap").remove(); -}); + jQuery( "body" ).append( + " <div id='unwrap' style='display: none;'> <div id='unwrap1'> <span class='unwrap'>" + + "a</span> <span class='unwrap'>b</span> </div> <div id='unwrap2'>" + + " <span class='unwrap'>c</span> <span class='unwrap'>d</span> </div>" + + " <div id='unwrap3'> <b><span class='unwrap unwrap3'>e</span></b> " + + "<b><span class='unwrap unwrap3'>f</span></b> </div> </div>" + ); + + var abcd = jQuery( "#unwrap1 > span, #unwrap2 > span" ).get(), + abcdef = jQuery( "#unwrap span" ).get(); + + equal( + jQuery( "#unwrap1 span" ).add( "#unwrap2 span:first-child" ).unwrap().length, + 3, + "make #unwrap1 and #unwrap2 go away" + ); + deepEqual( + jQuery( "#unwrap > span" ).get(), abcd, "all four spans should still exist" + ); + + deepEqual( + jQuery( "#unwrap3 span" ).unwrap().get(), + jQuery( "#unwrap3 > span" ).get(), + "make all b in #unwrap3 go away" + ); + + deepEqual( + jQuery( "#unwrap3 span" ).unwrap().get(), + jQuery( "#unwrap > span.unwrap3" ).get(), + "make #unwrap3 go away" + ); + + deepEqual( + jQuery( "#unwrap" ).children().get(), + abcdef, + "#unwrap only contains 6 child spans" + ); + + deepEqual( + jQuery( "#unwrap > span" ).unwrap().get(), + jQuery( "body > span.unwrap" ).get(), + "make the 6 spans become children of body" + ); + + deepEqual( + jQuery( "body > span.unwrap" ).unwrap().get(), + jQuery( "body > span.unwrap" ).get(), + "can't unwrap children of body" + ); + deepEqual( + jQuery( "body > span.unwrap" ).unwrap().get(), abcdef, "can't unwrap children of body" + ); + + deepEqual( + jQuery( "body > span.unwrap" ).get(), abcdef, "body contains 6 .unwrap child spans" + ); + + jQuery( "body > span.unwrap" ).remove(); +} ); test( "unwrap( selector )", function() { expect( 5 ); - jQuery( "body" ).append( " <div id='unwrap' style='display: none;'> <div id='unwrap1'> <span class='unwrap'>a</span> <span class='unwrap'>b</span> </div> <div id='unwrap2'> <span class='unwrap'>c</span> <span class='unwrap'>d</span> </div> </div>" ); + jQuery( "body" ).append( + " <div id='unwrap' style='display: none;'> <div id='unwrap1'>" + + " <span class='unwrap'>a</span> <span class='unwrap'>b</span> </div>" + + " <div id='unwrap2'> <span class='unwrap'>c</span> <span class='unwrap'>d</span>" + + " </div> </div>" + ); // Shouldn't unwrap, no match jQuery( "#unwrap1 span" ) .unwrap( "#unwrap2" ); - equal( jQuery("#unwrap1").length, 1, "still wrapped" ); + equal( + jQuery( "#unwrap1" ).length, 1, "still wrapped" + ); // Shouldn't unwrap, no match jQuery( "#unwrap1 span" ) .unwrap( "span" ); - equal( jQuery("#unwrap1").length, 1, "still wrapped" ); + equal( + jQuery( "#unwrap1" ).length, 1, "still wrapped" + ); // Unwraps jQuery( "#unwrap1 span" ) .unwrap( "#unwrap1" ); - equal( jQuery("#unwrap1").length, 0, "unwrapped match" ); + equal( + jQuery( "#unwrap1" ).length, 0, "unwrapped match" + ); // Check return values - deepEqual( jQuery( "#unwrap2 span" ).get(), jQuery( "#unwrap2 span" ).unwrap( "quote" ).get(), "return on unmatched unwrap" ); - deepEqual( jQuery( "#unwrap2 span" ).get(), jQuery( "#unwrap2 span" ).unwrap( "#unwrap2" ).get(), "return on matched unwrap" ); - - jQuery("body > span.unwrap").remove(); -}); + deepEqual( + jQuery( "#unwrap2 span" ).get(), + jQuery( "#unwrap2 span" ).unwrap( "quote" ).get(), + "return on unmatched unwrap" + ); + deepEqual( + jQuery( "#unwrap2 span" ).get(), + jQuery( "#unwrap2 span" ).unwrap( "#unwrap2" ).get(), + "return on matched unwrap" + ); + + jQuery( "body > span.unwrap" ).remove(); +} ); test( "jQuery(<tag>) & wrap[Inner/All]() handle unknown elems (#10667)", function() { @@ -370,24 +523,35 @@ test( "jQuery(<tag>) & wrap[Inner/All]() handle unknown elems (#10667)", functio var $wraptarget = jQuery( "<div id='wrap-target'>Target</div>" ).appendTo( "#qunit-fixture" ), $section = jQuery( "<section>" ).appendTo( "#qunit-fixture" ); - $wraptarget.wrapAll("<aside style='background-color:green'></aside>"); + $wraptarget.wrapAll( "<aside style='background-color:green'></aside>" ); - notEqual( $wraptarget.parent("aside").get( 0 ).style.backgroundColor, "transparent", "HTML5 elements created with wrapAll inherit styles" ); - notEqual( $section.get( 0 ).style.backgroundColor, "transparent", "HTML5 elements create with jQuery( string ) inherit styles" ); -}); + notEqual( + $wraptarget.parent( "aside" ).get( 0 ).style.backgroundColor, + "transparent", + "HTML5 elements created with wrapAll inherit styles" + ); + notEqual( + $section.get( 0 ).style.backgroundColor, + "transparent", + "HTML5 elements create with jQuery( string ) inherit styles" + ); +} ); test( "wrapping scripts (#10470)", function() { expect( 2 ); - var script = document.createElement("script"); - script.text = script.textContent = "ok( !document.eval10470, 'script evaluated once' ); document.eval10470 = true;"; + var script = document.createElement( "script" ); + script.text = script.textContent = + "ok( !document.eval10470, 'script evaluated once' ); document.eval10470 = true;"; document.eval10470 = false; - jQuery("#qunit-fixture").empty()[0].appendChild( script ); - jQuery("#qunit-fixture script").wrap("<b></b>"); - strictEqual( script.parentNode, jQuery("#qunit-fixture > b")[ 0 ], "correctly wrapped" ); + jQuery( "#qunit-fixture" ).empty()[ 0 ].appendChild( script ); + jQuery( "#qunit-fixture script" ).wrap( "<b></b>" ); + strictEqual( + script.parentNode, jQuery( "#qunit-fixture > b" )[ 0 ], "correctly wrapped" + ); jQuery( script ).remove(); -}); +} ); -})(); +} )(); |