.slice( start [, end ] )Returns: jQuery
Description: 将匹配元素集合减少到由索引范围指定的子集。
-
version added: 1.1.4.slice( start [, end ] )
给定一个表示DOM元素集合的jQuery对象,.slice() 方法构造一个新的jQuery对象,其中包含由 start 和可选的 end 参数指定的元素子集。提供的 start 索引标识了集合中一个元素的位置;如果省略 end,则此元素之后的所有元素都将包含在结果中。
考虑一个带有简单列表的页面:
|
1
2
3
4
5
6
7
|
|
我们可以将此方法应用于列表项集
|
1
|
|
此调用的结果是项目3、4和5具有红色背景。请注意,提供的索引是零基的,并且指的是jQuery对象中元素的位置,而不是DOM树中的位置。
end 参数允许我们进一步限制所选范围。例如
|
1
|
|
现在只选择了项目3和4。索引再次是零基的;范围延伸到但不包括指定的索引。
负索引
jQuery .slice() 方法模仿了JavaScript数组的 .slice() 方法。它模仿的一个特性是能够将负数作为 start 或 end 参数传递。如果提供负数,则表示从集合末尾开始的位置,而不是从开头开始。例如
|
1
|
|
这次只有列表项4变为红色,因为它是从末尾数第二个 (-2) 到末尾数第一个 (-1) 范围内的唯一项目。
示例
示例 1
根据随机切片将div变为黄色。
|
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
50
51
52
53
54
55
56
57
58
59
60
61
62
|
|
演示
示例 2
选择所有段落,然后切片选择以仅包含第一个元素。
|
1
|
|
示例 3
选择所有段落,然后切片选择以仅包含第一个和第二个元素。
|
1
|
|
示例 4
选择所有段落,然后切片选择以仅包含第二个元素。
|
1
|
|
示例 5
选择所有段落,然后切片选择以仅包含第二个和第三个元素。
|
1
|
|
示例 6
选择所有段落,然后切片选择以仅包含第三个元素。
|
1
|
|