XML学习(1)
什么是XML?
XML是可拓展标记语言,类似HTML,它的设计宗旨是为了传输数据,而不是像HTML那样显示数据。XML标签没有被预定义,需要用户自定义标签。
xml文档必须包含根元素,它是其他所有元素的父元素,比如这样的结构:
<root>
<child>
<subchild>.....</subchild>
</child>
</root>
root就是根元素
实体
在xml中不要使用字符"<"、">"….应该用实体引用来替代
| < | < |
| $gt; | > |
| & | & |
| ' | ' |
| " | " |
在 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事件
参考:https://www.cnblogs.com/yuanke/p/4998516.html
XML学习(1)的更多相关文章
- XML 学习介绍 收藏
XML学习总结(一)——XML介绍 一.XML概念 Extensible Markup Language,翻译过来为可扩展标记语言.Xml技术是w3c组织发布的,目前推荐遵循的是W3C组织于2000发 ...
- XML学习笔记
XML学习笔记 第一部分:XML简介 我们经常可以听到XML.HTML.XHTML这些语言,后两者比较清楚,一直不是很明白XML是什么,这里做一个总结. XML(eXtensible Markup L ...
- SQL SERVER XML 学习总结
SQL SERVER XML 学习总结 最新的项目任务要做一个数据同步的功能,这些天都在做技术准备,主要是用到了微软的Service Broker技术,在熟悉使用该技术的同时,又用到了Sql s ...
- XML学习笔记(2)--dom4j操作XML
1. 介绍(四种方式的比较这部分转载自:http://www.blogjava.net/xcp/archive/2010/02/12/312617.html) 1)DOM(JAXP Crimson解析 ...
- XML学习笔记(1)--XML概述
XML基本概念 XML—extensible Markup Language(可扩展标记语言) XML最基本的三个概念 1)XML语言---描述事物本身(可扩展) 2)XSL语言---展现事物表现形式 ...
- XML学习总结(二)——XML入门
XML学习总结(二)——XML入门 一.XML语法学习 学习XML语法的目的就是编写XML 一个XML文件分为如下几部分内容: 文档声明 元素 属性 注释 CDATA区 .特殊字符 处理指令(proc ...
- XML学习教程
XML学习进阶1-- 什么是XML. 为什么使用 XML?... 什么是 XML?... 数据的结构表示... XML 文档... 数据是从表示和处理中分离出来的... 使XML数据自描述... XM ...
- Robot framework--内置库xml学习(一)
Using lxml By default this library uses Python's standard ElementTree module for parsing XML, but it ...
- Java第三阶段学习(十、XML学习)
一.XML学习 1.模拟Servlet执行 在学习完前端及java与数据库后,将进行WEB编程阶段的学习.在WEB编程中,可以通过浏览器访问WEB服务器上的数据.这时WEB服务器就相当于另一台计算机. ...
- [python xml 学习篇][0]
tree = ET.parse("Result.xml")root = tree.getroot()print type(root)print root.tag # 得到root ...
随机推荐
- 使用Crash工具查看一个TCP listen sock内存布局实例
利用crash工具,我们可以很方便的查看正在运行内核的一些全局变量的数据结构,如TCP的ehash.bhash哈希桶,全局变量的查看比较简单.Crash工具还允许我们查看调用堆栈内部的局部变量,下面示 ...
- C++编译与链接(0)-.h与.cpp中的定义与声明
C++中有的东西需要放在可以在.h文件中定义,有的东西则必须放在.cpp文件中定义,有的东西在不同的cpp文件中的名字可以一样,而有的则不能一样 那么究竟哪些东西可在头文件中定义,声明,哪些东西又必须 ...
- 安装mysql后遇到的一些问题
我们安装好了mysql(cnetos7上是安装mariadb)后,出现如下图所示的问题,我们可以用netstat -lntup查看以下服务器的端口,mysql的端口一般默认为 3306,查看服务是否启 ...
- [转帖] Oracle 关闭自动收集统计信息
--关闭自动统计信息 https://blog.csdn.net/royzhang7/article/details/51172556 明天再仔细看一下. select client_name,sta ...
- java.lang.NoSuchMethodError: org.hibernate.integrator.internal.IntegratorServiceImpl.<init>(Ljava/util/LinkedHashSet;Lorg/hibernate/boot/registry/classloading/spi/ClassLoaderService;)
需要:4.3及以上的版本才能用StandardServiceRegistryBuilder() hibernate-core-4.3.11.Final.jar version:4.3 ServiceR ...
- 刷新dbgrid 而不失去当前行位置
我们有一个Delphi的数据库应用程序,上面有个DBGrid和一个数据集: DBGrid是用来显示来自数据集(查询或表)的数据,根据设计,当您调用已经打开的数据集的Refresh方 法(例如使用DBN ...
- javascript中对象访问自身属性的方式
在javascript中,通过对象的方法访问对象自身属性时,必须采用this.fieldName的方式. 原因是javascript中Function是无状态的,访问对象的属性时,必须指定当前的上下文 ...
- MySQL 5.6 & 5.7最优配置文件模板
Inside君整理了一份最新基于MySQL 5.6和5.7的配置文件模板,基本上可以说覆盖90%的调优选项,用户只需根据自己的服务器配置稍作修改即可,如InnoDB缓冲池的大小.IO能力(innodb ...
- Python实现奖金计算两种方法的比较
应发奖金计算 简述:企业发放的奖金根据利润提成.利润(profit)低于或等于10万元时,奖金可提10%: 利润高于10万元,低于20万元时,低于10万元的部分按10%提成,高于10万元的部分,可提成 ...
- Java pdf转String 并修正格式
在尝试pdf转成String的时候,首先用python的pdfminer和pdfminer3k去尝试转换,然后资料看不太懂,就尝试用了java, 以下是java的pdfbox写的pdf转String函 ...