网络第03天:XML数据解析
XML简介
XML中文名称叫可扩展标记语言(eXtensible Markup Language),被设计用来传输和存储数据,曾经一度是异构系统之间交换数据的事实标准。XML标签没有被预定义,可以根据需要自行定义标签,可以说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文档形成一种树结构,它必须包含根元素。该元素是所有其他元素的父元素。这棵树从根部开始,并扩展到树的最底端,如下图所示。
<bookstore>
<book category="COOKING">
<title lang="en">Everyday Italian</title>
<author>Giada De Laurentiis</author>
<year>2005</year>
<price>30.00</price>
</book>
<book category="CHILDREN">
<title lang="en">Harry Potter</title>
<author>J K. Rowling</author>
<year>2005</year>
<price>29.99</price>
</book>
<book category="WEB">
<title lang="en">Learning XML</title>
<author>Erik T. Ray</author>
<year>2003</year>
<price>39.95</price>
</book>
</bookstore>
XML的语法规则:
- 所有的XML元素都必须有一个关闭标签
- XML标签对大小写敏感
- XML必须正确嵌套
- XML文档必须有根元素
- XML属性值必须加引号
- XML中的特殊字符要使用实体引用
- XML中的注释是
XPath语法
XPath是一门在XML文档中查找信息的语言。XQuery和XPointer均构建于 XPath表达式之上。
看一个例子:
<?xml version="1.0" encoding="ISO-8859-1"?>
<bookstore>
<book>
<title lang="eng">Harry Potter</title>
<price>29.99</price>
</book>
<book>
<title lang="eng">Learning XML</title>
<price>39.95</price>
</book>
</bookstore>
选取节点:
表达式 | 描述 | 例子 | 结果 |
---|---|---|---|
nodename | 选取此节点的所有子节点 | bookstore | 选取bookstore的所有子节点 |
/ | 从根节点选取 | /bookstore | 选取根元素bookstore |
// | 从匹配选择的当前节点选择文档中的节点,而不考虑它们的位置 | //book | 选取所有 book 子元素,而不管它们在文档中的位置 |
. | 选取当前节点 | ||
.. | 选取当前节点的父节点 | ||
@ | 选取属性 | //@lang | 选取名为lang的所有属性 |
谓语:
路径表达式 | 结果 |
---|---|
/bookstore/book[1] | 选取属于bookstore子元素的第一个book元素。 |
/bookstore/book[last()] | 选取属于bookstore子元素的最后一个book元素。 |
/bookstore/book[last()-1] | 选取属于bookstore子元素的倒数第二个book元素。 |
/bookstore/book[position()<3] | 选取最前面的两个属于bookstore元素的子元素的 book元素。 |
//title[@lang] | 选取所有拥有名为lang的属性的title元素。 |
//title[@lang=’eng’] | 选取所有title元素,且这些元素拥有值为eng的lang属性。 |
/bookstore/book[price>35.00] | 选取bookstore元素的所有book元素,且其中的 price元素的值须大于35.00。 |
/bookstore/book[price>35.00]/title | 选取bookstore元素中的book元素的所有 title元素,且其中的price元素的值须大于35.00。 |
解析XML
SAX方式 (Simple API for XML)
事件驱动方式的顺序解析,适合大型XML的解析,省空间。不省时间
DOM(Document Object Model)方式
在内存中构造一棵DOM树,支持XPath查询,省时间。
使用XML格式数据的网站
开源中国
满座团购
基于DOM解析的第三方库
GDataXML
KissXML
KissXML的使用
下拉刷新和上拉刷新(触底刷新)
- UIRefreshControl和触底刷新的原理
self.tableView.delegate = self;
self.ref = [[UIRefreshControl alloc] init];
self.ref.tintColor = [UIColor orangeColor];
[self.ref addTarget:self action:@selector(doRefresh) forControlEvents:UIControlEventValueChanged];
[self.tableView addSubview:self.ref];
- (void)scrollViewDidEndDragging:(UIScrollView *)scrollView willDecelerate:(BOOL)decelerate {
if(scrollView.contentOffset.y + scrollView.frame.size.height > scrollView.contentSize.height + 50) {
}
}
第三方库:MJRefresh
markdown -markup
WebService–数据格式XML
二叉树遍历
循环引用: yaoshiu
HTML – 负责页面元素的显示 按钮输入框 链接
CSS(层叠样式表) – 负责页面元素的样式长什么样子 阴影 下划线 高亮
JavaScript – 负责用户交互 以及数据请求 响应事件