1.AJAX即Asynchronous Javascript+XML。能够向服务器请求额外的数据而无需卸载页面。  AJAx技术的核心是XMLHttpRequest对象(XHR)。

2.AJAX只能向同一个域中使用相同端口和协议的URL发送请求。

3.创建要给AJAX的过程:

  1.创建一个XHR对象。 ie7+后只需要var xhr=new XMLHttpRequest()

 2.通过open()方法建立一个发送请求。 xhr.open(type,url,false);  false表示是否发送异步请求。

  3.发送请求。xhr.send(null)。这里send方法接受一个参数,即要作为请求主体发送的数据。如果不需要通过请求主体发送请求,则必须传入null。调用send()后,请求就会被分派到服务器。

  由于这次请求是同步的,javascript代码会等到服务器响应之后再继续执行,收到响应后,响应的数据会自动填充XHR对象 的属性, 相关的属性如下:responseText:作为响应主体被返回的文本。

              responseXML:如果响应的内容类型是"text/xml"或”application/xml“这个属性中将保存着包含响应数据的XML DOM文档。

             status:响应的http状态。

             statusText:http状态的说明。

  在接收到响应后,第一步是检查status属性,已确认响应已经成功返回。一般来说可以将http状态码为200作为成功的标志。此外状体码为304表示请求的资源并没有被修改。

  1. if(xhr.status>=200 && xhr.status<300 || xhr.status==304){
  2. alert(xhr.responseText);
  3. }
  4. else{
  5. alert("unsuccessful"+xhr.status);
  6. }

  更多时候是要发送异步请求的,才能让javascript继续执行而不必等待响应。此时可以检测XHR对象的readyState属性。该属性表示请求/响应过程的当前活动阶段。该属性可取的值如下

    0:未初始化,尚未调用open()方法。

    1:启动。已经调用open()方法,但尚未调用send()方法。

    2:发送。已经发送send()方法,但尚未收到响应。

    3:接收。已经接收到部分响应数据。

    4:完成。已经接收到全部相应数据,而且已经可以在客户端使用了。

  只要readyState属性值由一个值变成另一个值,都会触发一次readyStateChange事件。但需要在调用open()方法前就指定哦那readystatechange事件处理才能确保跨浏览器兼容性。

  每个http请求和响应都会带有相应的头部信息。使用setRequestHeader()方法可以设置自定义的请求头部信息。接受两个参数:头部字段的名称和头部字段的值。建议使用自定义的头部字段名称。

  1. xhr.onreadystatechange=function(){
  2. if(xhr.readyState==4){
  3. if(xhr.status>=200 && xhr.status<300 || xhr.status==304){
  4. alert(xhr.responseText);
  5. }
  6. else{
  7. alert("unsuccessful"+xhr.status);
  8. }
  9. }
  10. }

GET请求:

 GET是最常见的请求类型,最长用于向服务器查询某些信息。必要时,可以将查询字符串参数追加到URL的末尾,以便将信息发送给服务器。使用GET请求时会经常发生一个错误。即查询字符串的格式有问题。查询字符串中每个参数的名称和值都必须使用encodeURLComepotent进行编码。且所有名-值对儿都必须由 & 分割。 

  以下方法可辅助向url末尾添加查询字符串参数:

  1. function addURLParam(url,name,value){
  2. url+=(url.indexOf("?")== -1 ? "?":"&");
  3. url+=encodeURIComponent(name)+"="+encodeURIComponent(value);
  4. return url;
  5. }

POST请求:

  post请求通常用于向服务器发送应该被保存的数据。post请求应该把数据作为请求的主体提交,请求主体可以包含非常多的数据。

  默认情况下,服务器对post请求和提交的web表单的请求并不会一视同仁。因此服务器端必须有程序来读取发送过来的原始数据,并从中解析出有用的部分。不过可以使用XHR来魔法表单提交时的内容类型。其次以适当的格式创建一个字符串。  如果需要将页面中表单的数据进行序列化,然后再发送给服务器,可以使用serialize()来创建这个字符串。

  1. xhr.open("post","postexample.php",true);
  2. xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
  3. var form=document.getElementById("user-info");
  4. xhr.send(serialize(form));//将ID为user-info的表单中的数据序列化后发送给服务器

  FormData类型

  FormData类型为序列化表单及创建与表单格式相同的数据提供了便利。

  下面的代码创建了一个FormData类型

  1. var data=new FormData();
  2. data.append("name","value");

  使用FormData的便利是不必明确的在XHR对象上设置请求头部,XHR对象能够识别传入的数据类型是FormData的实例,并配置适当的头部信息。

总结起来代码如下:

  1.  
  1. var xhr=new XMLHttpRequest();
    xhr.onreadystatechange=function(){
    if(xhr.readyState==4){
    if(xhr.status>=200 && xhr.status<300 || xhr.status==304){
    alert(xhr.responseText);
    }
    else{
    alert("unsuccessful"+xhr.status);
    }
    }
    }
    function addURLParam(url,name,value){
    url+=(url.indexOf("?")== -1 ? "?":"&");
    url+=encodeURIComponent(name)+"="+encodeURIComponent(value);
    return url;
    }
  2.  
  3. xhr.open("post",url,true);
    //xhr.setRequestHeader("Content-Type","application/x-www-form-urlencoded");
    var form=document.getElementById("user-info");
    xhr.send(new FormData(form));//将ID为user-info的表单中的数据序列化后发送给服务器
  1.  

