2018-09-30 23:01:58 +01:00
---
id: bad87fee1348bd9aed008826
title: Target Even Elements Using jQuery
required:
- link: 'https://cdnjs.cloudflare.com/ajax/libs/animate.css/3.2.0/animate.css'
challengeType: 6
2019-07-31 11:32:23 -07:00
forumTopicId: 18318
2018-09-30 23:01:58 +01:00
---
## Description
< section id = 'description' >
You can also target elements based on their positions using < code > :odd< / code > or < code > :even< / code > selectors.
Note that jQuery is zero-indexed which means the first element in a selection has a position of 0. This can be a little confusing as, counter-intuitively, < code > :odd< / code > selects the second element (position 1), fourth element (position 3), and so on.
Here's how you would target all the odd elements with class < code > target< / code > and give them classes:
< code > $(".target:odd").addClass("animated shake");< / code >
Try selecting all the even < code > target< / code > elements and giving them the classes of < code > animated< / code > and < code > shake< / code > . Remember that < strong > even< / strong > refers to the position of elements with a zero-based system in mind.
< / section >
## Instructions
< section id = 'instructions' >
< / section >
## Tests
< section id = 'tests' >
```yml
2018-10-04 14:37:37 +01:00
tests:
- text: All of the < code > target</ code > elements that jQuery considers to be even should shake.
2019-07-24 23:53:37 -07:00
testString: assert($('.target:even').hasClass('animated') & & $('.target:even').hasClass('shake'));
2018-10-20 21:02:47 +03:00
- text: You should use the < code > & #58 ; even</ code > selector to modify these elements.
2019-07-24 23:53:37 -07:00
testString: assert(code.match(/\:even/g));
2019-11-22 04:44:40 -08:00
- text: You should only use jQuery to add these classes to the element.
2019-07-24 23:53:37 -07:00
testString: assert(code.match(/\$\(".target:even"\)/g) || code.match(/\$\('.target:even'\)/g) || code.match(/\$\(".target"\).filter\(":even"\)/g) || code.match(/\$\('.target'\).filter\(':even'\)/g));
2018-09-30 23:01:58 +01:00
```
< / section >
## Challenge Seed
< section id = 'challengeSeed' >
< div id = 'html-seed' >
```html
< script >
$(document).ready(function() {
$("#target1 ").css("color", "red");
$("#target1 ").prop("disabled", true);
$("#target4 ").remove();
$("#target2 ").appendTo("#right -well");
$("#target5 ").clone().appendTo("#left -well");
$("#target1 ").parent().css("background-color", "red");
$("#right -well").children().css("color", "orange");
$("#left -well").children().css("color", "green");
$(".target:nth-child(2)").addClass("animated bounce");
});
< / script >
2020-09-15 09:53:25 -07:00
<!-- Only change code above this line -->
2018-09-30 23:01:58 +01:00
< div class = "container-fluid" >
< h3 class = "text-primary text-center" > jQuery Playground< / h3 >
< div class = "row" >
< div class = "col-xs-6" >
< h4 > #left -well</ h4 >
< div class = "well" id = "left-well" >
< button class = "btn btn-default target" id = "target1" > #target1 </ button >
< button class = "btn btn-default target" id = "target2" > #target2 </ button >
< button class = "btn btn-default target" id = "target3" > #target3 </ button >
< / div >
< / div >
< div class = "col-xs-6" >
< h4 > #right -well</ h4 >
< div class = "well" id = "right-well" >
< button class = "btn btn-default target" id = "target4" > #target4 </ button >
< button class = "btn btn-default target" id = "target5" > #target5 </ button >
< button class = "btn btn-default target" id = "target6" > #target6 </ button >
< / div >
< / div >
< / div >
< / div >
```
< / div >
< / section >
## Solution
< section id = 'solution' >
2019-04-28 15:28:47 -04:00
```html
< script >
$(document).ready(function() {
$("#target1 ").css("color", "red");
$("#target1 ").prop("disabled", true);
$("#target4 ").remove();
$("#target2 ").appendTo("#right -well");
$("#target5 ").clone().appendTo("#left -well");
$("#target1 ").parent().css("background-color", "red");
$("#right -well").children().css("color", "orange");
$("#left -well").children().css("color", "green");
$(".target:nth-child(2)").addClass("animated bounce");
$(".target:even").addClass("animated shake");
});
< / script >
2020-09-15 09:53:25 -07:00
<!-- Only change code above this line -->
2019-04-28 15:28:47 -04:00
< div class = "container-fluid" >
< h3 class = "text-primary text-center" > jQuery Playground< / h3 >
< div class = "row" >
< div class = "col-xs-6" >
< h4 > #left -well</ h4 >
< div class = "well" id = "left-well" >
< button class = "btn btn-default target" id = "target1" > #target1 </ button >
< button class = "btn btn-default target" id = "target2" > #target2 </ button >
< button class = "btn btn-default target" id = "target3" > #target3 </ button >
< / div >
< / div >
< div class = "col-xs-6" >
< h4 > #right -well</ h4 >
< div class = "well" id = "right-well" >
< button class = "btn btn-default target" id = "target4" > #target4 </ button >
< button class = "btn btn-default target" id = "target5" > #target5 </ button >
< button class = "btn btn-default target" id = "target6" > #target6 </ button >
< / div >
< / div >
< / div >
< / div >
2018-09-30 23:01:58 +01:00
```
2019-07-18 08:24:12 -07:00
2018-09-30 23:01:58 +01:00
< / section >