Learn how to a build a cloud-first strategyRegister Now

x
  • Status: Solved
  • Priority: Medium
  • Security: Public
  • Views: 847
  • Last Modified:

jQuery select class contain part of name

in my html i have the following
<li class="Bleu1" id="2">
<li class="Bleu1Selected" id="3">
<li class="yallow1Selected" id="4">
<li class="yallow1" id="5">

i want jQuay that will select all (li) with class name contain (Selected)
and then reset the class to be without (Selected)
Like this

<li class="Bleu1" id="2">
<li class="Bleu1" id="3">
<li class="yallow1" id="4">
<li class="yallow1" id="5">
0
palserv
Asked:
palserv
  • 3
  • 2
2 Solutions
 
mcuk_stormCommented:
Do you have control of the markup? If so i would suggest using multiple classes instead of a compound one i.e.
<li class="Bleu1 Selected">

You can then identify this through css/jQuery like

li.Bleu1.Selected

then if you want to remove selected you can do $('li.Bleu1.Selected').removeClass('Selected');

This makes selecting all Selected ones alot easier and likewise all Bleu1 ones easier
0
 
mcuk_stormCommented:
With the above comment, an example to reset all selected would simply be $('.Selected').removeClass('Selected');
0
 
leakim971PluritechnicianCommented:
You may use : http://api.jquery.com/attribute-contains-selector/


$("li[class*='Selected']").each(function() {
				prevClass = $(this).attr("className");
				nextClass = prevClass.replace("Selected","");
				$(this).removeClass(prevClass).addClass(nextClass);
			});

Open in new window

0
Independent Software Vendors: We Want Your Opinion

We value your feedback.

Take our survey and automatically be enter to win anyone of the following:
Yeti Cooler, Amazon eGift Card, and Movie eGift Card!

 
leakim971PluritechnicianCommented:
Test page :


<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
<html xmlns="http://www.w3.org/1999/xhtml">
<head>
<meta http-equiv="Content-Type" content="text/html; charset=utf-8" />
<title>Untitled Document</title>
<script language="javascript" src="http://code.jquery.com/jquery-1.4.2.min.js"></script>
<script language="javascript">
	$(document).ready(function() {
		$("#but").click(function() {
			$("li[class*='Selected']").each(function() {
				prevClass = $(this).attr("className");
				nextClass = prevClass.replace("Selected","");
				$(this).removeClass(prevClass).addClass(nextClass);
			});
		});
	});
</script>
</head>
<body>
<input type="button" id="but" value="click me" />
<ul>
    <li class="Bleu1" id="2">Hello</li>
    <li class="Bleu1Selected" id="3">Hello</li>
    <li class="yallow1Selected" id="4">Hello</li>
    <li class="yallow1" id="5">Hello</li>
</ul>
</body>
</html>

Open in new window

0
 
hehdaddyCommented:
Simple:

$("li[class*='Selected']").each(function()
{
    var class = $(this).attr("class");
    class.replace("Selected", "");
    $(this).attr("class", class);
});

Give this a go!
0
 
leakim971PluritechnicianCommented:
Thanks for the points!
0

Featured Post

Free Tool: IP Lookup

Get more info about an IP address or domain name, such as organization, abuse contacts and geolocation.

One of a set of tools we are providing to everyone as a way of saying thank you for being a part of the community.

  • 3
  • 2
Tackle projects and never again get stuck behind a technical roadblock.
Join Now