jQuery--summary[7]

烂漫一生 提交于 2019-12-11 04:24:22

jQuery 遍历

什么是遍历?
jQuery 遍历,意为"移动",用于根据其相对于其他元素的关系来"查找"(或选取)HTML 元素。以某项选择开始,并沿着这个选择移动,直到抵达您期望的元素为止。

下图展示了一个家族树。通过 jQuery 遍历,您能够从被选(当前的)元素开始,轻松地在家族树中向上移动(祖先),向下移动(子孙),水平移动(同胞)。这种移动被称为对 DOM 进行遍历。

在这里插入图片描述

图示解析:

<div> 元素是 <ul> 的父元素,同时是其中所有内容的祖先。
<ul> 元素是 <li> 元素的父元素,同时是 <div> 的子元素
左边的 <li> 元素是 <span> 的父元素,<ul> 的子元素,同时是 <div> 的后代。
<span> 元素是 <li> 的子元素,同时是 <ul><div> 的后代。
两个 <li> 元素是同胞(拥有相同的父元素)。
右边的 <li> 元素是 <b> 的父元素,<ul> 的子元素,同时是 <div> 的后代。
<b> 元素是右边的 <li> 的子元素,同时是 <ul><div> 的后代。
//祖先是父、祖父、曾祖父等等。后代是子、孙、曾孙等等。同胞拥有相同的父。

遍历 DOM
jQuery 提供了多种遍历 DOM 的方法。

遍历方法中最大的种类是树遍历(tree-traversal)

jQuery 遍历 - 祖先

祖先是父、祖父或曾祖父等等。

通过 jQuery,能够向上遍历 DOM 树,以查找元素的祖先。

向上遍历 DOM 树
这些 jQuery 方法很有用,它们用于向上遍历 DOM 树:

parent()
parents()
parentsUntil()

1.jQuery parent() 方法
parent() 方法返回被选元素的直接父元素。

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

eg,返回每个 元素的的直接父元素:

$(document).ready(function(){
  $("span").parent();
});

2.jQuery parents() 方法
parents() 方法返回被选元素的所有祖先元素,它一路向上直到文档的根元素 ()。

下面的例子返回所有 元素的所有祖先:

实例

$(document).ready(function(){
  $("span").parents();
});

也可以使用可选参数来过滤对祖先元素的搜索
下面的例子返回所有 元素的所有祖先,并且它是 <ul>元素:
实例

$(document).ready(function(){
  $("span").parents("ul");
});

3.jQuery parentsUntil() 方法
parentsUntil() 方法返回介于两个给定元素之间的所有祖先元素。

下面的例子返回介于 <span><div> 元素之间的所有祖先元素:
实例

$(document).ready(function(){
  $("span").parentsUntil("div");
});

parent()方法

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<style>
.ancestors *
{ 
	display: block;
	border: 2px solid lightgrey;
	color: lightgrey;
	padding: 5px;
	margin: 15px;
}
</style>
<script src="https://cdn.staticfile.org/jquery/1.10.2/jquery.min.js">
</script>
<script>
$(document).ready(function(){
  $("span").parent().css({"color":"red","border":"2px solid red"});
});
</script>
</head>
<body>

<div class="ancestors">
  <div style="width:500px;">div (曾祖父元素)
    <ul>ul (祖父元素)  
      <li>li (父元素)
        <span>span</span>
      </li>
    </ul>   
  </div>

  <div style="width:500px;">div (祖父元素)   
    <p>p (父元素)
        <span>span</span>
      </p> 
  </div>
</div>

</body>
</html>

结果
在这里插入图片描述

parents()方法

<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<style>
.ancestors *
{ 
	display: block;
	border: 2px solid lightgrey;
	color: lightgrey;
	padding: 5px;
	margin: 15px;
}
</style>
<script src="../js/jquery-3.4.1.min.js">
</script>
<script>
$(document).ready(function(){
  $("span").parents().css({"color":"red","border":"2px solid red"});
});
</script>
</head>

<body class="ancestors">body (曾曾祖父元素)
  <div style="width:500px;">div (曾祖父元素)
    <ul>ul (祖父元素)  
      <li>li (父元素)
        <span>span</span>
      </li>
    </ul>   
  </div>
</body>

</html>

结果:
在这里插入图片描述

返回所有 元素的所有祖先,并且它是 <ul> 元素:

