微信公众号搜"智元新知"关注
微信扫一扫可直接关注哦!

KissXml 简易API

KissXml 简易API

KissXml API


KissXml是iPhone平台目前比较好的xml解 析&操作的框架,尤其是他集成了XPath功能.但是网上没有成型的api,就连KissXml自己也没有出过完整的api。为了方便大家快速入 门、使用KissXML,就勉强做了这个所谓的API,如有谬误,敬请斧正。
=============================================================================================
DDXMLNode(结点类,所有结点类的父类
//创建元素结点的方法
+ (id)elementWithName:(Nsstring *)name;
+ (id)elementWithName:(Nsstring *)name URI:(Nsstring *)URI;
+ (id)elementWithName:(Nsstring *)name stringValue:(Nsstring *)string;
+ (id)elementWithName:(Nsstring *)name children:(NSArray *)children attributes:(NSArray *)attributes;
//创建属性结点
+ (id)attributeWithName:(Nsstring *)name stringValue:(Nsstring *)stringValue;
+ (id)attributeWithName:(Nsstring *)name URI:(Nsstring *)URI stringValue:(Nsstring *)stringValue;
//创建一个命名空间
+ (id)namespaceWithName:(Nsstring *)name stringValue:(Nsstring *)stringValue;
//创建处理指令,形如
+ (id)processingInstructionWithName:(Nsstring *)name stringValue:(Nsstring *)stringValue;
//创建一个注释结点
+ (id)commentWithStringValue:(Nsstring *)stringValue;
//创建一个textValue结点
+ (id)textWithStringValue:(Nsstring *)stringValue;
#pragma mark ------------------------ Properties ---------------------------
//返回结点类型
- (DDXMLNodeKind)kind;
//设置结点名
- (void)setName:(Nsstring *)name;
//获得结点名
- (Nsstring *)name;
//设置结点的stringValue,Element设置之后其子结点尽失,只剩下stringValue
- (void)setStringValue:(Nsstring *)string;
//获得stringValue
- (Nsstring *)stringValue;
#pragma mark ------------------------ Tree Navigation ------------------------------
//返回当前结点在兄弟结点中的index
- (NSUInteger)index;
//返回当前结点在树中的level
- (NSUInteger)level;
//获得所在树的根结点
- (DDXMLDocument *)rootDocument;
- (DDXMLNode *)parent;//获得父结点
- (NSUInteger)childCount;//获取子结点个数(所有的node子类)
- (NSArray *)children;//子结点列表
- (DDXMLNode *)childAtIndex:(NSUInteger)index;//指定index的子结点列表
- (DDXMLNode *)prevIoUsSibling;//上一个兄弟结点
- (DDXMLNode *)nextSibling;//下一个兄弟结点
- (DDXMLNode *)prevIoUsNode;//深度遍历顺序的上一个结点
- (DDXMLNode *)nextNode;//深度遍历顺序的下一个结点
- (void)detach;//当前结点所带子树,从父树上分离下来
- (Nsstring *)XPath;//当前结点所在树的XPath,[n]表示是(深度遍历顺序中)连续同名结点的第几个
#pragma mark ------------------------ qnames ---------------------------
- (Nsstring *)localName;//返回去掉第一个冒号和之前prefix之后的localName
- (Nsstring *)prefix;//返回去掉第一个冒号和之后localName之后的prefix
- (void)setURI:(Nsstring *)URI;//设置URI,形如 注:只在attribute中设置xmlns属性之后,用URI的get方法是读不到的
- (Nsstring *)URI;//URI的get方法
+ (Nsstring *)localNameForName:(Nsstring *)name;//处理name获得localName的方法
+ (Nsstring *)prefixForName:(Nsstring *)name;//处理name获得prefixForName的方法
#pragma mark ------------------------ Output ---------------------------
//description & XMLString相同,等价于[XMLStringWithOptions:0]
- (Nsstring *)description;
- (Nsstring *)XMLString;
//options>=0一行输出,且空标签不合并;option<0,合并空标签例如,且缩进输出
- (Nsstring *)XMLStringWithOptions:(NSUInteger)options;
#pragma mark ------------------------ XPath/XQuery ---------------------------
//获得对应XPath的结点,Document和Element有不同表示(其实一样,都是从其子结点开始path)
- (NSArray *)nodesForXPath:(Nsstring *)xpath error:(NSError **)error;
=============================================================================================
DDXMLDocument(DOC根结点类)
//初始化
- (id)initWithXMLString:(Nsstring *)string options:(NSUInteger)mask error:(NSError **)error;//用一段xml代码创建一颗dom树,mask无用,0即可。
- (id)initWithData:(NSData *)data options:(NSUInteger)mask error:(NSError **)error;//用一段xml代码创建一颗dom树,mask无用,0即可,上一个就是调用此法
- (DDXMLElement *)rootElement;//获得根元素Element
- (NSData *)XMLData;//获得包含XMLString的NSData对象
- (NSData *)XMLDataWithOptions:(NSUInteger)options;//获得包含XMLString的NSData对象,option>=0:一行,不合并空元素;option<0:合并,缩进;
=============================================================================================
DDXMLElement(元素结点类)
#pragma mark --------------------------- Init ---------------------------
- (id)initWithName:(Nsstring *)name;//创建名为name的Element
- (id)initWithName:(Nsstring *)name URI:(Nsstring *)URI;//创建名为name,且URI为URIString的Element
- (id)initWithName:(Nsstring *)name stringValue:(Nsstring *)string;//创建名为name且只有一个textVaule结点的Element
- (id)initWithXMLString:(Nsstring *)string error:(NSError **)error;//用一段xml子树代码创建一个Element对象
#pragma mark ------------------------------ Elements by name ------------------------------
- (NSArray *)elementsForName:(Nsstring *)name;//按照name获取Element列表
- (NSArray *)elementsForLocalName:(Nsstring *)localName URI:(Nsstring *)URI;//按照LocalName和URI获取Element列表
#pragma mark ------------------------------ Attributes ------------------------------
- (void)addAttribute:(DDXMLNode *)attribute;//在属性列表最后添加一个属性
- (void)removeAttributeForName:(Nsstring *)name;//移除指定属性属性列表里不存在同名的属性,诸如名如xmlns等URI其实不在属性列表里,虽然显示属性的位置上)
- (void)setAttributes:(NSArray *)attributes;//为当前Element设置属性列表
- (DDXMLNode *)attributeForName:(Nsstring *)name;//获得指定属性
- (NSArray *)attributes;//属性列表的get方法
#pragma mark ------------------------------ Namespaces ------------------------------
//命名空间,形如:
- (void)addNamespace:(DDXMLNode *)aNamespace;//为当前Element一个添加命名空间
- (void)removeNamespaceForPrefix:(Nsstring *)name;//移除指定的命名空间
- (void)setNamespaces:(NSArray *)namespaces;//设置命名空间列表
- (NSArray *)namespaces;//命名空间列表
- (DDXMLNode *)namespaceForPrefix:(Nsstring *)prefix;//根据prefix(即nsName)获得namespace
- (DDXMLNode *)resolveNamespaceForName:(Nsstring *)name;//获得指定标签名所属的namespace,例如:,将此结点的name传入即可获得所属的namespace对象
- (Nsstring *)resolvePrefixForNamespaceURI:(Nsstring *)namespaceURI;//获得指定URI值的namespace的nsName
#pragma mark ------------------------------ Children ------------------------------
- (void)insertChild:(DDXMLNode *)child atIndex:(NSUInteger)index;//在children(子结点列表)中插入子结点
- (void)removeChildAtIndex:(NSUInteger)index;//移除指定index的子结点
- (void)setChildren:(NSArray *)children;//设置子结点列表
- (void)addChild:(DDXMLNode *)child;//子结点列表的get方法
#pragma mark ------------------------------ Extra------------------------------
+ (DDXMLElement *)elementWithName:(Nsstring *)name xmlns:(Nsstring *)ns;//创建一个结点,形如:
- (DDXMLElement *)elementForName:(Nsstring *)name;//返回所有子元素中第一个名为name的element
- (DDXMLElement *)elementForName:(Nsstring *)name xmlns:(Nsstring *)xmlns;//返回所有子元素中第一个名为name且xmlns为xmlns值的element
//xmlns值的set和get方法
- (void)setXmlns:(Nsstring *)ns;
- (Nsstring *)xmlns;
- (void)addAttributeWithName:(Nsstring *)name stringValue:(Nsstring *)string;//为当前结点添加属性&属性
- (NSDictionary *)attributesAsDictionary;//返回属性字典列表
=============================================================================================
其他私有的方法(基本用不到,主要是内部调用,有兴趣的自己试下) @interface DDXMLNode (PrivateAPI) + (id)nodeWithPrimitive:(xmlKindPtr)nodePtr; - (id)initWithCheckedPrimitive:(xmlKindPtr)nodePtr; - (id)initWithUncheckedPrimitive:(xmlKindPtr)nodePtr; + (id)nodeWithPrimitive:(xmlKindPtr)nodePtr nsParent:(xmlNodePtr)parentPtr; - (id)initWithCheckedPrimitive:(xmlKindPtr)nodePtr nsParent:(xmlNodePtr)parentPtr; - (id)initWithUncheckedPrimitive:(xmlKindPtr)nodePtr nsParent:(xmlNodePtr)parentPtr; + (BOOL)isXmlAttrPtr:(xmlKindPtr)kindPtr; - (BOOL)isXmlAttrPtr; + (BOOL)isXmlNodePtr:(xmlKindPtr)kindPtr; - (BOOL)isXmlNodePtr; + (BOOL)isXmlDocPtr:(xmlKindPtr)kindPtr; - (BOOL)isXmlDocPtr; + (BOOL)isXmlDtdPtr:(xmlKindPtr)kindPtr; - (BOOL)isXmlDtdPtr; + (BOOL)isXmlNsPtr:(xmlKindPtr)kindPtr; - (BOOL)isXmlNsPtr; - (BOOL)hasParent;//是否有父结点 + (void)recursiveStripDocPointersFromNode:(xmlNodePtr)node; + (void)detachAttribute:(xmlAttrPtr)attr fromNode:(xmlNodePtr)node; + (void)removeAttribute:(xmlAttrPtr)attr fromNode:(xmlNodePtr)node; + (void)removeAllAttributesFromNode:(xmlNodePtr)node; + (void)detachNamespace:(xmlNsPtr)ns fromNode:(xmlNodePtr)node; + (void)removeNamespace:(xmlNsPtr)ns fromNode:(xmlNodePtr)node; + (void)removeAllNamespacesFromNode:(xmlNodePtr)node; + (void)detachChild:(xmlNodePtr)child fromNode:(xmlNodePtr)node; + (void)removeChild:(xmlNodePtr)child fromNode:(xmlNodePtr)node; + (void)removeAllChildrenFromNode:(xmlNodePtr)node; + (void)removeAllChildrenFromDoc:(xmlDocPtr)doc; - (void)nodeRetain; - (void)nodeRelease; + (NSError *)lastError; @end @interface DDXMLElement (PrivateAPI) + (id)nodeWithPrimitive:(xmlKindPtr)nodePtr; - (id)initWithCheckedPrimitive:(xmlKindPtr)nodePtr; - (id)initWithUncheckedPrimitive:(xmlKindPtr)nodePtr; - (NSArray *)elementsWithName:(Nsstring *)name uri:(Nsstring *)URI; + (DDXMLNode *)resolveNamespaceForPrefix:(Nsstring *)prefix atNode:(xmlNodePtr)nodePtr; + (Nsstring *)resolvePrefixForURI:(Nsstring *)uri atNode:(xmlNodePtr)nodePtr; @end @interface DDXMLDocument (PrivateAPI) + (id)nodeWithPrimitive:(xmlKindPtr)nodePtr; - (id)initWithCheckedPrimitive:(xmlKindPtr)nodePtr; - (id)initWithUncheckedPrimitive:(xmlKindPtr)nodePtr; @end

原文地址:https://www.jb51.cc/xml/297660.html

版权声明:本文内容由互联网用户自发贡献,该文观点与技术仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请发送邮件至 dio@foxmail.com 举报,一经查实,本站将立刻删除。