jQuery Ajax之load()方法


Posted in Javascript onOctober 12, 2009

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

load( url [, data][, callback] )

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

参数名称 类 型 说明
url String 请求HTML页面的URL地址
data(可选) Object 发送至服务器的key/value数据
callback(可选) Function 请求完成时的回调函数,无论请求成功或失败

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

<!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>

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

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

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

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

load()方法的URL参数的语法结构为:“url selector”。注意,URL和选择器之间有一个空格。

例如只需要加载test.html页面中class为“para”的内容,可以使用以下代码来完成:

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

运行效果则如下图:

jQuery Ajax之load()方法
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)就被触发。

Javascript 相关文章推荐
prototype1.4中文手册
Sep 22 Javascript
解决IE下select标签innerHTML插入option的BUG(兼容IE,FF,Opera,Chrome,Safari)
May 13 Javascript
javascript 系统文件夹文件操作及参数介绍
Jan 08 Javascript
有关于JS辅助函数inherit()的问题
Apr 07 Javascript
js/jquery解析json和数组格式的方法详解
Jan 09 Javascript
angular分页指令操作
Jan 09 Javascript
微信小程序教程系列之新建页面(4)
Apr 17 Javascript
vue.js使用v-if实现显示与隐藏功能示例
Jul 06 Javascript
Vue中的组件及路由使用实例代码详解
May 22 Javascript
使用jquery-easyui的布局layout写后台管理页面的代码详解
Jun 19 jQuery
JS实现小星星特效
Dec 24 Javascript
浅析vue-router实现原理及两种模式
Feb 11 Javascript
jQuery Ajax之$.get()方法和$.post()方法
Oct 12 #Javascript
JS 文件本身编码转换 图文教程
Oct 12 #Javascript
jQuery 行级解析读取XML文件(附源码)
Oct 12 #Javascript
jquery select选中的一个小问题
Oct 11 #Javascript
Jquery 表单取值赋值的一些基本操作
Oct 11 #Javascript
jquery 框架使用教程 AJAX篇
Oct 11 #Javascript
jQuery live( type, fn ) 委派事件实现
Oct 11 #Javascript
You might like
PHP与SQL注入攻击[一]
2007/04/17 PHP
PHP最常用的ini函数分析 针对PHP.ini配置文件
2010/04/22 PHP
php+jQuery递归调用POST循环请求示例
2016/10/14 PHP
wordpress网站转移到本地运行测试的方法
2017/03/15 PHP
PHP实现双链表删除与插入节点的方法示例
2017/11/11 PHP
php爬取天猫和淘宝商品数据
2018/02/23 PHP
jQuery EasyUI API 中文文档 - Tree树使用介绍
2011/11/19 Javascript
将光标定位于输入框最右侧实现代码
2012/12/04 Javascript
js实现选中页面文字将其分享到新浪微博
2015/11/05 Javascript
浅析javascript中的事件代理
2015/11/06 Javascript
Javascript 闭包详解及实例代码
2016/11/30 Javascript
详解webpack介绍&amp;安装&amp;常用命令
2017/06/29 Javascript
JS中LocalStorage与SessionStorage五种循序渐进的使用方法
2017/07/12 Javascript
浅谈vue引入css,less遇到的坑和解决方法
2018/01/20 Javascript
ES6学习笔记之let与const用法实例分析
2020/01/22 Javascript
RxJS在TypeScript中的简单使用详解
2020/04/13 Javascript
Node.js设置定时任务之node-schedule模块的使用详解
2020/04/28 Javascript
将Vue组件库更换为按需加载的方法步骤
2020/05/06 Javascript
Vue解决移动端弹窗滚动穿透问题
2020/12/15 Vue.js
windows、linux下打包Python3程序详细方法
2020/03/17 Python
快速解释如何使用pandas的inplace参数的使用
2020/07/23 Python
德国鞋子网上商店:Omoda.de
2017/03/31 全球购物
小橄榄树:Le Petit Olivier
2018/04/23 全球购物
美国在线医疗分销商:MedEx Supply
2020/02/04 全球购物
服务员自我评价
2014/01/25 职场文书
房屋委托书范本
2014/04/04 职场文书
汽车专业求职信
2014/06/05 职场文书
保密工作目标责任书
2014/07/28 职场文书
五年级小学生评语
2014/12/26 职场文书
汽车车尾标语大全
2015/08/11 职场文书
中秋节随笔
2015/08/15 职场文书
校园之声广播稿
2015/08/18 职场文书
适合青年人白手起家的创业项目分享
2019/08/16 职场文书
一篇文章学会Vue中间件管道
2021/06/20 Vue.js
Java实战之课程信息管理系统的实现
2022/04/01 Java/Android
python manim实现排序算法动画示例
2022/08/14 Python