Side navigation
#1681 closed enhancement (fixed)
Opened September 19, 2007 04:40PM UTC
Closed December 25, 2008 08:12PM UTC
More powerful toggleClass()
Reported by: | dimi | Owned by: | flesler |
---|---|---|---|
Priority: | major | Milestone: | 1.3 |
Component: | core | Version: | 1.2.1 |
Keywords: | Cc: | dimi, ecentinela, genezys | |
Blocked by: | Blocking: |
Description
A lot of times you need to add/remove a class to an element based on a boolean. toggleClass() should take an optional second parameter that would control if the toggle will add or remove the class.
The added complexity would be absolutely minimal (a few more characters), but it would be really useful.
Attachments (2)
Change History (7)
Changed November 14, 2007 03:11AM UTC by comment:1
need: | Review → Test Case |
---|
Changed December 07, 2007 11:58AM UTC by comment:2
I agree with this one, it would be nice to be able to add/remove a class based on a boolean value.
Here are some examples:
"item" is an object "$item" is the jQuery object representing "item" I want to add the class "Selected" to the UI when the object has the attribute "selected".
First version, very verbose
if( item.selected ) { $item.addClass("Selected"); } else { $item.removeClass("Selected"); }
Second version, less verbose but less readable
var toggleClass = ( item.selected ? $.fn.addClass : $.fn.removeClass ); toggleClass.call($item, "Selected");
Third version, what would be nice
$item.toggleClass("Selected", item.selected);
Changed May 09, 2008 12:44PM UTC by comment:3
An why not?
$item[item.selected ? 'removeClass' : 'addClass']("Selected");
Changed May 16, 2008 02:31AM UTC by comment:4
milestone: | 1.2.2 → 1.2.4 |
---|
So.. what do we do about this ?
Changed August 15, 2008 10:51AM UTC by comment:5
Here are attached the modification to the core and tests to fix this bug.
Changed August 15, 2008 05:24PM UTC by comment:6
cc: | → dimi, ecentinela, genezys |
---|---|
milestone: | 1.2.4 → 1.3 |
need: | Test Case → Patch |
owner: | → flesler |
status: | new → assigned |
This is not a bug, it's an enhancement.
I think this is doable, will handle it asap.
Changed December 25, 2008 08:12PM UTC by comment:7
resolution: | → fixed |
---|---|
status: | assigned → closed |
Added at [6000].
Could you provide a few examples of how this will improve your code?