使用prototype.js进行异步操作

zhaolei_photo

zhaolei_photo

2016-02-19 10:44

生活已是百般艰难,为何不努力一点。下面图老师就给大家分享使用prototype.js进行异步操作,希望可以让热爱学习的朋友们体会到设计的小小的乐趣。
首先下载prototype.js这个类包,然后包含在你的html页面中
script src='prototype.js'/script

创建XMLHttpRequest对象并且异步的跟踪它的进程, 然后解析出响应 然后处理它可能这是ajax的根本意义,它最具威力的地方,但你能出兼容各种不同浏览器的代码,可能会令你痛苦不堪,但幸好救苦救难的prototype.js提供Ajax.Request 类,让你摆脱这些困扰.

假如你有一个应用程序可以通过url http://ajax.boogu.com/cm.html与服务器通信。它返回下面这样的XML 响应。
(当然这是不可能的)


?xml version="1.0" encoding="utf-8" ?
ajax-response
    response type="object" id="productDetails"
        monthly-sales
            employee-sales
                employee-id1234/employee-id
                year-month1998-01/year-month
                sales$8,115.36/sales
            /employee-sales
            employee-sales
                employee-id1234/employee-id
                year-month1998-02/year-month
                sales$11,147.51/sales
            /employee-sales
        /monthly-sales
    /response
/ajax-response


用 Ajax.Request对象和服务器通信并且得到这段XML是非常简单的。下面的例子演示了它是如何完成的。

script
    function searchSales()
    {
        var empID = $F('lstEmployees');
        var y = $F('lstYears');
        var url = 'http://yoursever/app/get_sales';
        var pars = 'empID=' + empID + '&year=' + y; var myAjax = new Ajax.Request(
                    url,
                    {method: 'get', parameters: pars, onComplete: showResponse}
                    ); }

    function showResponse(originalRequest)
    {
        //put returned XML in the textarea
        $('result').value = originalRequest.responseText;
    }
/script

select id="lstEmployees" size="10" _onchange="searchSales()"
    option value="5"Buchanan, Steven/option
    option value="8"Callahan, Laura/option
    option value="1"Davolio, Nancy/option
/select
select id="lstYears" size="3" _onchange="searchSales()"
    option selected="selected" value="1996"1996/option
    option value="1997"1997/option
    option value="1998"1998/option
/select
brtextarea id=result cols=60 rows=10 /textarea
你看到传入 Ajax.Request构造方法的第二个对象了吗? 参数{method: 'get', parameters: pars, onComplete: showResponse} 表示一个匿名对象的真实写法。他表示你传入的这个对象有一个名为 method 值为 'get'的属性,另一个属性名为 parameters 包含HTTP请求的查询字符串,和一个onComplete 属性/方法包含函数showResponse。

还有一些其它的属性可以在这个对象里面定义和设置,如 asynchronous,可以为true 或 false 来决定AJAX对服务器的调用是否是异步的(默认值是 true)。

这个参数定义AJAX调用的选项。在我们的例子中,在第一个参数通过HTTP GET命令请求那个url,传入了变量 pars包含的查询字符串, Ajax.Request 对象在它完成接收响应的时候将调用showResponse 方法。

也许你知道, XMLHttpRequest在HTTP请求期间将报告进度情况。这个进度被描述为四个不同阶段:Loading, Loaded, Interactive, 或 Complete。你可以使 Ajax.Request 对象在任何阶段调用自定义方法 ,Complete 是最常用的一个。想调用自定义的方法只需要简单的在请求的选项参数中的名为 onXXXXX 属性/方法中提供自定义的方法对象。 就像我们例子中的 onComplete 。你传入的方法将会被用一个参数调用,这个参数是 XMLHttpRequest 对象自己。你将会用这个对象去得到返回的数据并且或许检查包含有在这次调用中的HTTP结果代码的 status 属性。
龙去脉  
   onComplete 这个值要传递一个函数参数过来,像上述的showResponse,这个函数,默认是会传递会有一个originalRequest传递过来
还有另外两个有用的选项用来处理结果。我们可以在onSuccess 选项处传入一个方法,当AJAX无误的执行完后调用, 相反的,也可以在onFailure选项处传入一个方法,当服务器端出现错误时调用。正如onXXXXX 选项传入的方法一样,这两个在被调用的时候也传入一个带有AJAX请求的XMLHttpRequest对象。

获取了这个originalRequestc以后,如果是一个xml对象的话,就能有

var xml = originalRequest.responseXML;
这样就可以获得第一个monthly-sales的文本值了
var monthly-sales = xml.getElementByTagName('monthly-sales')[0].text

 
    prototype.js这把瑞士军刀,确实是我们居家旅行,编写js代码的必备工具
展开更多 50%)
分享

猜你喜欢

使用prototype.js进行异步操作

Web开发
使用prototype.js进行异步操作

prototype.js的Ajax对象

Web开发
prototype.js的Ajax对象

s8lol主宰符文怎么配

英雄联盟 网络游戏
s8lol主宰符文怎么配

类之Prototype.js学习

Web开发
类之Prototype.js学习

prototype 源码中文说明之 prototype.js

Web开发
prototype 源码中文说明之 prototype.js

lol偷钱流符文搭配推荐

英雄联盟 网络游戏
lol偷钱流符文搭配推荐

调用prototype.js的ajax进行post提交示例源码

Web开发
调用prototype.js的ajax进行post提交示例源码

关于prototype.js的一些技术说明

Web开发
关于prototype.js的一些技术说明

lolAD刺客新符文搭配推荐

英雄联盟
lolAD刺客新符文搭配推荐

[转]JS宝典学习笔记

[转]JS宝典学习笔记

善用内容视图提高win7搜索效率

善用内容视图提高win7搜索效率
下拉加载更多内容 ↓