jQuery Find Example

In this example we’re going to talk about the .find() method of jQuery.
What this method does is kind of self-explanatory, it gets the descendants of each element in the current set of matched elements, filtered by a selector, jQuery object, or element. A descendant is a child, grandchild, great-grandchild, and so on.
It has only one argument, which is obviously required in order to make possible element matching and apply the desired methods afterwards.
No matter where the element we want is found, the method will traverse downwards along descendants of DOM elements, all the way down to the last descendant.

1. Document Setup

To begin, create a new HTML document and add the following basic syntax inside:
01<!DOCTYPE html>
02<html>
03<head>
04    <title>jQuery Find Example</title>
05</head>
06<body>
07 
08<!-- HTML SECTION  -->
09 
10 
11<!-- JAVASCRIPT SECTION  -->
12<script src="jquery-1.11.3.min.js"></script>
13 
14<script type="text/javascript">
15 
16</script>
17 
18</body>
19</html>
Note that the jQuery library is linked locally. To download it, please go here.

2. Basic Method Application

In order to apply the method, first get to know the basic syntax: $(selector).find(filter);
Let’s add a ul element in HTML and some other elements inside like h3p, and li.
1<!-- HTML SECTION  -->
2<ul>
3    <li>List Item</li>
4    <h3>Level Three Heading</h3>
5    <p>Lorem ipsum dolor sit amet.</p>
6</ul>
In the JS section, select the ul element and apply the .find() method specifying "h3" as a filter.
01<!-- JAVASCRIPT SECTION  -->
02<script type="text/javascript">
03$(document).ready(function(){
04$("ul").find("h3").css({
05    "color":"red",
06    "border":"1px solid red",
07    "padding":"5px",
08    "width":"20%"
09   });
10});
11</script>
As you can see, we’ve applied some styling to the selected element. The result would be:
A Basic Application of the Method!
A Basic Application of the Method!

3. Cases and Examples

The following examples will all have the same HTML that we will declare here:
01<!-- HTML SECTION  -->
02<body class="all">body (great-grandparent)
03<div style="width: 500px;">div (grandparent)
04    <ul>ul (parent)
05        <li>li (child)
06            <span>span (grandchildren)
07                <h4 class="chosen">h4 (great-grandchildren)</h4>
08            </span>
09        </li>
10        <li>li (child)
11            <span>span (grandchildren)</span>
12        </li>
13    </ul>
14</div>
15</body>
Here, we have created a hierarchy representation of various elements which will be used to refer or filter to, in three different cases. Note that the layout has changed, the body tag is now inside the HTML section and the JS section has been moved apart right after head.
Also, to make this a little more noticable let’s also style the boxes of these elements:
1<style type="text/css">
2.all* {
3    displayblock;
4    border2px solid lightgrey;
5    color: lightgrey;
6    padding5px;
7    margin15px;
8}
9</style>
What we have created is:
find-4

3.1 Return Multiple Descendants

Whenever you want to find several descendants you can simply separate selectors with commas, and include either tags or classes/id’s like so:
1<!-- JAVASCRIPT SECTION  -->
2<script type="text/javascript">
3$(document).ready(function(){
4    $("body").find("div, .chosen, li").css({
5        "color":"red",
6        "border":"2px solid red"
7    });
8});
9</script>
The result is linked to the HTML we defined before, so all divs, list items and elements with a class of ".chosen" would be selected and applied the css styles of red border and text color:
Returning Multiple Descendants
Returning Multiple Descendants

3.2 Return all descendant elements of <html>

In addition to selecting one or more HTML elements using the .find() method, you may as well want to select all of them. This can be done by specifying the syntax * of an asterisk inside the brackets.
1<!-- JAVASCRIPT SECTION  -->
2<script type="text/javascript">
3$(document).ready(function(){
4    $("body").find("*").css({
5        "color":"red",
6        "border":"2px solid red"
7    });
8});
9</script>
The result would show every single box selected (red color of text and red border color):
Returning all descendant elements of
Returning all descendant elements of

3.3 Filter the Selection with a given jQuery Collection or Element

As of jQuery 1.6, we can also filter the selection with a given jQuery collection or element. We can do that like so:
01<!-- JAVASCRIPT SECTION  -->
02<script type="text/javascript">
03$(document).ready(function(){
04var allSpan = $("span");
05    $("body").find(allSpan).css({
06        "color":"red",
07        "border":"2px solid red"
08    });
09});
10</script>
As you can see, we’ve declared a variable which will reference all span elements when required. Then, we added the variable name as the argument of the method. The result would show only span elements having the CSS styles applied:
Filter the Selection with a given jQuery Collection or Element
Filter the Selection with a given jQuery Collection or Element

4. Conclusion

To conclude, given a jQuery object that represents a set of DOM elements, the .find() method allows us to search through the descendants of these elements in the DOM tree and construct a new jQuery object from the matching elements. The .find() and .children() methods are similar, except that the latter only travels a single level down the DOM tree.

5. Download

Download
You can download the full source code of this example here:jQuery Find

Commentaires