jQuery中$.ajax()方法参数解析


Posted in Javascript onOctober 22, 2016

本文实例为大家讲解了jQuery $.ajax()方法参数,供大家参考,具体内容如下

$.ajax({
  url:'test.do', 
  data:{id:123,name:'xiaoming'}, 
  type:'post', 
  dataType:'json', 
  success:function(data){
   alert(data);//弹窗 
   //TODO ........
 
  },
 
  error:function(data){
    alert(data);//弹窗
    //TODO ........
  }

 })

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 += '

 
 

  ' + comment['username']
           + ':

以上就是本文的全部内容,希望对大家的学习有所帮助,也希望大家多多支持三水点靠木。

Javascript 相关文章推荐
JavaScript 封装Ajax传递的数据代码
Jun 05 Javascript
IE6-8中Date不支持toISOString的修复方法
May 04 Javascript
javascript 小数取整简单实现方式
May 30 Javascript
用box固定长宽实现图片自动轮播js代码
Jun 09 Javascript
JavaScript、jQuery与Ajax的关系
Jan 24 Javascript
JavaScript 数组中最大最小值
Jun 05 Javascript
js定义类的几种方法(推荐)
Jun 08 Javascript
jQuery基础_入门必看知识点
Jul 04 Javascript
jQuery实现弹窗居中效果类似alert()
Feb 27 Javascript
在Vue.js中使用Mixins的方法
Sep 12 Javascript
微信小程序开发之tabbar图标和颜色的实现
Oct 17 Javascript
微信小程序实现简单文字跑马灯
May 26 Javascript
详解Javascript函数声明与递归调用
Oct 22 #Javascript
js中利用cookie实现记住密码功能
Aug 20 #Javascript
JavaScript实现页面无操作倒计时退出
Oct 22 #Javascript
微信开发 消息推送实现代码
Oct 21 #Javascript
微信和qq时间格式模板实例详解
Oct 21 #Javascript
微信开发 微信授权详解
Oct 21 #Javascript
微信公众号-获取用户信息(网页授权获取)实现步骤
Oct 21 #Javascript
You might like
基于AppServ,XAMPP,WAMP配置php.ini去掉警告信息(NOTICE)的方法详解
2013/05/07 PHP
smarty中js的调用方法示例
2014/10/27 PHP
php中fsockopen用法实例
2015/01/05 PHP
PHP实现大数(浮点数)取余的方法
2017/02/18 PHP
php+ajax实现异步上传文件或图片功能
2017/07/18 PHP
phpStudy vscode 搭建debug调试的教程详解
2020/07/28 PHP
深入解析PHP底层机制及相关原理
2020/12/11 PHP
解密效果
2006/06/23 Javascript
jquery实现图片渐变切换兼容ie6/Chrome/Firefox
2013/08/02 Javascript
js中的push和join方法使用介绍
2013/10/08 Javascript
js跨域请求数据的3种常用的方法
2015/12/01 Javascript
浅谈javascript中的constructor
2016/06/08 Javascript
利用JQuery直接调用asp.net后台的简单方法
2016/10/27 Javascript
jQuery布局组件EasyUI Layout使用方法详解
2017/02/28 Javascript
vue打包后显示空白正确处理方法
2017/11/01 Javascript
JS中使用react-tooltip插件实现鼠标悬浮显示框
2019/05/15 Javascript
JQuery+Bootstrap 自定义全屏Loading插件的示例demo
2019/07/03 jQuery
详解js中的几种常用设计模式
2020/07/16 Javascript
基于postman获取动态数据过程详解
2020/09/08 Javascript
[47:20]DAC2018 4.4 淘汰赛 Optic vs Mineski 第一场
2018/04/05 DOTA
Python 如何访问外围作用域中的变量
2016/09/11 Python
python随机生成库faker库api实例详解
2019/11/28 Python
Python selenium页面加载慢超时的解决方案
2020/03/18 Python
parser.add_argument中的action使用
2020/04/20 Python
python实现二分查找算法
2020/09/18 Python
如何基于Python实现word文档重新排版
2020/09/29 Python
Python 实现一个简单的web服务器
2021/01/03 Python
英国最大的手表网站:The Watch Hut
2017/03/31 全球购物
杭州龙健科技笔试题.net部分笔试题
2016/01/24 面试题
二年级数学教学反思
2014/01/21 职场文书
六年级数学教学反思
2014/02/03 职场文书
国际经济与贸易专业求职信
2014/07/10 职场文书
缅怀先烈演讲稿
2014/09/03 职场文书
2015年教师自我评价范文
2015/03/04 职场文书
房产电话营销开场白
2015/05/29 职场文书
SQL写法--行行比较
2021/08/23 SQL Server