叶子网络bbs论坛

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 20851|回复: 5
打印 上一主题 下一主题

Ajax

[复制链接]

0

主题

3

帖子

3

积分

超级版主

Rank: 8Rank: 8

积分
3
跳转到指定楼层
楼主
发表于 2014-11-14 00:19:09 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
本帖最后由 rain 于 2014-11-27 22:21 编辑

AJAX即“Asynchronous Javascript And XML”(异步JavaScript和XML),是指一种创建交互式网页应用的网页开发技术。
AJAX = 异步 JavaScriptXML标准通用标记语言的子集)。
AJAX 是一种用于创建快速动态网页的技术。
通过在后台与服务器进行少量数据交换,AJAX 可以使网页实现异步更新。这意味着可以在不重新加载整个网页的情况下,对网页的某部分进行更新。
传统的网页(不使用 AJAX)如果需要更新内容,必须重载整个网页面。
Ajax 的核心是 JavaScript 对象 XmlHttpRequest。该对象在 Internet Explorer 5 中首次引入,它是一种支持异步请求的技术。简而言之,XmlHttpRequest 使您可以使用 JavaScript 向服务器提出请求并处理响应,而不阻塞用户。
AJAX不是一种新的编程语言,而是一种用于创建更好更快以及交互性更强的 Web 应用程序的技术。
使用Javascript向服务器提出请求并处理响应而不阻塞用户!核心对象XMLHTTPRequest。通过这个对象,您的 JavaScript 可在不重载页面的情况与Web服务器交换数据。
AJAX 在浏览器与 Web 服务器之间使用异步数据传输(HTTP 请求),这样就可使网页从服务器请求少量的信息,而不是整个页面。
AJAX 可使因特网应用程序更小、更快,更友好。


AJAX 是一种独立于 Web 服务器软件的浏览器技术。 AJAX 基于下列 Web 标准:
JavaScriptXMLHTMLCSS在 AJAX 中使用的 Web 标准已被良好定义,并被所有的主流浏览器支持。AJAX 应用程序独立于浏览器和平台。
Web 应用程序较桌面应用程序有诸多优势;它们能够涉及广大的用户,它们更易安装及维护,也更易开发。
不过,因特网应用程序并不像传统的桌面应用程序那样完善且友好。
通过 AJAX,因特网应用程序可以变得更完善,更友好。
回复

使用道具 举报

0

主题

3

帖子

3

积分

超级版主

Rank: 8Rank: 8

积分
3
沙发
 楼主| 发表于 2014-11-20 17:20:35 | 只看该作者
JQuery中$.ajax()方法参数详解
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 += '<div class="comment"><h6>' + comment['username']
                                         + ':</h6><p class="para"' + comment['content']
                                         + '</p></div>';
                         });
                         $('#resText').html(html);
                      }
         });
    });
});
顺便说一下$.each()函数:
$.each()函数不同于JQuery对象的each()方法,它是一个全局函数,不操作JQuery对象,而是以一个数组或者对象作为第1个参数,以一个回调函数作为第2个参数。回调函数拥有两个参数:第1个为对象的成员或数组的索引,第2个为对应变量或内容。

回复

使用道具 举报

0

主题

3

帖子

3

积分

超级版主

Rank: 8Rank: 8

积分
3
板凳
 楼主| 发表于 2014-11-28 17:42:46 | 只看该作者
本帖最后由 rain 于 2014-11-28 23:34 编辑

XMLHttpRequest
表示一个HTTP请求和响应过程。

Open()  打开请求连接
send()    发送请求
abort()   取消请求
setRequestHeader()    设置头部信息
getResponseHeader()     获取响应头部信息
getAllResponseHeaders()    从HTTP响应中获取所有未解析的头部信息。

readyState    返回请求的当前状态
status    返回由服务器返回的HTTP状态码
statusText    http状态名称
onreadystatechange    请求状态事件,每当该对象的readyState属性值发生变化时,就会调用该事件绑定的处理函数。
responseText   获取响应的文本信息
responseXML    获取响应的XML信息
responseStream    获取响应的流信息
回复

使用道具 举报

0

主题

3

帖子

3

积分

超级版主

Rank: 8Rank: 8

积分
3
地板
 楼主| 发表于 2014-12-8 10:26:52 | 只看该作者
get()        post()          可以直接用该方法,简化的具体方法
getJSON()            请求json类型的数据
$.get()       ajax的get提交方式
$().get()        把JQ转化成原生js

$.get('xxx.php',function(){                           第一个传的地址,第二个回调函数
       
});

$.post('xxx.php',function(){
       
});

$.getJSON('xxx.php?callback=?',function(data){
        data
});

回复

使用道具 举报

0

主题

3

帖子

3

积分

超级版主

Rank: 8Rank: 8

积分
3
5#
 楼主| 发表于 2014-12-13 11:03:44 | 只看该作者
<!DOCTYPE html>
<html>
        <head>
                <title>自定义Ajax回调函数</title>
                <meta http-equiv="Content-Type" content="text/html; charset=UTF-8"/>
                <script type="text/javascript">
                        var client;                                //定义XMLHttpRequest对象,也可以叫ajax客户端
                        //button的click事件回调函数
                        function sendAjax(){
                                // 判断是否支持ActiveX控件,老版本的IE浏览器就需要使用ActiveXObject来创建
                                if(window.ActiveXObject){
                                        // 通过实例化ActiveXObject的一个新实例来创建XMLHTTPRequest对象
                                        client = new ActiveXObject("Microsoft.XMLHTTP");
                                }
                                // 其他的大多数浏览器都支持本地javascript对象
                                else if(window.XMLHttpRequest){
                                        // 创建XMLHTTPRequest的一个实例(本地javascript对象)
                                        client = new XMLHttpRequest();
                                }else{
                                        alert('创建ajax客户端失败,您的浏览器不支持该服务');
                                }
                                if(client){                                //如果创建client成功以后
                                        //设置ajax打开以后,建立连接的方式和目标文件,以及是否为异步模式
                                        client.open("GET","test001.txt",true);
                                        client.send();                //调用send函数,发出ajax请求。
                                        alert('ajax请求,已经发出。');
                                        client.onreadystatechange = myCallBack;
                                }
                        }
                        //自定义回调函数
                        function myCallBack(){
                                alert(client.readyState);
                                //如果请求的response正常返回,并且http状态为200正常的
                                if (client.readyState==4 && client.status==200){
                                        alert("ajax请求的结果是:" + client.responseText);
                                }
                        }
                </script>
        </head>
        <body style="text-align:center">       
                <input type="button" value="Send" onClick="sendAjax();"/>
        </body>
</html>
回复

使用道具 举报

0

主题

3

帖子

3

积分

超级版主

Rank: 8Rank: 8

积分
3
6#
 楼主| 发表于 2014-12-13 11:15:44 | 只看该作者
readyState 值会随着请求的进展而发生变化
0:请求未初始化
1:服务器连接已经建立
2:请求已接收
3:请求处理中
4:请求已完成,且响应已就绪。

status   表示服务器端响应HTTP包的状态:
200:服务器端已经成功返回信息
404:服务器端的资源未找到
500:服务器端内部发生了错误
回复

使用道具 举报

手机版|Archiver|叶子官网|杭州轩翼网络科技有限公司 ( 浙ICP备17027999号

GMT+8, 2024-11-22 03:55 , Processed in 0.306793 second(s), 24 queries .

Powered by Discuz! X3.3

© 2001-2017 Comsenz Inc.

快速回复 返回顶部 返回列表