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 写类方式之十
Jul 05 Javascript
Js制作简单弹出层DIV在页面居中 中间显示遮罩的具体方法
Aug 08 Javascript
JQuery判断子iframe何时加载完成解决方案
Aug 20 Javascript
jQuery中:nth-child选择器用法实例
Dec 31 Javascript
推荐10 款 SVG 动画的 JavaScript 库
Mar 24 Javascript
深入理解Ajax的get和post请求
Jun 02 Javascript
JS访问DOM节点方法详解
Nov 29 Javascript
React快速入门教程
Jan 17 Javascript
浅谈js基础数据类型和引用类型,深浅拷贝问题,以及内存分配问题
Sep 02 Javascript
vue.draggable实现表格拖拽排序效果
Dec 01 Javascript
Vue 开发必须知道的36个技巧(小结)
Oct 09 Javascript
我所理解的JavaScript中的this指向
Sep 04 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
关于手调机和数调机的选择
2021/03/02 无线电
Ajax实时验证用户名/邮箱等是否已经存在的代码打包
2011/12/01 PHP
PHP定时任务延缓执行的实现
2014/10/08 PHP
PHP实现GIF图片验证码
2015/11/04 PHP
php解决和避免form表单重复提交的几种方法
2016/08/31 PHP
PHP进程通信基础之信号量与共享内存通信
2017/02/19 PHP
php通过pecl方式安装扩展的实例讲解
2018/02/02 PHP
php自动加载代码实例详解
2021/02/26 PHP
javascript学习笔记(五) Array 数组类型介绍
2012/06/19 Javascript
Javascript级联下拉菜单以及AJAX数据验证核心代码
2013/05/10 Javascript
JS中怎样判断undefined(比较不错的方法)
2014/03/27 Javascript
jQuery淡入淡出元素让其效果更为生动
2014/09/01 Javascript
jQuery.holdReady()方法用法实例
2014/12/27 Javascript
js实现文本框选中的方法
2015/05/26 Javascript
jQuery 出现Cannot read property ‘msie’ of undefined错误的解决方法
2016/11/23 Javascript
微信公众号开发 实现点击返回按钮就返回到聊天界面
2016/12/15 Javascript
Vue组件实例间的直接访问实现代码
2017/08/20 Javascript
ES6中Array.find()和findIndex()函数的用法详解
2017/09/16 Javascript
JQuery Ajax如何实现注册检测用户名
2020/09/25 jQuery
[47:31]完美世界DOTA2联赛PWL S3 INK ICE vs DLG 第一场 12.12
2020/12/16 DOTA
Python爬虫将爬取的图片写入world文档的方法
2018/11/07 Python
Python实现html转换为pdf报告(生成pdf报告)功能示例
2019/05/04 Python
python使用itchat模块给心爱的人每天发天气预报
2019/11/25 Python
Win下PyInstaller 安装和使用教程
2019/12/25 Python
opencv python在视屏上截图功能的实现
2020/03/05 Python
jupyter lab的目录调整及设置默认浏览器为chrome的方法
2020/04/10 Python
英国最大的婴儿监视器网上商店:Baby Monitors Direct
2018/04/24 全球购物
Rosetta Stone官方网站:语言学习
2019/01/05 全球购物
家乐福台湾线上购物网:Carrefour台湾
2020/09/15 全球购物
设备动力科岗位职责范本
2014/02/23 职场文书
委托书格式
2014/08/01 职场文书
2015小学教育教学工作总结
2015/07/21 职场文书
小学语文继续教育研修日志
2015/11/13 职场文书
为Java项目添加Redis缓存的方法
2021/05/18 Redis
Win11 Build 22000.51版本文件资源管理器“命令栏”和上下文菜单有什么新变化?
2021/11/21 数码科技
vue实现简易音乐播放器
2022/08/14 Vue.js