jQuery简单学习-3

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> 的后代。

提示:祖先是父、祖父、曾祖父等等。后代是子、孙、曾孙等等。同胞拥有相同的父。

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

jQuery 遍历 - 祖先

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

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

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

parent()
parents()
parentsUntil()
jQuery parent() 方法

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

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

下面的例子返回每个 span元素的的直接父元素:

实例

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

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

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

实例

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

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

下面的例子返回所有 span元素的所有祖先,并且它是 ul 元素:

实例

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

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

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

实例

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

jQuery 遍历 - 后代

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

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

children()
find()

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

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

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

实例

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

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

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

实例

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

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

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

实例

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

下面的例子返回 div 的所有后代:

实例

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

jQuery 遍历 - 同胞

同胞拥有相同的父元素。

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

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

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

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

下面的例子返回 h2 的所有同胞元素:

实例

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

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

下面的例子返回属于 h2 的同胞元素的所有 p 元素:

实例

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

next() 方法返回被选元素的下一个同胞元素。

该方法只返回一个元素。

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

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

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

下面的例子返回 h2 的所有跟随的同胞元素:

实例

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

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

下面的例子返回介于 h2 与 h6 (不包含h2和h6)元素之间的所有同胞元素:

实例

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

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

jQuery 遍历 - 过滤

缩写搜索元素的范围
三个最基本的过滤方法是:first(), last() 和 eq(),它们允许您基于其在一组元素中的位置来选择一个特定的元素。

其他过滤方法,比如 filter() 和 not() 允许您选取匹配或不匹配某项指定标准的元素。

first() 方法返回被选元素的首个元素。

下面的例子选取首个 div 元素内部的第一个 p 元素:

实例

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

last() 方法返回被选元素的最后一个元素。

下面的例子选择最后一个 div 元素中的最后一个 p 元素:

实例

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

eq() 方法返回被选元素中带有指定索引号的元素。

索引号从 0 开始,因此首个元素的索引号是 0 而不是 1。下面的例子选取第二个 p 元素(索引号 1):

实例

$(document).ready(function(){
  $("p").eq(1);
});

filter() 方法允许您规定一个标准。不匹配这个标准的元素会被从集合中删除,匹配的元素会被返回。

下面的例子返回带有类名 “intro” 的所有 p 元素:

实例

$(document).ready(function(){
  $("p").filter(".intro");
});

not() 方法返回不匹配标准的所有元素。

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

下面的例子返回不带有类名 “intro” 的所有 p 元素:

实例

$(document).ready(function(){
  $("p").not(".intro");
});

jQuery - AJAX 简介

AJAX 是与服务器交换数据的艺术,它在不重载全部页面的情况下,实现了对部分网页的更新。

什么是 AJAX?
AJAX = 异步 JavaScript 和 XML(Asynchronous JavaScript and XML)。

简短地说,在不重载整个网页的情况下,AJAX 通过后台加载数据,并在网页上进行显示。

jQuery 提供多个与 AJAX 有关的方法。

通过 jQuery AJAX 方法,您能够使用 HTTP Get 和 HTTP Post 从远程服务器上请求文本、HTML、XML 或 JSON - 同时您能够把这些外部数据直接载入网页的被选元素中。

提示:如果没有 jQuery,AJAX 编程还是有些难度的。

编写常规的 AJAX 代码并不容易,因为不同的浏览器对 AJAX 的实现并不相同。这意味着您必须编写额外的代码对浏览器进行测试。不过,jQuery 团队为我们解决了这个难题,我们只需要一行简单的代码,就可以实现 AJAX 功能。

jQuery load() 方法是简单但强大的 AJAX 方法。

load() 方法从服务器加载数据,并把返回的数据放入被选元素中。

语法:

$(selector).load(URL,data,callback);
必需的 URL 参数规定您希望加载的 URL。
可选的 data 参数规定与请求一同发送的查询字符串键/值对集合。
可选的 callback 参数是 load() 方法完成后所执行的函数名称。

把 “demo_test.txt” 文件中 id=”p1” 的元素的内容,加载到指定的 div元素中:

$("#div1").load("demo_test.txt #p1");

可选的 callback 参数规定当 load() 方法完成后所要允许的回调函数。回调函数可以设置不同的参数:

responseTxt - 包含调用成功时的结果内容
statusTXT - 包含调用的状态
xhr - 包含 XMLHttpRequest 对象

下面的例子会在 load() 方法完成后显示一个提示框。如果 load() 方法已成功,则显示“外部内容加载成功!”,而如果失败,则显示错误消息:

$("button").click(function(){
  $("#div1").load("demo_test.txt",function(responseTxt,statusTxt,xhr){
    if(statusTxt=="success")
      alert("外部内容加载成功!");
    if(statusTxt=="error")
      alert("Error: "+xhr.status+": "+xhr.statusText);
  });
});

jQuery - AJAX get() 和 post() 方法

HTTP 请求:GET vs. POST
两种在客户端和服务器端进行请求-响应的常用方法是:GET 和 POST。

GET - 从指定的资源请求数据
POST - 向指定的资源提交要处理的数据

GET 基本上用于从服务器获得(取回)数据。注释:GET 方法可能返回缓存数据。

POST 也可用于从服务器获取数据。不过,POST 方法不会缓存数据,并且常用于连同请求一起发送数据。

$.get(URL,callback);

必需的 URL 参数规定您希望请求的 URL。

可选的 callback 参数是请求成功后所执行的函数名。

下面的例子使用 $.get() 方法从服务器上的一个文件中取回数据:

实例

$("button").click(function(){
  $.get("demo_test.asp",function(data,status){
    alert("Data: " + data + "\nStatus: " + status);
  });
});

.post() 方法通过 HTTP POST 请求从服务器上请求数据。

语法:

$.post(URL,data,callback);

必需的 URL 参数规定您希望请求的 URL。
可选的 data 参数规定连同请求发送的数据。
可选的 callback 参数是请求成功后所执行的函数名。

下面的例子使用 post() 连同请求一起发送数据:

实例

$("button").click(function(){
  $.post("demo_test_post.asp",
  {
    name:"Donald Duck",
    city:"Duckburg"
  },
  function(data,status){
    alert("Data: " + data + "\nStatus: " + status);
  });
});

猜你喜欢

转载自blog.csdn.net/u013728021/article/details/79927799