Skip to content

Commit

Permalink
Ticket #6804. Adds a changeData event.
Browse files Browse the repository at this point in the history
  • Loading branch information
InfinitiesLoop authored and jeresig committed Jul 20, 2010
1 parent 6a0942c commit 2e10af1
Show file tree
Hide file tree
Showing 2 changed files with 21 additions and 5 deletions.
1 change: 1 addition & 0 deletions src/data.js
Original file line number Diff line number Diff line change
Expand Up @@ -129,6 +129,7 @@ jQuery.fn.extend({
} else {
return this.trigger("setData" + parts[1] + "!", [parts[0], value]).each(function() {
jQuery.data( this, key, value );
jQuery.event.trigger( "changeData" + parts[1] + "!", [parts[0], value], this );
});
}
},
Expand Down
25 changes: 20 additions & 5 deletions test/unit/data.js
Original file line number Diff line number Diff line change
Expand Up @@ -68,7 +68,7 @@ test(".data()", function() {
})

test(".data(String) and .data(String, Object)", function() {
expect(23);
expect(27);
var div = jQuery("<div/>");

ok( div.data("test") === undefined, "Check for no data exists" );
Expand All @@ -88,11 +88,23 @@ test(".data(String) and .data(String, Object)", function() {
ok( div.data("notexist") === undefined, "Check for no data exists" );

div.data("test", "overwritten");
var hits = {test:0}, gets = {test:0};
var hits = {test:0}, gets = {test:0}, changes = {test:0, value:null};


function logChangeData(e,key,value) {
var dataKey = key;
if ( e.namespace ) {
dataKey = dataKey + "." + e.namespace;
}
changes[key] += value;
changes.value = jQuery.data(e.target, dataKey);
}

div
.bind("setData",function(e,key,value){ hits[key] += value; })
.bind("setData.foo",function(e,key,value){ hits[key] += value; })
.bind("changeData",logChangeData)
.bind("changeData.foo",logChangeData)
.bind("getData",function(e,key){ gets[key] += 1; })
.bind("getData.foo",function(e,key){ gets[key] += 3; });

Expand All @@ -102,19 +114,22 @@ test(".data(String) and .data(String, Object)", function() {
equals( div.data("test.bar"), "overwritten", "Check for unmatched namespace" );
equals( hits.test, 2, "Check triggered setter functions" );
equals( gets.test, 5, "Check triggered getter functions" );
equals( changes.test, 2, "Check sets raise changeData");
equals( changes.value, 2, "Check changeData after data has been set" );

hits.test = 0;
gets.test = 0;
changes.test = 0;
changes.value = null;

div.data("test", 1);
equals( div.data("test"), 1, "Check for original data" );
equals( div.data("test.foo"), 2, "Check for namespaced data" );
equals( div.data("test.bar"), 1, "Check for unmatched namespace" );
equals( hits.test, 1, "Check triggered setter functions" );
equals( gets.test, 5, "Check triggered getter functions" );

hits.test = 0;
gets.test = 0;
equals( changes.test, 1, "Check sets raise changeData" );
equals( changes.value, 1, "Check changeData after data has been set" );

div
.bind("getData",function(e,key){ return key + "root"; })
Expand Down

0 comments on commit 2e10af1

Please sign in to comment.