网络第03天:XML数据解析

网络第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

  1. SAX方式 (Simple API for XML)

    事件驱动方式的顺序解析,适合大型XML的解析,省空间。不省时间

  2. DOM(Document Object Model)方式

    在内存中构造一棵DOM树,支持XPath查询,省时间。

使用XML格式数据的网站

  1. 开源中国

    • http://www.oschina.net/action/api/news_detail?id=44393
  2. 满座团购

    • http://mp.manzuo.com/china/chengdu/home_2.xml
    • http://mps.manzuo.com/mps/cate?id=0&cc=chengdu&pt=all&ffst=1&mnt=10&st=-1&hs=1

基于DOM解析的第三方库

  1. GDataXML

  2. KissXML

KissXML的使用

下拉刷新和上拉刷新(触底刷新)

  1. 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) {

    }
}
  1. 第三方库:MJRefresh

    点击查看相关链接

    markdown -markup
    WebService–数据格式XML
    二叉树遍历

循环引用: yaoshiu
HTML – 负责页面元素的显示 按钮输入框 链接
CSS(层叠样式表) – 负责页面元素的样式长什么样子 阴影 下划线 高亮
JavaScript – 负责用户交互 以及数据请求 响应事件

你可能感兴趣的:(网络第03天:XML数据解析)