Is there any better way to rewrite this ?
$('element').removeClass('class-1').removeClass('class-2').removeClass('class-3').removeClass('class-5') ...
to .removeClass('class-105')
:)
i want to remove all class-(n) classes
Thanks
Is there any better way to rewrite this ?
$('element').removeClass('class-1').removeClass('class-2').removeClass('class-3').removeClass('class-5') ...
to .removeClass('class-105')
:)
i want to remove all class-(n) classes
Thanks
Get the classes of the element, process it as a string, and put it back:
$('element').attr(
'className',
$('element').attr('className').replace(/\bclass-\d+\b/g, '')
);
Doing it in a better way using css selector, [type*=value]
$(function() {
var i = 0;
while( ++i <= 105) {
$('b').addClass('class-'+ i);
}
var clas = '';
var arey =[]
$('input[type=button]').click(function() {
clas = $('b').attr('class');
arey = clas.match(/class-\d{1,3}/g);
$.each(arey, function(i, e) {
$('b').removeClass(e);
});
});
});
Edit :
Demo : http://jsbin.com/opebu4/2
...or you can use a starts-with selector if you know the possible class names you'd like to remove. The nasty part of the task is the sheer number of classes to look for...
$(document).ready(function () {
var classesOfInterest = '';
for(var i = 1; i<=105; i++)
classesOfInterest += ' ' + 'class-' + i;
alert(classesOfInterest);
$("[class^='class-']").removeClass(classesOfInterest);
});