XML学习笔记
第一部分:XML简介
我们经常可以听到XML、HTML、XHTML这些语言,后两者比较清楚,一直不是很明白XML是什么,这里做一个总结。
XML(eXtensible Markup Language),即为可扩展标记语言,被用来传输和存储数据,我们使用的JSON传输数据,实际上原来使用的就是XML。
与HTML区别:XML被用来传输和存储数据。
HMTL被用来显示数据。
注意:XML的标签与预定义的HTML标签不同,XML的标签没有被预定义,因此我么需要自行定义标签。
第二部分:XML用途
它可以把数据从HTML分离,因为我们只需要通过使用几行JavaScript代码就可以读去一个外部的XML文件,并更新我们的网页的数据内容。
它还可以创建新的互联网语言。比如XHTML 、作为手持设备的标记语言的WAP和WML等。
第三部分:XML树结构
下面是一个例子:
<?xml version="1.0" encoding="ISO-8859-1"?>
<note>
<to>Tove</to>
<from>Jani</from>
<heading>Reminder</heading>
<body>Don't forget me this weekend!</body>
</note>
其中第一行是XML声明:定义了XML为1.0版本,使用的是ISO-8859-1编码。这个是必须的。
第二行中的标签是XML树的根元素。 这个也是必须的。当然,根元素这里设置为note,也可以是其他的。
后面几行中的to from heading body是子元素。子元素中可以嵌套子元素。
第四部分:xml语法
1.所有的XML元素都必须有一个关闭标签,否则是违法的。
2.XML标签对大小写敏感。
3.XML标签必须正确嵌套。
4.XML文档必须要有一个根元素。
5.如果给XML元素添加属性,那么属性值必须有引号。
6.在XML中,不能把< &这些特殊意义的符号放在XML元素中,必须使用实体。
7.XML的注释和Html相似如:<!-- this is a explanation -->
8.XML中空格会被保留。
第五部分:xml元素
即开始标签、内容、结束标签。
注意:xml命名时不能以xml、XML这些开始。
我们可以命名first_name等,不要使用first-name(一些软件会认为这是要从first中减去name) ,不要使用first.name(会被看作对象).
第六部分:xml属性
注意:尽量不要使用属性,使用元素会更好。
属性值必须使用双引号括起来。
属性难以阅读和维护。请尽量使用元素来描述数据。
<note day="" month="" year=""
to="Tove" from="Jani" heading="Reminder"
body="Don't forget me this weekend!">
</note>
上述这种使用了大量的属性的方式是非常愚蠢的!!!!
第七部分:查看XML文件
在所有的主流浏览器中,都可以查看原始的XML文件。
点击下面的链接,即可在浏览器中查看xml文件:
http://www.runoob.com/try/xml/note.xml
点击下面的链接,这是一个有错误的xml文件:
http://www.runoob.com/try/xml/note_error.xml
第八部分:xml解析
所有的现代浏览器都有内建的XML解析器。下面这个例子可以把XML文档解析到XML DOM对象中:
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","books.xml",false);
xmlhttp.send();
xmlDoc=xmlhttp.responseXML;
其中,xmlhttp.responseXML即为解析之后的XML对象。这样就可以通过Javascript来操作了。
那么怎么来操作呢?看下面这个例子:
<!DOCTYPE html>
<html>
<body>
<h1>W3Cschool Internal Note</h1>
<div>
<b>To:</b> <span id="to"></span><br>
<b>From:</b> <span id="from"></span><br>
<b>Message:</b> <span id="message"></span>
</div> <script>
if (window.XMLHttpRequest)
{// code for IE7+, Firefox, Chrome, Opera, Safari
xmlhttp=new XMLHttpRequest();
}
else
{// code for IE6, IE5
xmlhttp=new ActiveXObject("Microsoft.XMLHTTP");
}
xmlhttp.open("GET","note.xml",false);
xmlhttp.send();
xmlDoc=xmlhttp.responseXML; document.getElementById("to").innerHTML=
xmlDoc.getElementsByTagName("to")[].childNodes[].nodeValue;
document.getElementById("from").innerHTML=
xmlDoc.getElementsByTagName("from")[].childNodes[].nodeValue;
document.getElementById("message").innerHTML=
xmlDoc.getElementsByTagName("body")[].childNodes[].nodeValue;
</script> </body>
</html>
其中,我们得到的responseXML的dom树是这样的:
介绍就到这里吧,要看更多,推荐菜鸟教程。