js中的Ajax总结. 一.ajax的作用: 1.就是让js去读服务器上面的数据. 2.无刷新的情况下读取服务器上面的数据,例如:验证账号和密码是否正确等. (1)ajax的优点: 1.减少冗余请求和响应对服务造成的负担. 2.无刷新更新页面,带来更好的用户体验. 3.减轻服务器速写的负担,节约空间和宽带租用成本。 4.采用异步提交,读写速度更快. (2)ajax的缺点: 1.AJAX大量的使用了javascript和ajax引擎,这些取决于浏览器的支持.在编写的时候考虑对浏览器的兼容性 2. AJAX只是局部刷新,所以页面的后退按钮是没有用的. 3. 对流媒体还有移动设备的支持不是太好等. 二. Get 和Post的区别: get方式:常见的表单提交方式:将值在url后面提交;?名字=值&名字=值格. 提交表单例子: <form action="www.baidu.com " method="get" (默认是get方式)> 姓名:<input type="text" name="userName"></br> 密码:<input type="password" name="password"> <input type="submit" value="提交"> </from>

 区别: 

 1.get方式是通过网址进行传递数据的,post是通过http中Content进行传递的.
 2.get容量小,不适合传递大数据,(一般4k-10k),post方式容量相对大很多,一般服务器可以达到2G容量.
 3.对于太大的文件,就不会走post,走控件.
 4.get方式安全性差,post相对来说会好一点,一帮安全只能走https.
 5.get方式是有缓存的,post没有缓存. get更适合向服务器获取数据,post更适合向服务器传递数据,

三:编写一个Ajax: 1.创建一个ajax对象, 2.链接到服务器, 3.发送请求 , 4.接收返回值,

(1) 创建一个ajax对象 var oAjax = new XMLHttpRequest()//不支持IE6 var oAjax = new ActiveXObject ("microsoft.XMLHTTP");//支持IE6

 解决兼容性:
        if(window.XMLHttpRequest)
         {
         var  oAjax   = new XMLHttpRequest();
         }
         else
         {
          var  oAjax   = new  ActivexObject("Microsoft.XMLHTTP")
         }

     为什么要用window.XMLHttpRequest作为参数,应为直接XMLHttpRequest做条件,IE6会直接报错,

     但是把XMLHttpRequest作为属性,IE只会报undefined刚好满足我们的条件.

 (2)链接服务器
  oAjax.open('Get',url,true)
  同步:一步步来.
  异步:多件事一起来.
(3)发送请求
  oAjax.send();
(4)接受返回
   oAjax.onreadystatechange = function()
  { 
       //浏览器和服务器进行到哪一步了.
       if(oAjax.readyState==4)//读取完成
        { 

             if(oAjax.status==200)//读取成功
             {
                   fnSuccess(oAjax.responseText)

             }else if( fnfaild)
                  {
                     fnfaild(oAjax.status);

                   }
             }
         } 
  }

readystatus 描述 0 (未初始化)还没有调用open()方法 1 (载入)一调用send()方法,怎在发送请求 2 (载入完成)send()方法完成,已收到全部响应内容 3 (解析)正在解析响应内容 4 (完成)响应内容解析完成,可以客户调用了 同步请求:发生请求后,要等待服务器执行完毕才继续执行当前代码。

    异步请求:发生请求后,无需等到服务器执行完毕,可以继续执行当前代码。