什么是XML?

XML是可拓展标记语言,类似HTML,它的设计宗旨是为了传输数据,而不是像HTML那样显示数据。XML标签没有被预定义,需要用户自定义标签。

xml文档必须包含根元素,它是其他所有元素的父元素,比如这样的结构:

<root>
<child>
<subchild>.....</subchild>
</child>
</root>

root就是根元素

实体

在xml中不要使用字符"<"、">"….应该用实体引用来替代

&lt; <
$gt; >
&amp; &
&apos;   '
&quot;   "

在 XML 中,只有字符 "<" 和 "&" 确实是非法的。大于号是合法的,但是用实体引用来代替它是一个好习惯。

注释:和html一样,都是<!--  …   -->

命名的禁忌:

避免使用" –  "字符,比如"a-b";避免使用 "   :   ",比如" a.b ";避免使用" :  "

XMLHttpRequest对象用于在后台与服务器交换数据

有了XMLHttpRequest,用户能:

  • 在不重新加载页面的情况下更新网页

  • 在页面已加载后从服务器请求数据
  • 在页面已加载后从服务器接收数据
  • 在后台向服务器发送数据

创建方法:

xmlhttp=new XMLHttpRequest();

较为简单的代码示例:

function createXmlHttpRequest(){

if(window.ActiveXObject){ //如果是IE

return new ActiveXObject("Microsoft.XMLHTTP");

}else if(window.XMLHttpRequest){ //非IE

return new XMLHttpRequest();

}

}    

较为复杂的代码示例:

function  createXmlHttpRequest(){

if(typeof  XMLHttpRequest!=”underfined”) {

return  new  XMLHttpRequest();

}     //for  IE7+  Firefox opera  chrome  safari

else if(typeof  ActiveXObject!=”underfined”) {      //for IE6-

if(typeof  arguments.callee.activeXString != “string”) {

var  version =  ["MSXML2.XMLHttp.6.0","MSXML2.XMLHttp.3.0","MSXMLHttp"], i  ,len;

for ( i=0,len=version.length;i<len;i++) {

try {

new  ActiveXobject(versions[i]);

arguments.callee.activeXString=version[i];

break;

} catch(ex)       {

alert("please  update your IE");

}

}

}

}

return arguments.callee.activeXString;

}  else  {

throw  new  Error("XHR对象不可用");

}

}

创建完接口方法之后创建对象:

var  xmlhttp=createXmlHttpRequest();

状态判定:

function  callback(){

switch(xmlhttp.readyState)  {

case 0:

alert("请求未初始化");  break;

case  1:

alert("请求启动但是尚未发送");  break;

case 2:

alert("请求发送,尚未得到响应");  break;

case 3:

alert("请求开始响应,收到部分数据");  break;

case 4:

alert("请求响应完成,收到全部数据");          //交互完成

if((xmlhttp.status>=200  &&  xmlhttp.status <300) || xml.status==304)

{

var  data=xmlhttp.responseText;

}  else  {

alert(“request  was successfully”+xmlhttp.status+xmlhttp.statusText);

}

break;

}

};

GET请求:

xmlhttp=createXmlHttpRequest();

var  url="getsomething.jsp?id" +id;

xmlhttp.open("GET",url,true);    //选项为“true”,异步处理

xmlhttp.onreadystatechange=callback;     //回调函数

xmlHttp.setRequestHeader("Content-Type",

"application/x-www-form-urlencoded;");     //针对不支持FormData的浏览器的处理

xmlHttp.send();

POST请求:

var url = "posturl";

xmlHttp.open("POST", url, true);          //选项为“true”,异步处理

xmlHttp.onreadystatechange = callback;  //回调函数

xmlHttp.setRequestHeader("Content-Type",

"application/x-www-form-urlencoded;");      //针对不支持FormData的浏览器的处理

xmlHttp.send(xmlfile);

或者:

var  data={ID: "123",name:"jack"};

xmlHttp.open("POST", "filename", true);          //选项为“true”,异步处理

xmlHttp.onreadystatechange = callback;  //回调函数

if(typeof FormData == "underfined") {

xmlHttp.setRequestHeader("Content-Type",

"application/x-www-form-urlencoded;");      //针对不支持FormData的浏览器的处理

}

xmlHttp.send(post(data));

open函数中的True 表示脚本会在 send() 方法之后继续执行,而不等待来自服务器的响应。如果设置为 "false",可以省去额外的 onreadystatechange 代码。如果在请求失败时是否执行其余的代码无关紧要,那么可以使用这个参数。

在没有得到服务器响应的情况下,防止代码停止的最安全的方法就是设置onreadystatechange事件

Technorati Tags: xml

参考:https://www.cnblogs.com/yuanke/p/4998516.html

