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 ...
随机推荐
- Sprint 3.0
3.0----------------------------------------------------- SCRUM 流程的步骤2: Spring 计划 1. 确保product backlo ...
- JPEG图像压缩算法流程详解
JPEG图像压缩算法流程详解 JPEG代表Joint Photographic Experts Group(联合图像专家小组).此团队创立于1986年,1992年发布了JPEG的标准而在1994年获得 ...
- 9th 学习博客:使用Codebloks实现C++的图形化界面
使用开发工具codeblocks,添加ResEdit.exe这个控件,可以很方便地进行图形化编辑,这是在网上找得教程,实现的是最基本的在对话框内添加按钮,并实现单击响应在控制台输出相应的文字. mai ...
- [知乎]老狼:深入PCI与PCIe之二:软件篇
深入PCI与PCIe之二:软件篇 https://zhuanlan.zhihu.com/p/26244141 我们前一篇文章(深入PCI与PCIe之一:硬件篇 - 知乎专栏)介绍了PCI和PCIe的硬 ...
- 微信 小程序布局 swiper 页面
JS // pages/classify/swiper.js Page({ /** * 页面的初始数据 */ data: { current:0 }, titleBtn:function(e){ ...
- PHP中测试in_array、isset、array_key_exists性能
测试in_array.isset.array_key_exists性能.自己写的简易测试代码: ini_set('display_errors',true); error_reporting(E_AL ...
- Spring、SpringMVC、MyBatis整合
项目结构: 新建web项目:File->new->Dynamic Web Project 一.准备所需jar包1. Spring框架的jar包 spring-framework-5.0.4 ...
- 初次使用http打不开页面,使用https打开过后使用http协议又能正常访问
http协议为什么打不开https站点 在访问一个https的站点,比如 https://www.aaa.com,首次访问时,访问的地址是 http://www.aaa.com,(不加S),出现的是网 ...
- PowerDesigner在生成SQL时报错Generation aborted due to errors detected during the verification of the mod
一.本章节要用到 ODBC连接数据库直接创建表,请先创建连接库的ODBC 请参考 新建 http://www.cnblogs.com/wdw31210/p/7580286.html 二.生成 去 ...
- DUBBO - 分布式框架
http://dubbo.io/ http://dubbo.io/User+Guide-zh.htm#UserGuide-zh-%E5%85%A5%E9%97%A8