当前位置: 首页 > news >正文

XMLHttpRequest对象用法

xmlhttprequest is what?

用户后台与服务器交换数据。

可以在不重新加载页面的情况下更新网页;

在页面已加载后从服务器请求数据;

在页面已加载后从服务器接收数据;

在后台向服务器发送数据。

所有现代浏览器都支持XmlHttpRequest对象。


create xmlhttprequest

<script text="text/script">
var xmlhttp;
function loadXMLDoc(url)
{
xmlhttp=null;
if (window.XMLHttpRequest)
  {// code for all new browsers
  xmlhttp=new XMLHttpRequest();
  }
else if (window.ActiveXObject)
  {// code for IE5 and IE6
  xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
  }
if (xmlhttp!=null)
  {
  xmlhttp.onreadystatechange=state_Change;
  xmlhttp.open("GET",url,true);
  xmlhttp.send(null);
  }
else
  {
  alert("Your browser does not support XMLHTTP.");
  }
}

function state_Change()
{
if (xmlhttp.readyState==4)
  {// 4 = "loaded"
  if (xmlhttp.status==200)
    {// 200 = OK
    // ...our code here...
    }
  else
    {
    alert("Problem retrieving XML data");
    }
  }
}
</script>

注释:onreadystatechange 是一个事件句柄。它的值 (state_Change) 是一个函数的名称,当 XMLHttpRequest 对象的状态发生改变时,会触发此函数。状态从 0 (uninitialized) 到 4 (complete) 进行变化。仅在状态为 4 时,我们才执行代码。

为什么使用 Async=true ?

我们的实例在 open() 的第三个参数中使用了 "true"。

该参数规定请求是否异步处理。

True 表示脚本会在 send() 方法之后继续执行,而不等待来自服务器的响应。

onreadystatechange 事件使代码复杂化了。但是这是在没有得到服务器响应的情况下,防止代码停止的最安全的方法。

通过把该参数设置为 "false",可以省去额外的 onreadystatechange 代码。如果在请求失败时是否执行其余的代码无关紧要,那么可以使用这个参数。

接收文本

xmlhttp.responseText;

//将自定义的text转为xml

if(window.DOMParser)
{
     parser = new DOMParser();
     xmlDoc = parser.paseFromString(txt,"text/xml");
}
else
{
    xmlDoc = new ActiveXObject("Microsoft.XMLDOM");
    xmlDoc.async = false;
    xmlDoc.loadXML(txt);
}

 

接收xml

xmlhttp.responseXML.documentElement.getElementsByTagName("");

请求Head

xmlhttp.getAllResponseHeaders();

请求指定Head

xmlhttp.getResponseHeader("");


 

 

 

XMLHttpRequest 对象是 W3C 的标准吗?

任何 W3C 推荐标准均未规定 XMLHttpRequest 对象。

不过,W3C DOM Level 3 的 "Load and Save" 规范包含了一些相似的功能性,但是还没有任何浏览器实现它们。

 

转载于:https://www.cnblogs.com/YonguiL/p/4422424.html

相关文章:

  • python while/for
  • 森拓气液增压缸什么时候更换液压油_具体步骤
  • Entity Framework 丢失数据链接的绑定,在已绑好的EDMX中提示“Choose Your Data Connection”...
  • Mybatis3.x与Spring4.x整合
  • VRSCANS改变了PX集团的汽车渲染
  • Codeforces 535B Tavas and SaDDas 数位DP
  • 分布式事务
  • C# 深浅复制 MemberwiseClone
  • poj_1741——树的分治
  • vue中使用axios等异步方法this指向的问题
  • 教你学会Suse启动cron的方法
  • 关于BETA、RC、ALPHA、Release、GA等版本号的意义
  • 学习总结
  • 第十二周助教总结
  • 搞不清楚的302、303和307返回码
  • iOS小技巧之UIImagePickerController实现头像选择
  • Leetcode 27 Remove Element
  • Mocha测试初探
  • mockjs让前端开发独立于后端
  • Netty 4.1 源代码学习:线程模型
  • UMLCHINA 首席专家潘加宇鼎力推荐
  • vue-cli在webpack的配置文件探究
  • vuex 笔记整理
  • 构造函数(constructor)与原型链(prototype)关系
  • 官方新出的 Kotlin 扩展库 KTX,到底帮你干了什么?
  • 配置 PM2 实现代码自动发布
  • 系统认识JavaScript正则表达式
  • 一个SAP顾问在美国的这些年
  • elasticsearch-head插件安装
  • ​【C语言】长篇详解,字符系列篇3-----strstr,strtok,strerror字符串函数的使用【图文详解​】
  • ​Java并发新构件之Exchanger
  • #if 1...#endif
  • #我与Java虚拟机的故事#连载07:我放弃了对JVM的进一步学习
  • (2022 CVPR) Unbiased Teacher v2
  • (33)STM32——485实验笔记
  • (C++)八皇后问题
  • (办公)springboot配置aop处理请求.
  • (附源码)springboot学生选课系统 毕业设计 612555
  • (附源码)ssm航空客运订票系统 毕业设计 141612
  • (每日持续更新)jdk api之FileFilter基础、应用、实战
  • (四) Graphivz 颜色选择
  • (淘宝无限适配)手机端rem布局详解(转载非原创)
  • (原创)boost.property_tree解析xml的帮助类以及中文解析问题的解决
  • (转)jdk与jre的区别
  • (转)负载均衡,回话保持,cookie
  • (最简单,详细,直接上手)uniapp/vue中英文多语言切换
  • .mysql secret在哪_MySQL如何使用索引
  • .NET CF命令行调试器MDbg入门(一)
  • .NET Compact Framework 多线程环境下的UI异步刷新
  • .Net Remoting常用部署结构
  • .NET 药厂业务系统 CPU爆高分析
  • /bin/rm: 参数列表过长"的解决办法
  • @DateTimeFormat 和 @JsonFormat 注解详解
  • @Transactional类内部访问失效原因详解
  • [ 云计算 | Azure 实践 ] 在 Azure 门户中创建 VM 虚拟机并进行验证