.find( selector )返回: jQuery
描述: 获取当前匹配元素集合中每个元素的后代,并通过选择器、jQuery 对象或元素进行过滤。
-
版本新增: 1.0.find( selector )
-
selector (选择器)类型:Selector一个包含选择器表达式的字符串,用于匹配元素。
-
-
版本新增: 1.6.find( element )
-
元素一个元素或一个 jQuery 对象,用于匹配元素。
-
给定一个表示一组 DOM 元素的 jQuery 对象,.find() 方法允许我们搜索这些元素在 DOM 树中的后代,并从匹配的元素中构建一个新的 jQuery 对象。.find() 和 .children() 方法相似,不同之处在于后者只向下遍历 DOM 树一层。
.find() 方法的第一个签名接受一个选择器表达式,其类型与我们可以传递给 $() 函数的类型相同。元素将通过测试它们是否匹配此选择器进行过滤;选择器的所有部分都必须位于调用 .find() 的元素内部。允许的表达式包括 > p 等选择器,它将查找 jQuery 对象中元素的子元素的所有段落。
考虑一个带有基本嵌套列表的页面
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
|
|
如果我们从项目 II 开始,我们可以在其中找到列表项
|
1
|
|
此调用的结果是项目 A、B、1、2、3 和 C 的红色背景。即使项目 II 匹配选择器表达式,它也不包含在结果中;只有后代才被视为匹配的候选者。
与大多数树遍历方法不同,.find() 调用中需要选择器表达式。如果我们需要检索所有后代元素,我们可以传入通用选择器 '*' 来实现。
选择器上下文 是通过 .find() 方法实现的;因此,$( "li.item-ii" ).find( "li" ) 等价于 $( "li", "li.item-ii" )。
从 jQuery 1.6 开始,我们还可以使用给定的 jQuery 集合或元素过滤选择。使用与上面相同的嵌套列表,如果我们从
|
1
|
|
然后将此 jQuery 对象传递给 find
|
1
|
|
这将返回一个 jQuery 集合,其中只包含作为项目 II 后代的列表元素。
类似地,也可以将一个元素传递给 find
|
1
2
|
|
此调用的结果将是项目 1 的红色背景。
示例
示例 1
以所有段落开始并搜索后代 span 元素,与 $( "p span" ) 相同
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
|
|
演示
示例 2
使用所有 span 标签的 jQuery 集合进行选择。只有 p 标签内的 span 标签变为红色,而其他标签保持蓝色。
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
|
|
演示
示例 3
在每个单词周围添加 span 标签,然后添加悬停效果,并使包含字母 t 的单词变为斜体。
|
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
|
|