3

How can you remove a class name and replace it with a new one?

<style>
    .red {background-color: #FF0000;}
    .green{background-color: #00FF00;}
    .blue {background-color: #0000FF;}
</style>

<body class="red">
    <ul>
        <li><a href="">red</a></li>
        <li><a href="">green</a></li>
        <li><a href="">blue</a></li>
    </ul>
</body>

In this case when you click on red or green or blue, the body class name will change accordingly. Also it will make a cookie which will save the choice.

I tried the jQuery .addClass and it's working, but it's adding a class on top of the existing one. Also I can't manage to save the cookie.

Peter Mortensen
  • 28,342
  • 21
  • 95
  • 123
kakkalo
  • 715
  • 3
  • 7
  • 11

3 Answers3

18

Use:

$('.red').removeClass('red').addClass('blue');

Here's the full working code:

$(function() {
    $("a").click(function() {
        var color = $(this).text();
        $("body").removeClass().addClass(color);
        return false;
    });
});

And now for the cookie part

$(function() {
    $("a").click(function() {
        var color = $(this).text();
        $("body").removeClass().addClass(color);
        createCookie("color",color);
        return false;
    });

    if (readCookie("color") != null) {
      $("body").removeClass().addClass(readCookie("color"));

    }
    else {
      $("body").removeClass().addClass("red");
    }
});

function createCookie(name,value,days) {
    if (days) {
        var date = new Date();
        date.setTime(date.getTime()+(days*24*60*60*1000));
        var expires = "; expires="+date.toGMTString();
    }
    else
        var expires = "";
        document.cookie = name+"="+value+expires+"; path=/";
    }

    function readCookie(name) {
        var nameEQ = name + "=";
        var ca = document.cookie.split(';');
        for (var i=0;i < ca.length;i++) {
            var c = ca[i];
            while (c.charAt(0)==' ')
                c = c.substring(1,c.length);
            if (c.indexOf(nameEQ) == 0)
                return c.substring(nameEQ.length,c.length);
        }
        return null;
    }

    function eraseCookie(name) {
    createCookie(name,"",-1);
}

Working example here. A thank you to QuirksMode for the pre-made cookie code (cookie-cutter cookie code?)

Peter Mortensen
  • 28,342
  • 21
  • 95
  • 123
Russ Cam
  • 117,566
  • 29
  • 193
  • 253
  • i tried that but since the cookie value will replace that class name its not working. – kakkalo Apr 29 '09 at 22:43
  • thank you very much. this works perfectly. now for the cookie part. is there any other way to save without cookie plugin – kakkalo Apr 29 '09 at 22:59
4

Without jQuery you can do this with a line as simple as:

document.getElementsByTagName("body")[0].className = "red";

This effectively removes the class assigned to the element and replace it with whatever you want.

For cookies, PPK has a few simple methods to read/write/erase cookies.

createCookie("mySiteCookie", "red", 7); // Set the cookie to expire in 7 days.
readCookie("mySiteCookie"); // Should yield "red"
Zack The Human
  • 8,052
  • 6
  • 37
  • 59
1

You'll also need removeClass.

Hank Gay
  • 65,372
  • 31
  • 148
  • 218