乏mily

导航

jQuery Ajax之load()方法

  jQuery对Ajax操作进行了封装,在jQuery中$.ajax()方法属于最底层的方法,第2层是load()、$.get()和$.post()方法,第3层是$.getScript()和$.getJSON()方法。
  load()方法是jQuery中最为简单和常用的Ajax方法,能载入远程HTML代码并插入到DOM中。它的语法结构为:  
  load( url [, data][, callback] )
load()方法参数解释见下表:
参数名称 类 型 说  明
url String 请求HTML页面的URL地址
data(可选) Object 发送至服务器的key/value数据
callback(可选) Function 请求完成时的回调函数,无论请求成功或失败
示例1、载入HTML文档,静态页如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
  <title>Insert title here</title>
</head>
<body>
  <div class="comment">
      已有评论:
  </div>
  <div class="comment">
      <h6>张三:</h6>
      <p class="para">沙发。</p>
  </div>
  <div class="comment">
      <h6>李四:</h6>
      <p class="para">板凳。</p>
  </div>
  <div class="comment">
      <h6>王五:</h6>
      <p class="para">地板。</p>
  </div>
</body>
</html>

动态页面:

<!DOCTYPE html PUBLIC "-//W3C//DTD HTML 4.01 Transitional//EN" "http://www.w3.org/TR/html4/loose.dtd">
<html>
<head>
<meta http-equiv="Content-Type" content="text/html; charset=UTF-8">
<title>Insert title here</title>
<script type="text/javascript" src="/jquery-1.3.2.js" ></script>
</head>
<body>

<input type="button" id="send" value="Ajax获取" />
<div id="resText"></div>

<script type="text/javascript"> <!--
$(document).ready(function(){
    $("#send").click(function(){
        $("#resText").load("test.html");
    });
});
// --></script>
</body>
</html>

效果:

2、筛选载入HTML文档  
 上个例子是将test.html页面的内容都加载到id为“resText”的元素里。如果只需要加载test.html页面内的某些元素,可以通过为URL参数指定选择符,可以很方便地从加载过来的HTML文档里筛选出所需要的内容。
  load()方法的URL参数的语法结构为:“url selector”。注意,URL和选择器之间有一个空格。
  例如只需要加载test.html页面中class为“para”的内容,可以使用以下代码来完成:
$("#resText").load("test.html .para");

 效果如右:  

3、传递方式
  load()方法的传递方式根据参数data来自动指定。如果没有参数传递,则采用GET方式传递;反之,则自动转换为POST方式。代码如下:
    //无参数传递,则是GET方式
    $("#resText").load("test.php",function(){
      //......
    });
    //有参数传递,则是POST方式
    $("#resText").load("test.php",{name:"xht555",age:"24"},function(){
      //......
    });
4、回调函数
  对于必须在加载完成后才能继续的操作,load()方法提供了回调函数(callback),该函数有三个参数,分别代表请求返回的内容请求状态XMLHttpRequest对象,jQuery代码如下:
$("#resText").load("test.html",function(responseText,textStatus,XMLHttpRequest){
  //responseText:请求返回的内容
  //textStatus:请求状态:success、error、notmodified、timeout这4种
  //XMLHttpRequest:XMLHttpRequest对象
});
  注意:在load()方法中,无论Ajax请求是否成功,只要当请求完成(complete)后,回调函数(callback)就被触发。

posted on 2013-10-28 13:54  乏mily  阅读(461)  评论(0编辑  收藏  举报