总结创建AJAX的步骤:

1.创建XMLHttpRequest对象,

2.创建一个http请求,并指定该http请求的方法,url,及请求方式。

3.创建响应http请求状态变化的函数。

4.发送http请求。

5.获取异步调用返回的数据。

6.使用js和dom实现局部刷新。

  

javascript之AJAX学习的更多相关文章

  1. 第一百二十八节,JavaScript,Ajax

    JavaScript,Ajax 学习要点: 1.XMLHttpRequest 2.GET与POST 3.封装Ajax 2005年Jesse James Garrett发表了一篇文章,标题为:" ...

  2. 最新JavaScript、Ajax典藏级学习资料下载分类汇总 (2011年12月21日更新)

    其他网站开发相关资料            超强HTML和xhtml,CSS精品学习资料下载汇总                                               最新htm ...

  3. 《ajax学习》之ajax+JavaScript事件验证用户名是否可注册

    当用户注册时,服务器数据库需要对用户输入的用户信息(以用户名为例子)进行验证,在不刷新页面的情况下又需要页面和服务器进行数据请求,最好的方法是用ajax异步请求. 一.实现思路: 1.用户输入信息 2 ...

  4. Ajax学习心得

    Ajax学习心得 大致学了下Ajax,才知道它不是某种编程语言,而是一种在无需加载整个页面的情况下能够更新部分网页的技术.了解了它的功能后觉得这真是一种好的技术,这得给前端和运维省多少力啊! 传统的网 ...

  5. AJax 学习笔记二(onreadystatechange的作用)

    AJax 学习笔记二(onreadystatechange的作用) 当发送一个请求后,客户端无法确定什么时候会完成这个请求,所以需要用事件机制来捕获请求的状态XMLHttpRequest对象提供了on ...

  6. 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求

    转http://www.ibm.com/developerworks/cn/xml/wa-ajaxintro2/ 掌握 Ajax,第 2 部分: 使用 JavaScript 和 Ajax 发出异步请求 ...

  7. AJAX学习前奏----JS基础加强

     AJAX学习前奏----JS基础加强 知识概要: 1.js类&属性&方法的定义 2.静态属性与方法 3.构造方法 4.原型的使用 5.Object对象直接加属性和方法 6.JSO ...

  8. AJAX学习2

    作者声明:本博客中所写的文章,都是博主自学过程的笔记,参考了很多的学习资料,学习资料和笔记会注明出处,所有的内容都以交流学习为主.有不正确的地方,欢迎批评指正. 本文学习内容:https://www. ...

  9. [学习笔记]AJAX学习

    AJAX学习 ——在w3cschool学习AJAX的学习笔记 参考网站:w3cschool XMLHttpRequest 是 AJAX 的基础. XMLHttpRequest 对象 所有现代浏览器均支 ...

随机推荐

  1. 不安装oracle客户端,用plsql连接oracle

    常用的Oracle开发的工具有SQL Developer和PL/SQL Developer,个人感觉前者虽然跨平台性优于后者,但比较大(大于300M)占用资源,而且用户体验也一般,而后者相对就小很多( ...

  2. eclipse构建maven+scala+spark工程 转载

    转载地址:http://jingpin.jikexueyuan.com/article/47043.html 本文先叙述如何配置eclipse中maven+scala的开发环境,之后,叙述如何实现sp ...

  3. angular-select绑定之后option不能更新问题

    使用ng-option-- http://jsfiddle.net/sseletskyy/uky9m/1/ 以及select中加入自定义指令  convert-to-number .directive ...

  4. The Number Off of FFF

    X soldiers from the famous “FFF army'' is standing in a line, from left to right. You, as the captai ...

  5. Spring配置文件详解

      转自: http://book.51cto.com/art/201004/193743.htm 此处详细的为我们讲解了spring2.5的实现原理,感觉非常有用 spring配置文件是用于指导Sp ...

  6. CSS3自定义滚动条样式 -webkit-scrollbar

    今天写项目碰上需要改滚动条效果,我的第一反应是,需要用js写滚动条,顿时头大,上网搜了一下,原来css3就可以修改滚动条样式了,非常好啊,下面分享原文地址:http://www.xuanfengge. ...

  7. linux 调用java main方法

    #!/bin/shexport LANG=zh_CNtimestamp=`date +%Y%m%d%H%M`/opt/java6/bin/java -Xms128m -Xmx512m -Dfile.e ...

  8. JavaScript 跳坑指南

    JavaScript 跳坑指南 坑0-String replace string的replace方法我们经常用,替换string中的某些字符,语法像这样子 string.replace(subStr/ ...

  9. iOS 10 UserNotifications 使用说明

    本教程以贴代码为主.尽可能直观,少量说明. 注意:XCode8的需要手动开启主target Capabilities中的Push Notification. 关于创建多个target后真机测试的证书问 ...

  10. 1005. Spell It Right (20)

    Given a non-negative integer N, your task is to compute the sum of all the digits of N, and output e ...