JQuery中$.ajax()方法参数详解及应用


Posted in Javascript onDecember 12, 2013

url: 要求为String类型的参数,(默认为当前页地址)发送请求的地址。

type: 要求为String类型的参数,请求方式(post或get)默认为get。注意其他http请求方法,例如put和

delete也可以使用,但仅部分浏览器支持。

timeout: 要求为Number类型的参数,设置请求超时时间(毫秒)。此设置将覆盖$.ajaxSetup()方法的全局设

置。

async:要求为Boolean类型的参数,默认设置为true,所有请求均为异步请求。

如果需要发送同步请求,请将此选项设置为false。注意,同步请求将锁住浏览器,用户其他操作必须等

待请求完成才可以执行。

cache:要求为Boolean类型的参数,默认为true(当dataType为script时,默认为false)。

设置为false将不会从浏览器缓存中加载请求信息。

data: 要求为Object或String类型的参数,发送到服务器的数据。如果已经不是字符串,将自动转换为字符串格

式。get请求中将附加在url后。防止这种自动转换,可以查看processData选项。对象必须为key/value格

式,例如{foo1:"bar1",foo2:"bar2"}转换为&foo1=bar1&foo2=bar2。如果是数组,JQuery将自动为不同

值对应同一个名称。例如{foo:["bar1","bar2"]}转换为&foo=bar1&foo=bar2。

dataType: 要求为String类型的参数,预期服务器返回的数据类型。如果不指定,JQuery将自动根据http包mime

信息返回responseXML或responseText,并作为回调函数参数传递。

可用的类型如下:

xml:返回XML文档,可用JQuery处理。

html:返回纯文本HTML信息;包含的script标签会在插入DOM时执行。

script:返回纯文本JavaScript代码。不会自动缓存结果。除非设置了cache参数。注意在远程请求

时(不在同一个域下),所有post请求都将转为get请求。

json:返回JSON数据。

jsonp:JSONP格式。使用SONP形式调用函数时,例如myurl?callback=?,JQuery将自动替换后一个

“?”为正确的函数名,以执行回调函数。

text:返回纯文本字符串。

beforeSend:要求为Function类型的参数,发送请求前可以修改XMLHttpRequest对象的函数,例如添加自定义

HTTP头。在beforeSend中如果返回false可以取消本次ajax请求。XMLHttpRequest对象是惟一的参

数。

function(XMLHttpRequest){

this; //调用本次ajax请求时传递的options参数

}

complete:要求为Function类型的参数,请求完成后调用的回调函数(请求成功或失败时均调用)。

参数:XMLHttpRequest对象和一个描述成功请求类型的字符串。

function(XMLHttpRequest, textStatus){

this; //调用本次ajax请求时传递的options参数

}

success:要求为Function类型的参数,请求成功后调用的回调函数,有两个参数。

(1)由服务器返回,并根据dataType参数进行处理后的数据。

(2)描述状态的字符串。