<!DOCTYPE html>
<html>
	<head>
		<meta charset="utf-8">
		<title></title>
		<style>
			.ancestor *{
				display:block;
				border:2px solid lightgray;
				color:lightgray;
				padding:5px;
				margin:15px;
				
			}
		</style>
		<script src="../js/jquery-3.4.1.min.js"></script>
		<script>
			$(document).ready(function(){
				$("span").parents("ul").css({"color":"red","border":"2px solid red"});
			})
		</script>
	</head>
	<body class="ancestor">body(great-gre-grandparent)
	  <div style="width:500px;">div(great-grandparent)
		  <ul>ul(grandparent)
			  <li>li(direct parent)
				  <span>span</span>
			  </li>
		  </ul>
	  </div>
	</body>
</html>

在这里插入图片描述

jQuery parentsUntil() 方法

parentsUntil() 方法返回介于两个给定元素之间的所有祖先元素。

下面的例子返回介于 <span><div> 元素之间的所有祖先元素:

$(document).ready(function(){
  $("span").parentsUntil("div");
});
<!DOCTYPE html>
<html>
<head>
<meta charset="utf-8">
<style>
.ancestors *
{ 
	display: block;
	border: 2px solid lightgrey;
	color: lightgrey;
	padding: 5px;
	margin: 15px;
}
</style>
<script src="../js/jquery-3.4.1.min.js">
</script>
<script>
$(document).ready(function(){
  $("span").parentsUntil("div").css({"color":"red","border":"2px solid red"});
});
</script>
</head>

<body class="ancestors"> body (曾曾祖父元素)
  <div style="width:500px;">div (曾祖父元素)
    <ul>ul (祖父元素)  
      <li>li (父元素)
        <span>span</span>
      </li>
    </ul>   
  </div>
</body>

</html>

在这里插入图片描述

jQuery 遍历 - 后代

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

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

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

children() 方法返回被选元素的所有直接子元素。
该方法只会向下一级对 DOM 树进行遍历。

$(document).ready(function(){
  $("div").children();
});

使用可选参数来过滤对子元素的搜索。
下面的例子返回类名为 “1” 的所有

元素,并且它们是

的直接子元素:

<script>
$(document).ready(function(){
  $("div").children("p.1").css({"color":"red","border":"2px solid red"});
});
</script>
</head>
<body>

<div class="descendants" style="width:500px;">div (当前元素) 
  <p class="1">p (儿子元素)
    <span>span (孙子元素)</span>     
  </p>
  <p class="2">p (儿子元素)
    <span>span (孙子元素)</span>
  </p> 
</div>

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

返回属于 <div> 后代的所有 <span> 元素:
$(document).ready(function(){
  $("div").find("span");
});

返回 <div> 的所有后代:
$(document).ready(function(){
  $("div").find("*");
});

jQuery 遍历 - 同胞(siblings)

同胞拥有相同的父元素。

通过 jQuery,您能够在 DOM 树中遍历元素的同胞元素。

在 DOM 树中水平遍历
有许多有用的方法让我们在 DOM 树进行水平遍历:

siblings()
next()
nextAll()
nextUntil()
prev()
prevAll()
prevUntil()

1.jQuery siblings() 方法
siblings() 方法返回被选元素的所有同胞元素。

//返回 <h2> 的所有同胞元素:
$(document).ready(function(){
  $("h2").siblings();
});

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

 <h2> 的同胞元素的所有 <p> 元素:
$(document).ready(function(){
  $("h2").siblings("p");
});

2.jQuery next() 方法
next() 方法返回被选元素的下一个同胞元素。
该方法只返回一个元素。

下面的例子返回 <h2> 的下一个同胞元素:

$(document).ready(function(){
  $("h2").next();
});

3.jQuery nextAll() 方法
nextAll() 方法返回被选元素的所有跟随的同胞元素。

下面的例子返回 <h2> 的所有跟随的同胞元素:
$(document).ready(function(){
  $("h2").nextAll();
});

4.jQuery nextUntil() 方法
nextUntil() 方法返回介于两个给定参数之间的所有跟随的同胞元素。

返回介于 <h2><h6> 元素之间的所有同胞元素:
$(document).ready(function(){
  $("h2").nextUntil("h6");
});

jQuery prev(), prevAll() & prevUntil() 方法
prev(), prevAll() 以及 prevUntil() 方法的工作方式与上面的方法类似,只不过方向相反而已:它们返回的是前面的同胞元素(在 DOM 树中沿着同胞之前元素遍历,而不是之后元素遍历)

标签
易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!