Update jQuery Migrate to 1.4.1
http://blog.jquery.com/2016/05/19/jquery-migrate-1-4-1-released-and-the-path-to-jquery-3-0/ Unquoted selectors for attribute selectors should function once again (and output a warning so that plugins and themes using them can update). Fixes #36892 git-svn-id: https://develop.svn.wordpress.org/trunk@37472 602fd350-edb4-49c9-b593-d223f7449a82
This commit is contained in:
parent
761dde5ee9
commit
82d0c1f523
77
src/wp-includes/js/jquery/jquery-migrate.js
vendored
77
src/wp-includes/js/jquery/jquery-migrate.js
vendored
@ -1,5 +1,5 @@
|
|||||||
/*!
|
/*!
|
||||||
* jQuery Migrate - v1.4.0 - 2016-02-26
|
* jQuery Migrate - v1.4.1 - 2016-05-19
|
||||||
* Copyright jQuery Foundation and other contributors
|
* Copyright jQuery Foundation and other contributors
|
||||||
*/
|
*/
|
||||||
(function( jQuery, window, undefined ) {
|
(function( jQuery, window, undefined ) {
|
||||||
@ -7,7 +7,7 @@
|
|||||||
// "use strict";
|
// "use strict";
|
||||||
|
|
||||||
|
|
||||||
jQuery.migrateVersion = "1.4.0";
|
jQuery.migrateVersion = "1.4.1";
|
||||||
|
|
||||||
|
|
||||||
var warnedAbout = {};
|
var warnedAbout = {};
|
||||||
@ -193,9 +193,11 @@ jQuery.attrHooks.value = {
|
|||||||
|
|
||||||
var matched, browser,
|
var matched, browser,
|
||||||
oldInit = jQuery.fn.init,
|
oldInit = jQuery.fn.init,
|
||||||
|
oldFind = jQuery.find,
|
||||||
oldParseJSON = jQuery.parseJSON,
|
oldParseJSON = jQuery.parseJSON,
|
||||||
rspaceAngle = /^\s*</,
|
rspaceAngle = /^\s*</,
|
||||||
rattrHash = /\[\s*\w+\s*[~|^$*]?=\s*(?![\s'"])[^#\]]*#/,
|
rattrHashTest = /\[(\s*[-\w]+\s*)([~|^$*]?=)\s*([-\w#]*?#[-\w#]*)\s*\]/,
|
||||||
|
rattrHashGlob = /\[(\s*[-\w]+\s*)([~|^$*]?=)\s*([-\w#]*?#[-\w#]*)\s*\]/g,
|
||||||
// Note: XSS check is done below after string is trimmed
|
// Note: XSS check is done below after string is trimmed
|
||||||
rquickExpr = /^([^<]*)(<[\w\W]+>)([^>]*)$/;
|
rquickExpr = /^([^<]*)(<[\w\W]+>)([^>]*)$/;
|
||||||
|
|
||||||
@ -203,8 +205,10 @@ var matched, browser,
|
|||||||
jQuery.fn.init = function( selector, context, rootjQuery ) {
|
jQuery.fn.init = function( selector, context, rootjQuery ) {
|
||||||
var match, ret;
|
var match, ret;
|
||||||
|
|
||||||
if ( selector && typeof selector === "string" && !jQuery.isPlainObject( context ) &&
|
if ( selector && typeof selector === "string" ) {
|
||||||
|
if ( !jQuery.isPlainObject( context ) &&
|
||||||
(match = rquickExpr.exec( jQuery.trim( selector ) )) && match[ 0 ] ) {
|
(match = rquickExpr.exec( jQuery.trim( selector ) )) && match[ 0 ] ) {
|
||||||
|
|
||||||
// This is an HTML string according to the "old" rules; is it still?
|
// This is an HTML string according to the "old" rules; is it still?
|
||||||
if ( !rspaceAngle.test( selector ) ) {
|
if ( !rspaceAngle.test( selector ) ) {
|
||||||
migrateWarn("$(html) HTML strings must start with '<' character");
|
migrateWarn("$(html) HTML strings must start with '<' character");
|
||||||
@ -213,35 +217,25 @@ jQuery.fn.init = function( selector, context, rootjQuery ) {
|
|||||||
migrateWarn("$(html) HTML text after last tag is ignored");
|
migrateWarn("$(html) HTML text after last tag is ignored");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Consistently reject any HTML-like string starting with a hash (#9521)
|
// Consistently reject any HTML-like string starting with a hash (gh-9521)
|
||||||
// Note that this may break jQuery 1.6.x code that otherwise would work.
|
// Note that this may break jQuery 1.6.x code that otherwise would work.
|
||||||
if ( match[ 0 ].charAt( 0 ) === "#" ) {
|
if ( match[ 0 ].charAt( 0 ) === "#" ) {
|
||||||
migrateWarn("HTML string cannot start with a '#' character");
|
migrateWarn("HTML string cannot start with a '#' character");
|
||||||
jQuery.error("JQMIGRATE: Invalid selector string (XSS)");
|
jQuery.error("JQMIGRATE: Invalid selector string (XSS)");
|
||||||
}
|
}
|
||||||
|
|
||||||
// Now process using loose rules; let pre-1.8 play too
|
// Now process using loose rules; let pre-1.8 play too
|
||||||
if ( context && context.context ) {
|
// Is this a jQuery context? parseHTML expects a DOM element (#178)
|
||||||
// jQuery object as context; parseHTML expects a DOM object
|
if ( context && context.context && context.context.nodeType ) {
|
||||||
context = context.context;
|
context = context.context;
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( jQuery.parseHTML ) {
|
if ( jQuery.parseHTML ) {
|
||||||
return oldInit.call( this,
|
return oldInit.call( this,
|
||||||
jQuery.parseHTML( match[ 2 ], context && context.ownerDocument ||
|
jQuery.parseHTML( match[ 2 ], context && context.ownerDocument ||
|
||||||
context || document, true ), context, rootjQuery );
|
context || document, true ), context, rootjQuery );
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
if ( selector === "#" ) {
|
|
||||||
|
|
||||||
// jQuery( "#" ) is a bogus ID selector, but it returned an empty set before jQuery 3.0
|
|
||||||
migrateWarn( "jQuery( '#' ) is not a valid selector" );
|
|
||||||
selector = [];
|
|
||||||
|
|
||||||
} else if ( rattrHash.test( selector ) ) {
|
|
||||||
|
|
||||||
// The nonstandard and undocumented unquoted-hash was removed in jQuery 1.12.0
|
|
||||||
// Note that this doesn't actually fix the selector due to potential false positives
|
|
||||||
migrateWarn( "Attribute selectors with '#' must be quoted: '" + selector + "'" );
|
|
||||||
}
|
}
|
||||||
|
|
||||||
ret = oldInit.apply( this, arguments );
|
ret = oldInit.apply( this, arguments );
|
||||||
@ -263,6 +257,47 @@ jQuery.fn.init = function( selector, context, rootjQuery ) {
|
|||||||
};
|
};
|
||||||
jQuery.fn.init.prototype = jQuery.fn;
|
jQuery.fn.init.prototype = jQuery.fn;
|
||||||
|
|
||||||
|
jQuery.find = function( selector ) {
|
||||||
|
var args = Array.prototype.slice.call( arguments );
|
||||||
|
|
||||||
|
// Support: PhantomJS 1.x
|
||||||
|
// String#match fails to match when used with a //g RegExp, only on some strings
|
||||||
|
if ( typeof selector === "string" && rattrHashTest.test( selector ) ) {
|
||||||
|
|
||||||
|
// The nonstandard and undocumented unquoted-hash was removed in jQuery 1.12.0
|
||||||
|
// First see if qS thinks it's a valid selector, if so avoid a false positive
|
||||||
|
try {
|
||||||
|
document.querySelector( selector );
|
||||||
|
} catch ( err1 ) {
|
||||||
|
|
||||||
|
// Didn't *look* valid to qSA, warn and try quoting what we think is the value
|
||||||
|
selector = selector.replace( rattrHashGlob, function( _, attr, op, value ) {
|
||||||
|
return "[" + attr + op + "\"" + value + "\"]";
|
||||||
|
} );
|
||||||
|
|
||||||
|
// If the regexp *may* have created an invalid selector, don't update it
|
||||||
|
// Note that there may be false alarms if selector uses jQuery extensions
|
||||||
|
try {
|
||||||
|
document.querySelector( selector );
|
||||||
|
migrateWarn( "Attribute selector with '#' must be quoted: " + args[ 0 ] );
|
||||||
|
args[ 0 ] = selector;
|
||||||
|
} catch ( err2 ) {
|
||||||
|
migrateWarn( "Attribute selector with '#' was not fixed: " + args[ 0 ] );
|
||||||
|
}
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
return oldFind.apply( this, args );
|
||||||
|
};
|
||||||
|
|
||||||
|
// Copy properties attached to original jQuery.find method (e.g. .attr, .isXML)
|
||||||
|
var findProp;
|
||||||
|
for ( findProp in oldFind ) {
|
||||||
|
if ( Object.prototype.hasOwnProperty.call( oldFind, findProp ) ) {
|
||||||
|
jQuery.find[ findProp ] = oldFind[ findProp ];
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
// Let $.parseJSON(falsy_value) return null
|
// Let $.parseJSON(falsy_value) return null
|
||||||
jQuery.parseJSON = function( json ) {
|
jQuery.parseJSON = function( json ) {
|
||||||
if ( !json ) {
|
if ( !json ) {
|
||||||
@ -631,7 +666,7 @@ jQuery.event.special.ready = {
|
|||||||
};
|
};
|
||||||
|
|
||||||
var oldSelf = jQuery.fn.andSelf || jQuery.fn.addBack,
|
var oldSelf = jQuery.fn.andSelf || jQuery.fn.addBack,
|
||||||
oldFind = jQuery.fn.find;
|
oldFnFind = jQuery.fn.find;
|
||||||
|
|
||||||
jQuery.fn.andSelf = function() {
|
jQuery.fn.andSelf = function() {
|
||||||
migrateWarn("jQuery.fn.andSelf() replaced by jQuery.fn.addBack()");
|
migrateWarn("jQuery.fn.andSelf() replaced by jQuery.fn.addBack()");
|
||||||
@ -639,7 +674,7 @@ jQuery.fn.andSelf = function() {
|
|||||||
};
|
};
|
||||||
|
|
||||||
jQuery.fn.find = function( selector ) {
|
jQuery.fn.find = function( selector ) {
|
||||||
var ret = oldFind.apply( this, arguments );
|
var ret = oldFnFind.apply( this, arguments );
|
||||||
ret.context = this.context;
|
ret.context = this.context;
|
||||||
ret.selector = this.selector ? this.selector + " " + selector : selector;
|
ret.selector = this.selector ? this.selector + " " + selector : selector;
|
||||||
return ret;
|
return ret;
|
||||||
|
File diff suppressed because one or more lines are too long
@ -181,7 +181,7 @@ function wp_default_scripts( &$scripts ) {
|
|||||||
// jQuery
|
// jQuery
|
||||||
$scripts->add( 'jquery', false, array( 'jquery-core', 'jquery-migrate' ), '1.12.4-pre' );
|
$scripts->add( 'jquery', false, array( 'jquery-core', 'jquery-migrate' ), '1.12.4-pre' );
|
||||||
$scripts->add( 'jquery-core', '/wp-includes/js/jquery/jquery.js', array(), '1.12.4-pre' );
|
$scripts->add( 'jquery-core', '/wp-includes/js/jquery/jquery.js', array(), '1.12.4-pre' );
|
||||||
$scripts->add( 'jquery-migrate', "/wp-includes/js/jquery/jquery-migrate$suffix.js", array(), '1.4.0' );
|
$scripts->add( 'jquery-migrate', "/wp-includes/js/jquery/jquery-migrate$suffix.js", array(), '1.4.1' );
|
||||||
|
|
||||||
// full jQuery UI
|
// full jQuery UI
|
||||||
$scripts->add( 'jquery-ui-core', "/wp-includes/js/jquery/ui/core$dev_suffix.js", array('jquery'), '1.11.4', 1 );
|
$scripts->add( 'jquery-ui-core', "/wp-includes/js/jquery/ui/core$dev_suffix.js", array('jquery'), '1.11.4', 1 );
|
||||||
|
Loading…
Reference in New Issue
Block a user