前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >iOS开发——MJExtension的实际使用,JSON格式解析

iOS开发——MJExtension的实际使用,JSON格式解析

作者头像
Originalee
发布2018-08-30 10:37:35
3.6K0
发布2018-08-30 10:37:35
举报
文章被收录于专栏:编程之旅编程之旅

现在的iOS在跟服务器进行交互式,采取的常用数据格式是XML和JSON,而今天就探讨一个JSON解析框架 —— MJExtension。

MJExtension是李明杰老师写的一个开源框架,是一个转换速度快,使用简单方便的字典转模型框架。

它可以完成的数据转换是有如下方式的:

  • JSON --> ModelCore Data Model
  • JSONString --> ModelCore Data Model
  • ModelCore Data Model --> JSON
  • JSON Array --> Model ArrayCore Data Model Array
  • JSONString --> Model ArrayCore Data Model Array
  • Model ArrayCore Data Model Array --> JSON Array

在MJExtension的GitHub上,文档中已经很清楚的写明了这个框架的简单用法,所以我就不赘述这个框架最基本的使用了。今天我打算举一个很简单的例子,来告诉大家,实际项目中该如何使用MJExtension框架来处理Model数据。

首先我们先来看一个JSON数据格式。

代码语言:javascript
复制
{
    "group": [
        {
            "roomgroup": [
                {
                    "device_name": "海尔",
                    "address": "客厅电视机",
                    "device_id": "c6f7cd61-245f-46fc-8e81-1e32a0f38cd6",
                    "device_status": "0"
                },
                {
                    "device_name": "乐视",
                    "address": "餐厅电视机",
                    "device_id": "7c756f4a-d3cf-492a-817b-92311f6ea34b",
                    "device_status": "0"
                }
            ],
            "room": "厨房"
        },
        {
            "roomgroup": [
                {
                    "device_name": "海尔",
                    "address": "客厅电视机",
                    "device_id": "784ec8cd-723d-44bc-a6cc-3ae78022e6e9",
                    "device_status": "0"
                }
            ],
            "room": "客厅"
        },
        {
            "roomgroup": [
                {
                    "device_name": "乐视",
                    "address": "餐厅电视机",
                    "device_id": "3d141e71-95ce-4e04-845a-9f0a455d37c2",
                    "device_status": "0"
                }
            ],
            "room": "阳台"
        }
    ],
    "message": {
        "code": "200",
        "message": "操作成功!"
    },
    "rows": null,
    "total": 0
}

观察这个JSON数据,我们能发现它里面装着数组属性,而数组中又装着其他模型。这里主要就是要提取group这个数组中的数据。

  • 那么首先我们定义一个模型,我把它命名为GroupRoomModel
代码语言:javascript
复制
@property (nonatomic, copy) NSMutableArray *roomGroup;
@property (nonatomic, copy) NSMutableArray *group; 
@property (nonatomic, copy) NSString *room; 
@property (nonatomic, copy) NSMutableArray *deviceDetail;
  • 接着再定义一个模型,我把它命名为RoomModel,用来存储roomgroup中的数据
代码语言:javascript
复制
@property (nonatomic, copy) NSString *deviceName;   
@property (nonatomic, copy) NSString *deviceStatus; 
@property (nonatomic, copy) NSString *deviceID;     
@property (nonatomic, copy) NSString *address;      
  • 接下来我们要重新映射Model中的键值与JSON数据中的对应。
代码语言:javascript
复制
    [GroupRoomModel mj_setupReplacedKeyFromPropertyName:^NSDictionary *{
        return @{
            @"roomGroup":@"roomgroup",
            };
    }];
    
        [RoomModel mj_setupReplacedKeyFromPropertyName:^NSDictionary *{
        return @{
                             @"deviceID":@"device_id",
                             @"deviceName":@"device_name",
                             @"deviceStatus":@"device_status",
                 };
    }];
  • 之后先解析我们拿到的data,这里可以直接解析出group
代码语言:javascript
复制
GroupRoomModel *groupRoomModel = [GroupRoomModel mj_objectWithKeyValues:data];

一行代码搞定,是不是很简单。

之后我们解析group这个数组中的数据,把room中的字符串提取出来存在Modelroom里,把roomgroup里的字典分别提取出来,存在RoomModel类型的Model里,并且把RoomModel添加到GroupRoomModel中的deviceDetail这个可变数组中。

具体的代码如下

代码语言:javascript
复制
  NSMutableArray *modelArray = [NSMutableArray array];
    _dataSource = [NSMutableArray array];
    for (NSDictionary *dic in groupRoomModel.group) {
        GroupRoomModel *model = [GroupRoomModel mj_objectWithKeyValues:dic];
        NSMutableArray *deviceArray = [NSMutableArray array];
        for (NSDictionary *deviceDic in model.roomGroup) {
            RoomModel *roomModel = [RoomModel mj_objectWithKeyValues:deviceDic];
            [deviceArray addObject:roomModel];
        }
        [modelArray addObject:model];
        model.deviceDetail = [NSMutableArray arrayWithArray:deviceArray];
        [_dataSource addObject:model];
    }

这样我们就完成了多层的JSON数据解析。

其实MJExtension的使用非常简单,多看看文档,很容易掌握。

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2016.05.25 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档