DOM解析和JSON解析简单操作

DOM解析:首先根据数据形成一个dom树

112132357047004.png

代码演示

//    1.获取文件路径
    NSString *path = [[NSBundle mainBundle] pathForResource:@"contacts" ofType:@"xml"];

//    2.根据文件路径,将文件内容读取成NSData对象
    NSData *data = [NSData dataWithContentsOfFile:path];

//    3.根据data创建解析对象
//    创建GDataXMLDocument的过程就是一个将文件读取成dom树的过程
    GDataXMLDocument *xmlDocument = [[GDataXMLDocument alloc] initWithData:data options:0 error:nil];

//    初始化联系人数组
    self.contactArray = [NSMutableArray array];

//    4.开始解析
//    4.1获取根节点
    GDataXMLElement *rootElement = xmlDocument.rootElement;

//    4.2获取根节点所有的子节点
    NSArray *subElements = rootElement.children;

//    4.3遍历所有的子节点
    for (GDataXMLElement *contactElement in subElements) {

//        创建联系人对象
        Contact *contact = [[Contact alloc] init];

//        4.4遍历每个联系人节点的子节点
        for (GDataXMLElement *attrElement in contactElement.children) {

            [contact setValue:attrElement.stringValue forKey:attrElement.name];

//            if ([attrElement.name isEqualToString:@"name"]) {
//                contact.name = attrElement.stringValue;
//            }
//            
//            if ([attrElement.name isEqualToString:@"sex"]) {
//                contact.sex = attrElement.stringValue;
//            }
//            
//            if ([attrElement.name isEqualToString:@"tel"]) {
//                contact.tel = attrElement.stringValue;
//            }
        }
//        4.5将联系人添加到数组中
        [self.contactArray addObject:contact];
        [contact release];

    }

    for (Contact *cont in self.contactArray) {
        NSLog(@"%@ %@ %@",cont.name,cont.sex,cont.tel);
    }

JSONKit使用

112147409542646.png

代码实现

- (IBAction)jsonKitBtn:(UIButton *)sender {

    //JsonKit不仅能够实现json转化成对象,还能实现对象转化成Json(Json本事就是一种文本,字符串)

//    对象->Json
    NSArray *arr = [NSArray arrayWithObjects:@"aaa",@"bbb",@"ccc", nil];

    NSString *jsonStr = [arr JSONString];
    NSLog(@"%@",jsonStr);

//    Json->对象
//    1.获取json文件路径
    NSString *path = [[NSBundle mainBundle] pathForResource:@"json" ofType:@"xml"];
//    2.根据path将文件中的数据转化成data
    NSData *data = [NSData dataWithContentsOfFile:path];

//    3.根据json文件的实际结构获取对象,第一层是数组,因此返回的是数组
   NSArray *arr1  = [data objectFromJSONData];

//    4.贮备一个空的数组
    self.contactArray = [NSMutableArray array];
//    5.遍历数组,根据实际情况,得到内部对象为字典
    for (NSDictionary *dic in arr1) {
//        创建一个空内容
        Contact *con = [[Contact alloc] init];
//        根据KVC,将字典直接转化成内容
        [con setValuesForKeysWithDictionary:dic];
//        将内容添加进数组
        [self.contactArray addObject:con];
        [con release];
    }

//    6.遍历数组,输出内容
    for (Contact *con in self.contactArray) {
        NSLog(@"%@ %@ %@",con.name,con.sex,con.tel);
    }

}
  • 2
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
对于LotusScript,除了Rich-Text域外的元素,如文本、单选框、列表框、复选框等,你可以用几乎相同的代码取得它们的值。例如:如果有一个“Location”域,不论它是何种类型,你都可以用下面的LotusScript代码取得它的值:   fieldVals = doc.Location   或者这样:   fieldVals = doc.GetItemValue("Location")   在LotusScript中,域的类型对于你要取值(值数组)的代码并不重要。但是在JavaScript中,不同类型的域除了显示选项(比如单选框、复选框或者文本)外,并不像在Notes里那样,它们是不同的类型的对象,每一个都要用不同的方式去引用。其实,那也不是绝对的,有些对象是相似的,但是引用过程并不像在LotusScript里那么流畅。   在JavaScript中,没有所谓的Rich-Text域,在HTML中更没有。Notes里提供了一个可以放在浏览器里的富文本Java(不是JavaScript)小程序,从而可以得到富文本的一些功能,但是你并不能用JavaScript来对它编程,而且它也不是一个真正的HTML对象类型。   更让Notes开发人员惊讶的是,在Web上还没有数字型或时间型的域。HTML的域都是文本型的。尽管你能用它们来收集数字信息,如数量或单价,而保存的数据依然是文本。为了像数字一样使用它,你必须把它转换成数字类型。另一个区别是在Web上没有计算域,但并不意味着你不能在你的表单里加入计算域。你可以加入计算域,计算值将会在Web页中显示,除非域是隐藏的。关键是即使域就在那里显示,而HTML通常的处理是没有定义域。如果你把test域改成计算域而不是可编辑的,在测试时你会发现其值是取不到的,我们可以对比下计算域和可编辑域生成的html代码:   计算域的时候生成的代码(js是取不到值的):      action="/weboa/ggxx/Dinner.nsf/test?OpenForm&Seq=1" name="_test">
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值