aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorJeremy Dunck <jdunck@gmail.com>2013-08-19 17:55:05 +0200
committerMichał Gołębiowski <m.goleb@gmail.com>2013-08-19 17:55:49 +0200
commitc418b94eb48188cd9329519ae5e030a52dd81cc9 (patch)
tree89385c97c2a3ad10a93ba794eb1fdcd47039c4aa
parent32e803c5bc821a34d6d225659f7a4b4a24053e07 (diff)
downloadjquery-c418b94eb48188cd9329519ae5e030a52dd81cc9.tar.gz
jquery-c418b94eb48188cd9329519ae5e030a52dd81cc9.zip
Fix #14164: assign className in addClass/removeClass only if changed. Close gh-1331.
-rw-r--r--src/attributes/classes.js17
1 files changed, 13 insertions, 4 deletions
diff --git a/src/attributes/classes.js b/src/attributes/classes.js
index 170787c83..aed8db88a 100644
--- a/src/attributes/classes.js
+++ b/src/attributes/classes.js
@@ -9,7 +9,7 @@ var rclass = /[\t\r\n\f]/g;
jQuery.fn.extend({
addClass: function( value ) {
- var classes, elem, cur, clazz, j,
+ var classes, elem, cur, clazz, j, finalValue,
i = 0,
len = this.length,
proceed = typeof value === "string" && value;
@@ -38,8 +38,12 @@ jQuery.fn.extend({
cur += clazz + " ";
}
}
- elem.className = jQuery.trim( cur );
+ // only assign if different to avoid unneeded rendering.
+ finalValue = jQuery.trim( cur );
+ if ( elem.className !== finalValue ) {
+ elem.className = finalValue;
+ }
}
}
}
@@ -48,7 +52,7 @@ jQuery.fn.extend({
},
removeClass: function( value ) {
- var classes, elem, cur, clazz, j,
+ var classes, elem, cur, clazz, j, finalValue,
i = 0,
len = this.length,
proceed = arguments.length === 0 || typeof value === "string" && value;
@@ -77,7 +81,12 @@ jQuery.fn.extend({
cur = cur.replace( " " + clazz + " ", " " );
}
}
- elem.className = value ? jQuery.trim( cur ) : "";
+
+ // only assign if different to avoid unneeded rendering.
+ finalValue = value ? jQuery.trim( cur ) : "";
+ if ( elem.className !== finalValue ) {
+ elem.className = finalValue;
+ }
}
}
}