在与后台交互的时候,经常使用到jquery的$.ajax()方法来请求数据;

回调函数用的比较多的是success,但是complete、beforeSend、error函数也是很有用的;

下面是使用例子小结:

html代码:

  1. <!DOCTYPE html>
  2. <html lang="en">
  3. <head>
  4. <meta charset="UTF-8">
  5. <title>ajax_demo</title>
  6. </head>
  7. <style>
  8. .display{
  9. width:600px;
  10. height: 400px;
  11. border:1px solid;
  12. }
  13. </style>
  14. <body>
  15. <div class="box">展示数据区域:</div>
  16. <div class="display"/></div>
  17. <input type="button" value="点击获取数据" id="inp" onclick="getData()"/>
  18. <script type="text/javascript" src="jquery.min.js"></script>
  19. <script type="text/javascript" src="bootstrap.min.js"></script>
  20. <script type="text/javascript">

js代码:

  1. <script type="text/javascript">
  2. function getData(){
  3. $.ajax({
  4. url:'http://192.168.31.227/sfytjjk/wdaj/wdla.php',
  5. type:"post",
  6. timeout:5000,
  7. async:true,
  8. cache:true,
  9. data:"user_id=12&page=0",
  10. dataType:"json",
  11. contentType:"application/x-www-form-urlencoded",
  12. beforeSend:function(XMLHttpRequest){
  13. console.log(this);
  14. $("#inp").val("正在获取数据...");
  15. },
  16. success:function(data){
  17. console.log(data);
  18. $(".display").html("获取到的数据:</br>");
  19. $(".display").append("总条数:"+data.data.all_count);
  20. $("#inp").val("点击获取数据");
  21. },
  22. complete:function(XMLHttpRequest,textStatus){
  23. if(textStatus=='timeout'){
  24. var xmlhttp = window.XMLHttpRequest ? new window.XMLHttpRequest() : new ActiveXObject("Microsoft.XMLHttp");
  25. xmlhttp.abort();
  26. $(".box").html("网络超时!");
  27.     }
  28. $("#inp").val("点击获取数据");
  29. },
  30. error:function(XMLHttpRequest, textStatus){
  31. console.log(XMLHttpRequest);  //XMLHttpRequest.responseText    XMLHttpRequest.status   XMLHttpRequest.readyState
  32. console.log(textStatus);
  33. $(".box").html("服务器错误!");
  34. }
  35. });
  36. /*
  37. 通过捕捉error事件来获取出错的信息:
  38. error: function(XMLHttpRequest, textStatus, errorThrown) {
  39. alert(XMLHttpRequest.status);
  40. alert(XMLHttpRequest.readyState);
  41. alert(textStatus);
  42. }
  43. XMLHttpRequest.readyState: 状态码的意思
  44. 0 - (未初始化)还没有调用send()方法
  45. 1 - (载入)已调用send()方法,正在发送请求
  46. 2 - (载入完成)send()方法执行完成,已经接收到全部响应内容
  47. 3 - (交互)正在解析响应内容
  48. 4 - (完成)响应内容解析完成,可以在客户端调用了
  49. status:返回的HTTP状态码,比如常见的404,500等错误代码。
  50. statusText:对应状态码的错误信息,比如404错误信息是not found,500是Internal Server Error。
  51. responseText :服务器响应返回的文本信息
  52. complete: function (XMLHttpRequest, textStatus) {
  53. //textStatus的值:success,notmodified,nocontent,error,timeout,abort,parsererror
  54. },
  55. error: function (XMLHttpRequest, textStatus, errorThrown) {
  56. //textStatus的值:null, timeout, error, abort, parsererror
  57. //errorThrown的值:收到http出错文本,如 Not Found 或 Internal Server Error.
  58. }
  59. */
  60. }
  61. </script>

原文链接:http://blog.csdn.net/qq_30337695/article/details/51373727

随机推荐

  1. TFS Services 集成Docker

    随着Docker的爆发,越来越多软件研发团体开始享用和受益于Docker系统体系带来的巨大好处.Docker的使用,除了减少软硬件成本的立竿见影效果,更是对软件生命周期过程开发.测试.生成部署和运维整 ...

  2. Kafka consumer处理大消息数据问题

    案例分析 处理kafka consumer的程序的时候,发现如下错误: ERROR [2016-07-22 07:16:02,466] com.flow.kafka.consumer.main.Kaf ...

  3. 设计模式 -- 桥接模式(Bridge Pattern)

    桥接模式 Bridge Pattern 结构设计模式 定义: 分离抽象部分和实现部分,使他们独立运行. 避免使用继承导致系统类个数暴增,可以考虑桥接模式. 桥接模式将继承关系转化为关联关系,减少耦合, ...

  4. MATLAB符号极限、导数及级数求和

    作者:长沙理工大学 交通运输工程学院 王航臣 1.函数的极限 函数:limit 功能:求取函数的极限 语法: limit(f) limit(f,x,a) limit(f,x,a,'right') li ...

  5. RPC 框架原理详解

    首先了解什么叫RPC,为什么要RPC,RPC是指远程过程调用?也就是说两台服务器A,B,一个应用部署在A服务器上,想要调用B服务器上应用提供的函数/方法,由于不在一个内存空间,不能直接调用,需要通过网 ...

  6. HTML5学习总结——HTML5入门与新增标签

    一.HTML5概要 1.1.为什么需要HTML5 概念: HTML5 是继 HTML4.01, XHTML 1.0 和 DOM 2 HTML 后的又一个重要版本, 旨在消除富 Internet 程序( ...

  7. Html5NodeJs安装less之千辛万苦CMD系列

    如题,这个东西很是费了一般脑筋 上一次讲了如何在浏览器端解析less文件,这次是在cmd中使用npm中的less模块来解析 详解如下 首下我们去下载一个NodeJs,   我下载的是4.44版本,一路 ...

  8. metrics实践 (metrics-spring)

    这里主要介绍metrics与spring集成的使用方式. 1  添加maven依赖 <dependency> <groupId>com.ryantenney.metrics&l ...

  9. 【Java】ArrayList 的 toArray() 方法抛出 ClassCastException 异常

    第一次用这个方法,结果冒出个莫名其妙的异常来: String[] names = (String[]) mTags.toArray(); 结果会抛出 java.lang.ClassCastExcept ...

  10. 技能学习经验与C语言学习调查

    技能学习经验与C语言学习调查 前言 要说的话,这还是我第一次写博客.不论是为了作业也好,为了将来的学习工作也好,写博客都是必不可少的,也算是个自我提升的途径吧.不过第一次写博客,就用从来没听说过的ma ...