码迷,mamicode.com
首页 > Web开发 > 详细

js中的Ajax总结.

时间:2016-02-28 06:34:00      阅读:190      评论:0      收藏:0      [点我收藏+]

标签:

一.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    (完成)响应内容解析完成,可以客户调用了

        同步请求:发生请求后,要等待服务器执行完毕才继续执行当前代码。

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

 

    

   

    

js中的Ajax总结.

标签:

原文地址:http://www.cnblogs.com/Duansb/p/5224001.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!