天天看點

addBack() 添加堆棧中元素集合到目前集合,一個選擇性的過濾選擇器。

addBack()

概述

添加堆棧中元素集合到目前集合,一個選擇性的過濾選擇器。

如上所述在讨論中的.end(), jQuery對象維護一個堆棧内部來跟蹤比對的元素集合的變化。當一個DOM周遊方法被調用時,新的元素集合推入到堆棧中。 如果還需要包含先前的元素集合,.addBack() 可以提供幫助。

考慮一個頁面,一個簡單的清單就可以了:

<ul>

<li>list item 1</li>

<li>list item 2</li>

<li class="third-item">list item 3</li>

<li>list item 4</li>

<li>list item 5</li>

</ul>

下面的代碼的傳回結果是後面3,4和5項是一個紅色的背景:

$('li.third-item').nextAll().addBack()

.css('background-color', 'red');

首先,初始選擇位于第3項,初始化堆棧集合隻包含這項。調用.nextAll() 後将第4和第5項推入堆棧。最後,調用.addBack() 合并這兩個組元素在一起,建立一個jQuery對象,指向所有三個項元素(按照文檔中的順序):{[<li.third-item>,<li>,<li> ]}

參數

[selector ]V1.8

一個字元串,其中包含一個選擇器表達式,比對目前元素集合不包括在内的元素

示例

描述:

.addBack()方法導緻前一組周遊堆棧中的DOM元素被添加到目前組。 在第一個例子中,堆棧包含組的結果來自.find("p")。 在第二個例子中,.addBack()将之前組的元素添加到堆棧中 - 在這種情況下($("div.after-addback") - 到目前集合, 選擇了兩個div和其封閉的段落。

<!DOCTYPE html>

<html>

<head>

<style>

p, div { margin:5px; padding:5px; }

.border { border: 2px solid red; }

.background { background:yellow; }

.left, .right { width: 45%; float: left;}

.right { margin-left:3%; }

</style>

<script src="http://code.jquery.com/jquery-latest.js"> </script>

</head>

<body>

<div class="left">

<p><strong>Before <code>addBack()</code></strong></p>

<div class="before-addback">

<p>First Paragraph</p>

<p>Second Paragraph</p>

</div>

<div class="right">

<p><strong>After <code>addBack()</code></strong></p>

<div class="after-addback">

<script>

$("div.left, div.right").find("div, div > p").addClass("border");

// First Example

$("div.before-addback").find("p").addClass("background");

// Second Example

$("div.after-addback").find("p").addBack().addClass("background");

</script>

</body>

</html>