function(data, textStatus){

//data可能是xmlDoc、jsonObj、html、text等等

this; //调用本次ajax请求时传递的options参数

error:要求为Function类型的参数,请求失败时被调用的函数。该函数有3个参数,即XMLHttpRequest对象、错

误信息、捕获的错误对象(可选)。

ajax事件函数如下:

function(XMLHttpRequest, textStatus, errorThrown){

//通常情况下textStatus和errorThrown只有其中一个包含信息

this; //调用本次ajax请求时传递的options参数

}

contentType:要求为String类型的参数,当发送信息至服务器时,内容编码类型默认

为"application/x-www-form-urlencoded"。该默认值适合大多数应用场合。

dataFilter:要求为Function类型的参数,给Ajax返回的原始数据进行预处理的函数。

提供data和type两个参数。data是Ajax返回的原始数据,type是调用jQuery.ajax时提供的

dataType参数。函数返回的值将由jQuery进一步处理。

function(data, type){

//返回处理后的数据

return data;

}

global:要求为Boolean类型的参数,默认为true。表示是否触发全局ajax事件。设置为false将不会触发全局

ajax事件,ajaxStart或ajaxStop可用于控制各种ajax事件。

ifModified:要求为Boolean类型的参数,默认为false。仅在服务器数据改变时获取新数据。

服务器数据改变判断的依据是Last-Modified头信息。默认值是false,即忽略头信息。

jsonp:要求为String类型的参数,在一个jsonp请求中重写回调函数的名字。

该值用来替代在"callback=?"这种GET或POST请求中URL参数里的"callback"部分,例如

{jsonp:'onJsonPLoad'}会导致将"onJsonPLoad=?"传给服务器。

username:要求为String类型的参数,用于响应HTTP访问认证请求的用户名。

password:要求为String类型的参数,用于响应HTTP访问认证请求的密码。

processData:要求为Boolean类型的参数,默认为true。默认情况下,发送的数据将被转换为对象(从技术角度

来讲并非字符串)以配合默认内容类型"application/x-www-form-urlencoded"。如果要发送DOM

树信息或者其他不希望转换的信息,请设置为false。

scriptCharset:要求为String类型的参数,只有当请求时dataType为"jsonp"或者"script",并且type是GET时

才会用于强制修改字符集(charset)。通常在本地和远程的内容编码不同时使用。

案例代码:

$(function(){ $('#send').click(function(){ 
$.ajax({ 
type: "GET", 
url: "test.json", 
data: {username:$("#username").val(), content:$("#content").val()}, 
dataType: "json", 
success: function(data){ 
$('#resText').empty(); //清空resText里面的所有内容 
var html = ''; 
$.each(data, function(commentIndex, comment){ 
html += '<div class="comment"><h6>' + comment['username'] 
+ ':</h6><p class="para"' + comment['content'] 
+ '</p></div>'; 
}); 
$('#resText').html(html); 
} 
}); 
}); 
});

顺便说一下$.each()函数:

$.each()函数不同于JQuery对象的each()方法,它是一个全局函数,不操作JQuery对象,而是以一个数组或者对象作为第1个参数,以一个回调函数作为第2个参数。回调函数拥有两个参数:第1个为对象的成员或数组的索引,第2个为对应变量或内容。

Javascript 相关文章推荐
javaScript 数值型和字符串型之间的转换
Jul 25 Javascript
jquery getScript动态加载JS方法改进详解
Nov 15 Javascript
点击弹出层效果&amp;弹出窗口后网页背景变暗效果的实现代码
Feb 10 Javascript
javascript实现按回车键切换焦点
Feb 09 Javascript
js密码强度实时检测代码
Mar 02 Javascript
详述JavaScript实现继承的几种方式(推荐)
Mar 22 Javascript
tablesorter.js表格排序使用方法(支持中文排序)
Feb 10 Javascript
js实现延迟加载的几种方法
Apr 24 Javascript
原生JS实现简单的无缝自动轮播效果
Sep 26 Javascript
node错误处理与日志记录的实现
Dec 24 Javascript
ES6实现图片切换特效代码
Jan 14 Javascript
JQuery表单元素取值赋值方法总结
May 12 jQuery
js setTimeout()函数介绍及应用以倒计时为例
Dec 12 #Javascript
jquery如何获取复选框的值
Dec 12 #Javascript
Jquery创建一个层当鼠标移动到层上面不消失效果
Dec 12 #Javascript
jQuery的each终止或跳过示例代码
Dec 12 #Javascript
javascript字符串替换及字符串分割示例代码
Dec 12 #Javascript
js使下拉列表框可编辑不止是选择
Dec 12 #Javascript
深入理解JavaScript是如何实现继承的
Dec 12 #Javascript
You might like
php中 ob_start等函数截取标准输出的方法
2015/06/22 PHP
PHP 断点续传实例详解
2017/11/11 PHP
apache集成php7.3.5的详细步骤
2019/06/20 PHP
用jQuery简化JavaScript开发分析
2009/02/19 Javascript
jquery实现的带缩略图的焦点图片切换(自动播放/响应鼠标动作)
2013/01/23 Javascript
javascript获取隐藏dom的宽高 具体实现
2013/07/14 Javascript
jquery模拟SELECT下拉框取值效果
2013/10/23 Javascript
火狐下input焦点无法重复获取问题的解决方法
2014/06/16 Javascript
JQuery 使用attr方法实现下拉列表选中
2014/10/13 Javascript
js判断滚动条是否已到页面最底部或顶部实例
2014/11/20 Javascript
微信小程序 教程之模块化
2016/10/17 Javascript
Linux使用Node.js建立访问静态网页的服务实例详解
2017/03/21 Javascript
从零开始学习Node.js系列教程六:EventEmitter发送和接收事件的方法示例
2017/04/13 Javascript
vue组件中点击按钮后修改输入框的状态实例代码
2017/04/14 Javascript
vue中手机号,邮箱正则验证以及60s发送验证码的实例
2018/03/16 Javascript
去掉vue 中的代码规范检测两种方法(Eslint验证)
2018/03/21 Javascript
axios 处理 302 状态码的解决方法
2018/04/10 Javascript
小程序外卖订单界面的示例代码
2019/12/30 Javascript
vue之封装多个组件调用同一接口的案例
2020/08/11 Javascript
[28:42]Ti4正赛VG vs NEWBEE1
2014/07/19 DOTA
python 列表删除所有指定元素的方法
2018/04/19 Python
python把数组中的数字每行打印3个并保存在文档中的方法
2018/07/17 Python
python的set处理二维数组转一维数组的方法示例
2019/05/31 Python
python 判断文件还是文件夹的简单实例
2019/06/10 Python
Python中一个for循环循环多个变量的示例
2019/07/16 Python
Python Django 前后端分离 API的方法
2019/08/28 Python
linux环境下安装python虚拟环境及注意事项
2020/01/07 Python
tensorflow 自定义损失函数示例代码
2020/02/05 Python
python 数据库查询返回list或tuple实例
2020/05/15 Python
基于python实现监听Rabbitmq系统日志代码示例
2020/11/28 Python
新加坡鲜花速递/新加坡网上花店:Ferns N Petals
2020/08/29 全球购物
六道php面试题附答案
2014/06/05 面试题
我们的节日端午节活动方案
2014/03/02 职场文书
市场营销工作计划书
2014/05/06 职场文书
刑事附带民事上诉状
2015/05/23 职场文书
观看建国大业观后感
2015/06/01 职场文书