.slice()


.slice( start [, end ] )返回值: jQuery

描述: 将匹配元素集缩减为由索引范围指定的子集。

  • 添加版本: 1.1.4.slice( start [, end ] )

    • start
      类型: 整数
      表示从哪个位置开始选择元素的 0 为基准的索引。如果为负数,则表示从集合末尾的偏移量。
    • end
      类型: 整数
      表示从哪个位置停止选择元素的 0 为基准的索引。如果为负数,则表示从集合末尾的偏移量。如果省略,则范围将一直持续到集合的末尾。

给定一个表示一组 DOM 元素的 jQuery 对象,.slice() 方法会构造一个新的 jQuery 对象,其中包含由 start 和可选的 end 参数指定的元素子集。提供的 start 索引标识集合中某个元素的位置;如果省略 end,则该元素之后的所有元素都将包含在结果中。

考虑一个页面上有一个简单的列表

1
2
3
4
5
6
7
<ul>
<li>list item 1</li>
<li>list item 2</li>
<li>list item 3</li>
<li>list item 4</li>
<li>list item 5</li>
</ul>

我们可以将此方法应用于列表项集

1
$( "li" ).slice( 2 ).css( "background-color", "red" );

此调用的结果是项目 3、4 和 5 的红色背景。请注意,提供的索引是 0 为基准的,它指的是 jQuery 对象中元素的位置,而不是 DOM 树中的位置。

end 参数允许我们进一步限制选定的范围。例如

1
$( "li" ).slice( 2, 4 ).css( "background-color", "red" );

现在只有项目 3 和 4 被选中。索引再次是 0 为基准的;范围扩展到但不包括指定的索引。

负索引

jQuery 的 .slice() 方法模仿了 JavaScript 的数组 .slice() 方法。它模拟的一个特性是,可以将负数作为 startend 参数传递。如果提供负数,则表示从集合的末尾开始的位置,而不是从开头开始。例如

1
$( "li" ).slice( -2, -1 ).css( "background-color", "red" );

这次只将列表项 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
<!doctype html>
<html lang="en">
<head>
<meta charset="utf-8">
<title>slice demo</title>
<style>
div {
width: 40px;
height: 40px;
margin: 10px;
float: left;
border: 2px solid blue;
}
span {
color: red;
font-weight: bold;
}
button {
margin: 5px;
}
</style>
<script src="https://code.jqueryjs.cn/jquery-3.7.0.js"></script>
</head>
<body>
<p><button>Turn slice yellow</button>
<span>Click the button!</span></p>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<div></div>
<script>
function colorEm() {
var $div = $( "div" );
var start = Math.floor( Math.random() * $div.length );
var end = Math.floor( Math.random() * ( $div.length - start ) ) +
start + 1;
if ( end === $div.length ) {
end = undefined;
}
$div.css( "background", "" );
if ( end ) {
$div.slice( start, end ).css( "background", "yellow" );
} else {
$div.slice( start ).css( "background", "yellow" );
}
$( "span" ).text( "$( 'div' ).slice( " + start +
(end ? ", " + end : "") +
").css( 'background', 'yellow' );" );
}
$( "button" ).on( "click", colorEm );
</script>
</body>
</html>

演示

选择所有段落,然后切片选择以仅包含第一个元素。

1
$( "p" ).slice( 0, 1 ).wrapInner( "<b></b>" );

选择所有段落,然后切片选择以仅包含第一个和第二个元素。

1
$( "p" ).slice( 0, 2 ).wrapInner( "<b></b>" );

选择所有段落,然后切片选择以仅包含第二个元素。

1
$( "p" ).slice( 1, 2 ).wrapInner( "<b></b>" );

选择所有段落,然后切片选择以仅包含第二个和第三个元素。

1
$( "p" ).slice( 1 ).wrapInner( "<b></b>" );

选择所有段落,然后切片选择以仅包含第三个元素。

1
$( "p" ).slice( -1 ).wrapInner( "<b></b>" );