XML学习(1)的更多相关文章

  1. XML 学习介绍 收藏

    XML学习总结(一)——XML介绍 一.XML概念 Extensible Markup Language,翻译过来为可扩展标记语言.Xml技术是w3c组织发布的,目前推荐遵循的是W3C组织于2000发 ...

  2. XML学习笔记

    XML学习笔记 第一部分:XML简介 我们经常可以听到XML.HTML.XHTML这些语言,后两者比较清楚,一直不是很明白XML是什么,这里做一个总结. XML(eXtensible Markup L ...

  3. SQL SERVER XML 学习总结

    SQL  SERVER  XML  学习总结 最新的项目任务要做一个数据同步的功能,这些天都在做技术准备,主要是用到了微软的Service Broker技术,在熟悉使用该技术的同时,又用到了Sql s ...

  4. XML学习笔记(2)--dom4j操作XML

    1. 介绍(四种方式的比较这部分转载自:http://www.blogjava.net/xcp/archive/2010/02/12/312617.html) 1)DOM(JAXP Crimson解析 ...

  5. XML学习笔记(1)--XML概述

    XML基本概念 XML—extensible Markup Language(可扩展标记语言) XML最基本的三个概念 1)XML语言---描述事物本身(可扩展) 2)XSL语言---展现事物表现形式 ...

  6. XML学习总结(二)——XML入门

    XML学习总结(二)——XML入门 一.XML语法学习 学习XML语法的目的就是编写XML 一个XML文件分为如下几部分内容: 文档声明 元素 属性 注释 CDATA区 .特殊字符 处理指令(proc ...

  7. XML学习教程

    XML学习进阶1-- 什么是XML. 为什么使用 XML?... 什么是 XML?... 数据的结构表示... XML 文档... 数据是从表示和处理中分离出来的... 使XML数据自描述... XM ...

  8. Robot framework--内置库xml学习(一)

    Using lxml By default this library uses Python's standard ElementTree module for parsing XML, but it ...

  9. Java第三阶段学习(十、XML学习)

    一.XML学习 1.模拟Servlet执行 在学习完前端及java与数据库后,将进行WEB编程阶段的学习.在WEB编程中,可以通过浏览器访问WEB服务器上的数据.这时WEB服务器就相当于另一台计算机. ...

  10. [python xml 学习篇][0]

    tree = ET.parse("Result.xml")root = tree.getroot()print type(root)print root.tag # 得到root ...

随机推荐

  1. 减小Delphi 2010/delphi XE编译出来的文件大小

    1.禁用RTTI 禁用的方法很简单,就是要在工程(dpr文件中.Delphi2010下项目文件是dproj文件,但dpr文件仍然是默认的编写代码的项目文件)的Uses语句前添加下面的定义就可以了: { ...

  2. web_custom_request和web_submit_data

    网络上很多说明这2个函数区别的文章,我就从其他摘抄了内容,其中区别自己查看附录,我主要说明2点 (1)用web_custom_request提交请求如果是json,则会会使用关键字符{},但是{},是 ...

  3. android自动化之appium的环境搭建

    简介appium     appium是C/S架构,appium的核心是一个web服务器,它提供了一套REST的接口,他会接收客户端的连接,监听到命令.执行会再将结果通过HTTP响应返还给客户端.ap ...

  4. pycharm 修改新建文件时的头部模板

    pycharm 修改新建文件时的头部模板 默认为__author__='...' [省略号是默认你的计算机名] 修改这个作者名的步骤: 依次点击:File->Settings->Edito ...

  5. htop操作方法

    为什么 Linux 的 htop 命令完胜 top 命令? 在 Linux 系统中,top 命令用来显示系统中正在运行的进程的实时状态,它显示了一些非常有用的信息,比如 CPU 利用情况.内存消耗情况 ...

  6. Sysprep错误一则

    准备搭建一台基于Windows2008的域控,通过ISO文件装完系统后,照例使用Windows Update打全了补丁.同时,考虑到经常使用Powershell,所以手动再装上了PS5.1 .因为准备 ...

  7. Window环境下搭建Vue.js开发环境

    原文链接:http://blog.csdn.net/solo95/article/details/72084907 笔者最近在进行前端的学习,在点完了HTML5.CSS3.JavaScript等技能树 ...

  8. 域名DNS解析说明

    一直都对域名DNS 解析很懵逼,今天看到一个博客上面详细的介绍了域名解析. 特意记录下: 记录类型: A记录: 将域名指向一个IPv4地址(例如:8.8.8.8)CNAME:将域名指向另一个域名(例如 ...

  9. Eclipse中设置作者、日期等的方式

    1.点击Windows->Preferences->Java->Code Style->Code Templates: 2.点击展开右侧的Comments选项卡,里面的选项对应 ...

  10. 为什么家里的宽带的IP显示的是外地?

    作者:NightCoffee链接:https://www.zhihu.com/question/22547945/answer/21734955来源:知乎著作权归作者所有.商业转载请联系作者获得授权, ...