Toggle between 3 classes using toggleclass

2019-01-25 20:16发布

I have 3 images that I want to switch between. I put each one of them in a class & change it's image in the css. I can now switch between 2 classes but when I add the third one the code doesn't work. Any class of them can be the starting one.

    $('.one').click(function(){                             
        $(this).toggleClass("two");
        $(this).toggleClass("one");

    });
     $('.two').click(function(){                             
        $(this).toggleClass("one");
        $(this).toggleClass("two");

    });

When I add this line:

        $(this).toggleClass("three"); 

It doesn't toggle at all....

Do you know a method in which I can put all of them in one function ?

Thanks.

3条回答
一夜七次
2楼-- · 2019-01-25 20:56
$('.one, .two, .three').click(function(){                             
        $(this).toggleClass("one, two, three");
    });
查看更多
Lonely孤独者°
3楼-- · 2019-01-25 21:04

The safest way would be to remove unwanted classes and add the required class:

// Switch to class 'three'
$(this).removeClass('one').removeClass('two').addClass('three');
查看更多
我只想做你的唯一
4楼-- · 2019-01-25 21:09

Example fiddle: http://jsfiddle.net/KdfEV/

This code will allow you to cycle through a sequence of defined classes

$('.one, .two, .three').click(function() {                             
    this.className = {
       three : 'one', one: 'two', two: 'three'
    }[this.className];
});
查看更多
登录 后发表回答