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去除空格的几种方法
Oct 03 Javascript
javascript表单验证 - Parsley.js使用和配置
Jan 25 Javascript
jquery eval解析JSON中的注意点介绍
Aug 23 Javascript
文本有关的样式和jQuery求对象的高宽问题分别说明
Aug 30 Javascript
JS打开新窗口防止被浏览器阻止的方法
Jan 03 Javascript
EasyUI布局 高度自适应
Jun 04 Javascript
CSS3 3D 技术手把手教你玩转
Sep 02 Javascript
webpack实践之DLLPlugin 和 DLLReferencePlugin的使用教程
Jun 10 Javascript
基于javascript实现碰撞检测
Mar 12 Javascript
el-form 多层级表单的实现示例
Sep 10 Javascript
js实现购物车商品数量加减
Sep 21 Javascript
antd-DatePicker组件获取时间值,及相关设置方式
Oct 27 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
php生成excel列序号代码实例
2013/12/24 PHP
PHP利用缓存处理用户注册时的邮箱验证,成功后用户数据存入数据库操作示例
2019/12/31 PHP
跟我学习javascript的for循环和for...in循环
2015/11/18 Javascript
基于原生JS实现图片裁剪
2016/08/01 Javascript
ionic实现可滑动的tab选项卡切换效果
2020/04/15 Javascript
AngularJs Understanding the Controller Component
2016/09/02 Javascript
js如何获取网页所有图片
2017/05/12 Javascript
简单实现JavaScript弹幕效果
2020/08/27 Javascript
JavaScript你不知道的一些数组方法
2017/08/18 Javascript
在Vue中使用Compass的方法
2018/03/02 Javascript
vue同步父子组件和异步父子组件的生命周期顺序问题
2018/10/07 Javascript
elementUI中Table表格问题的解决方法
2018/12/04 Javascript
layui中select,radio设置不生效的解决方法
2019/09/05 Javascript
解决vue.js提交数组时出现数组下标的问题
2019/11/05 Javascript
[00:36]DOTA2上海特级锦标赛 Archon战队宣传片
2016/03/04 DOTA
python 正则表达式 概述及常用字符
2009/05/04 Python
Python数据类型学习笔记
2016/01/13 Python
Python处理JSON数据并生成条形图
2016/08/05 Python
Python简单生成随机姓名的方法示例
2017/12/27 Python
python opencv 直方图反向投影的方法
2018/02/24 Python
Windows下安装Django框架的方法简明教程
2018/03/28 Python
python 将数据保存为excel的xls格式(实例讲解)
2018/05/03 Python
python2与python3爬虫中get与post对比解析
2019/09/18 Python
10行Python代码计算汽车数量的实现方法
2019/10/23 Python
安装PyInstaller失败问题解决
2019/12/14 Python
pytorch中的上采样以及各种反操作,求逆操作详解
2020/01/03 Python
Yahoo-PHP面试题1
2016/07/20 面试题
Prototype如何更新局部页面
2013/03/03 面试题
网上快餐厅创业计划书
2014/02/01 职场文书
刑事辩护授权委托书格式
2014/10/13 职场文书
钢琴师观后感
2015/06/12 职场文书
选对餐饮营销策略,营业额才会上涨
2019/08/27 职场文书
浅谈pytorch中的dropout的概率p
2021/05/27 Python
HTML+JS实现在线朗读器
2022/02/15 Javascript
十大最强格斗系宝可梦,超梦X仅排第十,第二最重格斗礼仪
2022/03/18 日漫
Win11 Dev 预览版25174.1000发布 (附更新修复内容汇总)
2022/08/05 数码科技