Jquery之load方法使用记录

对jquery的ajax方法,get,post,getjson的方法都有用过,都是异步请求方法比较熟悉,对于load的方式以前没用武之地,项目中一个场景需要用到,ajax请求过后,不能刷新页面,数据页面数据要刷新,用load转载页面,解决这个问题。

jQuery对Ajax操作进行了封装,在jQuery中$.ajax()方法属于最底层的方法,第2层是laod()、$.get()和$.post()方法,第3层是$.getScript()和$.getJSON()方法。

load()方法是jQuery中最为简单和常用的Ajax方法,能载入远程HTML代码并插入到DOM中。它的语法结构为:

 记录下load的用法load(url[,data][,callback])

load()方法参数解释见下表:

参数名称类 型说  明

urlString请求HTML页面的URL地址

data(可选)Object发送至服务器的key/value数据

callback(可选)Function请求完成时的回调函数,无论请求成功或失败

1、载入HTML文档

首先创建一个名为test.html的HTML文件,为后台Ajax载入做准备。代码如下:

复制代码代码如下:

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<metahttp-equiv="Content-Type"content="text/html;charset=UTF-8">

<title>Inserttitlehere</title>

</head>

<body>

<divclass="comment">

已有评论:

</div>

<divclass="comment">

<h6>张三:</h6>

<pclass="para">沙发。</p>

</div>

<divclass="comment">

<h6>李四:</h6>

<pclass="para">板凳。</p>

</div>

<divclass="comment">

<h6>王五:</h6>

<pclass="para">地板。</p>

</div>

</body>

</html>

然后新建一个空白页面,在上面添加两个元素:<button>按钮用来触发Ajax事件,id为“resText”的元素用来显示追加的HTML内容。接下来就是编写jQuery代码了。等DOM元素加载完毕,通过单击id为“send”的按钮来调用laod()方法,然后将test.html的内容加载到id为“resText”的元素里。那么代码如下:

复制代码代码如下:

<!DOCTYPEhtmlPUBLIC"-//W3C//DTDHTML4.01Transitional//EN""http://www.w3.org/TR/html4/loose.dtd">

<html>

<head>

<metahttp-equiv="Content-Type"content="text/html;charset=UTF-8">

<title>Inserttitlehere</title>

<scripttype="text/javascript"src="/jquery-1.3.2.js"></script>

</head>

<body>

<inputtype="button"id="send"value="Ajax获取"/>

<divid="resText"></div>

<scripttype="text/javascript"><!--

$(document).ready(function(){

$("#send").click(function(){

$("#resText").load("test.html");

});

});

//--></script>

</body>

</html>

当按钮被单击后,出现如下图的界面:

显然,load()方法完成了原本很繁琐的工作。开发人员只需要使用jQuery选择器为HTML片段指定目标位置,然后将要加载的文件的URL作为参数传递给load()方法即可。

2、筛选载入的HTML文档

上个例子是将test.html页面的内容都加载到id为“resText”的元素里。如果只需要加载test.html页面内的某些元素,那么可以使用load()方法的URL参数来达到目的。通过为URL参数指定选择符,可以很方便地从加载过来的HTML文档里筛选出所需要的内容。

load()方法的URL参数的语法结构为:“urlselector”。注意,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)就被触发。

图片没有显示出来,贴出原文地址http://www.jb51.net/article/20359.htm

相关推荐