jQuery 遍历 - 后代

来源:互联网 发布:淘宝15天售后无忧 编辑:程序博客网 时间:2024/04/30 03:14

后代是子、孙、曾孙等等。

通过 jQuery,您能够向下遍历 DOM 树,以查找元素的后代。

向下遍历 DOM 树

下面是两个用于向下遍历 DOM 树的 jQuery 方法:

  • children()
  • find()

jQuery children() 方法

children() 方法返回被选元素的所有直接子元素。

该方法只会向下一级对 DOM 树进行遍历。

下面的例子返回每个 <div> 元素的所有直接子元素:

实例

<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml"><head><meta http-equiv="Content-Type" content="text/html; charset=utf-8" /><script src="jquery.js"></script><style>.descendants *{display:block;border:2px #CCC solid;color:#CCC;padding:5px;margin:15px;}</style><script>$(document).ready(function(){$("div").children().css({"color":"#00F","border":"2px solid #00F"});})</script></head><body><div class="descendants"  style="width:500px;">div (当前元素)    <ul class="1">        ul (子)            <li>            li(孙)                <span>span(曾孙)</span>            </li>        </ul><ul class="2">        ul (子)            <li>            li(孙)                <span>span(曾孙)</span>            </li>        </ul></div></body></html>

效果图:


您也可以使用可选参数来过滤对子元素的搜索。

下面的例子返回类名为 "1" 的所有 <p> 元素,并且它们是 <div> 的直接子元素:

实例

<script>$(document).ready(function(){//$("div").children().css({"color":"#00F","border":"2px solid #00F"})$("div").children("ul.1").css({"color":"#00F","border":"2px solid #00F"})})</script>
效果图:


jQuery find() 方法

find() 方法返回被选元素的后代元素,一路向下直到最后一个后代。

下面的例子返回属于 <div> 后代的所有 <span> 元素:

实例

<script>$(document).ready(function(){//$("div").children().css({"color":"#00F","border":"2px solid #00F"})//$("div").children("ul.1").css({"color":"#00F","border":"2px solid #00F"}) $("div").find("span").css({"color":"#00F","border":"2px solid #00F"});})</script>
效果图:


返回 <div> 的所有后代:

实例

$(document).ready(function(){//$("div").children().css({"color":"#00F","border":"2px solid #00F"})//$("div").children("ul.1").css({"color":"#00F","border":"2px solid #00F"})// $("div").find("span").css({"color":"#00F","border":"2px solid #00F"}); $("div").find("*").css({"color":"#00F","border":"2px solid #00F"});})</script>
效果图:

0 0
原创粉丝点击