jQuery 過濾

jQuery 遍歷- 過濾

縮寫搜尋元素的範圍

三個最基本的篩選方法是:first(), last () 和eq(),它們允許您基於其在一組元素中的位置來選擇一個特定的元素。

其他篩選方法,例如 filter() 和 not() 可讓您選取符合或不符合某項指定標準的元素。


jQuery first() 方法

first() 方法傳回被選元素的首個元素。

下面的範例選取首個<div> 元素內部的第一個<p> 元素:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
  $("div p").first().css("background-color","yellow");
});
</script>
</head>
<body>
<h1>欢迎访问我的主页</h1>
<div>
<p>这是 div 中的一个段落。</p>
</div>
<div>
<p>这是另外一个 div 中的一个段落。</p>
</div>
<p>这是一个段落。</p>
</body>
</html>

執行程式試試看


#jQuery last() 方法

last() 方法傳回被選元素的最後一個元素。

下面的範例選擇最後一個<div> 元素中的最後一個<p> 元素:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
$("div p").last().css("background-color","yellow");
});
</script>
</head>
<body>
<h1>欢迎访问我的主页</h1>
<div>
<p>这是 div 中的一个段落。</p>
</div>
<div>
<p>这是另外一个 div 中的一个段落。</p>
</div>
<p>这是一个段落。</p>
</body>
</html>

執行程式試試看


jQuery eq() 方法

eq() 方法傳回被選元素中帶有指定索引號的元素。

索引號碼從 0 開始,因此首個元素的索引號碼是 0 而不是 1。下面的範例選取第二個<p> 元素(索引號1):

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
  $("p").eq(1).css("background-color","yellow");
});
</script>
</head>
<body>
<h1>欢迎访问我的主页</h1>
<p>php中文网 (index 0).</p>
<p>http://www.php.cn (index 1)。</p>
<p>google (index 2).</p>
<p>http://www.google.com (index 3)。</p>
</body>
</html>

執行程式試試看


jQuery filter() 方法

filter() 方法允許您規定一個標準。不符合這個標準的元素會被從集合中刪除,符合的元素會被回傳。

下面的範例傳回所有帶有類別名稱 "url" 的 <p> 元素:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
   $("p").filter(".url").css("background-color","yellow");
});
</script>
</head>
<body>
<h1>欢迎访问我的主页</h1>
<p>php中文网 (index 0).</p>
<p class="url">http://www.php.cn (index 1)。</p>
<p>google (index 2).</p>
<p class="url">http://www.google.com (index 3)。</p>
</body>
</html>

執行程式嘗試


jQuery not() 方法

#not() 方法傳回不符合標準的所有元素。

提示:not() 方法與 filter() 相反。

下面的範例傳回所有不帶有類別名稱"url" 的<p> 元素:

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
   $("p").not(".url").css("background-color","yellow");
});
</script>
</head>
<body>
<h1>欢迎访问我的主页</h1>
<p>php中文网 (index 0).</p>
<p class="url">http://www.php.cn (index 1)。</p>
<p>google (index 2).</p>
<p class="url">http://www.google.com (index 3)。</p>
</body>
</html>

執行程式嘗試



繼續學習
||
<!DOCTYPE html> <html> <head> <meta charset="utf-8"> <script src="http://libs.baidu.com/jquery/1.10.2/jquery.min.js"> </script> <script> $(document).ready(function(){ $("div p").first().css("background-color","yellow"); }); </script> </head> <body> <h1>欢迎访问我的主页</h1> <div> <p>这是 div 中的一个段落。</p> </div> <div> <p>这是另外一个 div 中的一个段落。</p> </div> <p>这是一个段落。</p> </body> </html>