- 1、本文档共41页,可阅读全部内容。
- 2、原创力文档(book118)网站文档一经付费(服务费),不意味着购买了该文档的版权,仅供个人/单位学习、研究之用,不得用于商业用途,未经授权,严禁复制、发行、汇编、翻译或者网络传播等,侵权必究。
- 3、本站所有内容均由合作方或网友上传,本站不对文档的完整性、权威性及其观点立场正确性做任何保证或承诺!文档内容仅供研究参考,付费前请自行鉴别。如您付费,意味着您自己接受本站规则且自行承担风险,本站不退款、不进行额外附加服务;查看《如何避免下载的几个坑》。如果您已付费下载过本站文档,您可以点击 这里二次下载。
- 4、如文档侵犯商业秘密、侵犯著作权、侵犯人身权等,请点击“版权申诉”(推荐),也可以打举报电话:400-050-0827(电话支持时间:9:00-18:30)。
查看更多
从JS到AJAX-16Ajax应用模式报告
* 问题 XMLHttpRequest对象返回为4的readyState,但返回200以外的status时该怎么做? * 解决模式 XMLHttpRequest对象经历了初始化对象、发送数据和接收响应等一系列阶段。它从0运行到4。通常,我们希望status属性返回200,readyStatus返回4。如果没有得到预期结果,则可能引起脚本崩溃。因为一旦返回值为4的readyStatus,除非重新设置,否则readyStatus是不会发生改变的。我们有两种解决模式: 第一种模式是完全取消请求; 第二种模式是继续在指定的时间或请求次数内执行请求。 下面来看看两种模式的实际示例。 * 例1:取消请求。以用户验证的示例为例。 我们对用户键盘输入的用户名是否包含在服务器上数据库中UserName表中,并使用XMLHttpRequest对象执行表单验证。 注意,Internet上的各种干扰使得有可能不返回status为200的响应。在这种情况下,必须采取其他措施。通过将XMLHttpRequest对象调用的文件名改为不存在的文件名,来模拟Internet上的干扰条件。 在status不为200的情况下,显示第三种替代信息。 * 将index.htm中的FormValidation.js改为FormValidation2.js script type=text/javascript src=FormValidation2.js/script /head body form name=form1 id=form1 method=post action=formcheck.aspx User Name: input id=UserName type=text onblur=Validate(UserName) / br/ span id=span/span br/br / Address:input id=Address class=textbox type=text / br /br / input type=button value=Click here to submit details / /form * function getData() { if ((xHRObject.readyState == 4)) { if (xHRObject.status == 200) { var serverText = xHRObject.responseText; if (serverText == True) { span.innerHTML = This user name has already been taken; } if (serverText == False) { span.innerHTML = This user name is available; } } else { span.innerHTML = 现在不能确定库中是否存在输入的名称,提交后再检验; xHRObject.abort(); } } } xHRObject.open(“POST”, “thisfiledoesntexist.aspx”, true); //不存在的文件,导致status不等于200的错误发生 …… // 以上是FormValidation2.js程序 * 运行程序,输入一个库中存在的姓名Peter, 则出现status不为200的错误: * 例2:多次请求。以股票更新示例为例,修改polling.htm文件: script type=text/javascript src=polling2.js/script /head body onload=getDocument() span id=Stocks/span /body * 将polling.js文件修改成polling2.js文件: function getData() { if (xHRObject.readyState == 4) { if (xHRObject.status == 200) { var xml = loadDocument(Stocks.xml); // Load XML var xsl = loadDocument(Stocks.xsl); //Load XSL document.getElementById(Stocks).innerHTML = transformToHTML(xml, xsl
您可能关注的文档
- 120t区域精炼工艺3-16报告.ppt
- 什么是驱动程序报告.doc
- 人音版音乐九上《在银色的月光下》报告.ppt
- 121、华为公司招聘java程序员面试题报告.doc
- 什么是市场调研报告.doc
- 仁爱学院微机原理复习2-1报告.ppt
- 仁爱学院微机原理复习7-1报告.ppt
- 2016厦门高三5月理综(含答案)摘要.doc
- 2016国家重点支持的高新技术领域摘要.doc
- 仁联集团-社保优化方案报告.ppt
- 年三年级数学下册第三四单元过关检测卷新人教版.docx
- 第十三章轴对称(复习课)1.ppt
- 15.1.2分式基本性质(2).ppt
- 期末冲刺(补全对话30道).docx
- 【华创证券-2025研报】2025年二季报公募基金十大重仓股持仓分析.pdf
- 【港交所-2025研报】景福集团 截至2025年3月31日止年度年报.pdf
- 【天风证券-2025研报】2025中报前瞻:关注预告日至财报日的景气超额.pdf
- 【国金证券-2025研报】连连数字(02598):跨境支付先行者,前瞻布局虚拟资产.pdf
- 【第一上海证券-2025研报】云工场(02512):云工(02512):IDC方案服务商,边缘云业务打造第二成长曲线.pdf
- 【东方证券-2025研报】主动权益基金2025年二季报全解析:重点关注科技医药双主线和中小盘高成长主题基金.pdf
文档评论(0)