X-Git-Url: http://git.asbjorn.biz/?a=blobdiff_plain;f=src%2Fdata.js;h=295ea794a51d18807e86a4f862e72f16f8bae57e;hb=8ebb9b22df32fe5739a48087b6e33abb9f5cda49;hp=eb96b860f74b9dea789a8921b5ecbc11e471f459;hpb=2084e01780b57e5becbb00817b883175ef67b0b5;p=jquery.git diff --git a/src/data.js b/src/data.js index eb96b86..295ea79 100644 --- a/src/data.js +++ b/src/data.js @@ -1,4 +1,7 @@ -var windowData = {}; +(function( jQuery ) { + +var windowData = {}, + rbrace = /^(?:{.*}|\[.*\])$/; jQuery.extend({ cache: {}, @@ -140,16 +143,42 @@ jQuery.fn.extend({ if ( value === undefined ) { var data = this.triggerHandler("getData" + parts[1] + "!", [parts[0]]); + // Try to fetch any internally stored data first if ( data === undefined && this.length ) { data = jQuery.data( this[0], key ); + + // If nothing was found internally, try to fetch any + // data from the HTML5 data-* attribute + if ( data === undefined && this[0].nodeType === 1 ) { + data = this[0].getAttribute( "data-" + key ); + + if ( typeof data === "string" ) { + try { + data = data === "true" ? true : + data === "false" ? false : + data === "null" ? null : + !isNaN( data ) ? parseFloat( data ) : + rbrace.test( data ) ? jQuery.parseJSON( data ) : + data; + } catch( e ) {} + + } else { + data = undefined; + } + } } + return data === undefined && parts[1] ? this.data( parts[0] ) : data; + } else { - return this.trigger("setData" + parts[1] + "!", [parts[0], value]).each(function() { + return this.each(function() { + var $this = jQuery( this ), args = [ parts[0], value ]; + + $this.triggerHandler( "setData" + parts[1] + "!", args ); jQuery.data( this, key, value ); - jQuery.event.trigger( "changeData" + parts[1] + "!", [parts[0], value], this ); + $this.triggerHandler( "changeData" + parts[1] + "!", args ); }); } }, @@ -160,3 +189,5 @@ jQuery.fn.extend({ }); } }); + +})( jQuery );