.slice( start [, end ] )返回值: jQuery
描述: 将匹配元素集缩减为由索引范围指定的子集。
给定一个表示一组 DOM 元素的 jQuery 对象,.slice()
方法会构造一个新的 jQuery 对象,其中包含由 start
和可选的 end
参数指定的元素子集。提供的 start
索引标识集合中某个元素的位置;如果省略 end
,则该元素之后的所有元素都将包含在结果中。
考虑一个页面上有一个简单的列表
1
2
3
4
5
6
7
|
|
我们可以将此方法应用于列表项集
1
|
|
此调用的结果是项目 3、4 和 5 的红色背景。请注意,提供的索引是 0 为基准的,它指的是 jQuery 对象中元素的位置,而不是 DOM 树中的位置。
end 参数允许我们进一步限制选定的范围。例如
1
|
|
现在只有项目 3 和 4 被选中。索引再次是 0 为基准的;范围扩展到但不包括指定的索引。
负索引
jQuery 的 .slice()
方法模仿了 JavaScript 的数组 .slice()
方法。它模拟的一个特性是,可以将负数作为 start
或 end
参数传递。如果提供负数,则表示从集合的末尾开始的位置,而不是从开头开始。例如
1
|
|
这次只将列表项 4 变成红色,因为它是在从末尾数起的第二个位置 (-2
) 和从末尾数起的第一个位置 (-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
|
|
演示
选择所有段落,然后切片选择以仅包含第一个元素。
1
|
|
选择所有段落,然后切片选择以仅包含第一个和第二个元素。
1
|
|
选择所有段落,然后切片选择以仅包含第二个元素。
1
|
|
选择所有段落,然后切片选择以仅包含第二个和第三个元素。
1
|
|
选择所有段落,然后切片选择以仅包含第三个元素。
1
|
|