iOS 中JSONModel的使用
基本使用
涉想你的JSON数据像这样:
- { "id": "10", "country": "Germany", "dialCode": 49, "isInEurope": true }
- 为你的数据模型创建一个Objective-C的类,继承自JSONModel.
- 将JSON中的keys在.h文件中声明为属性:

- #import "JSONModel.h"
- @interface CountryModel : JSONModel
- @property (assign, nonatomic) int id;
- @property (strong, nonatomic) NSString* country;
- @property (strong, nonatomic) NSString* dialCode;
- @property (assign, nonatomic) BOOL isInEurope;
- @end

在.m文件中不需要做任何事情.
- 用数据初始化你的model:

- #import "CountryModel.h"
- ...
- NSString* json = (fetch here JSON from Internet) ...
- NSError* err = nil;
- CountryModel* country = [[CountryModel alloc] initWithString:json error:&err];

举个例子
命名自动匹配
- {
- "id": "123",
- "name": "Product name",
- "price": 12.95
- }

- @interface ProductModel : JSONModel
- @property (assign, nonatomic) int id;
- @property (strong, nonatomic) NSString* name;
- @property (assign, nonatomic) float price;
- @end
- @implementation ProductModel
- @end

模型嵌套 (模型包含其他模型)

- {
- "order_id": 104,
- "total_price": 13.45,
- "product" : {
- "id": "123",
- "name": "Product name",
- "price": 12.95
- }
- }
- @interface OrderModel : JSONModel
- @property (assign, nonatomic) int order_id;
- @property (assign, nonatomic) float total_price;
- @property (strong, nonatomic) ProductModel* product;
- @end
- @implementation OrderModel
- @end

模型集合

- {
- "order_id": 104,
- "total_price": 103.45,
- "products" : [
- {
- "id": "123",
- "name": "Product #1",
- "price": 12.95
- },
- {
- "id": "137",
- "name": "Product #2",
- "price": 82.95
- }
- ]
- }


- @protocol ProductModel
- @end
- @interface ProductModel : JSONModel
- @property (assign, nonatomic) int id;
- @property (strong, nonatomic) NSString* name;
- @property (assign, nonatomic) float price;
- @end
- @implementation ProductModel
- @end
- @interface OrderModel : JSONModel
- @property (assign, nonatomic) int order_id;
- @property (assign, nonatomic) float total_price;
- @property (strong, nonatomic) NSArray<ProductModel>* products;
- @end
- @implementation OrderModel
- @end

注意: 尖括号后 NSArray
包含一个协议. 这跟Objective-C原生的泛型不是一个概念. 他们不会冲突, 但对于JSONModel来说,协议必须在一个地方声明.
key映射

- {
- "order_id": 104,
- "order_details" : [
- {
- "name": "Product#1",
- "price": {
- "usd": 12.95
- }
- }
- ]
- }
- @interface OrderModel : JSONModel
- @property (assign, nonatomic) int id;
- @property (assign, nonatomic) float price;
- @property (strong, nonatomic) NSString* productName;
- @end
- @implementation OrderModel
- +(JSONKeyMapper*)keyMapper
- {
- return [[JSONKeyMapper alloc] initWithDictionary:@{
- @"order_id": @"id",
- @"order_details.name": @"productName",
- @"order_details.price.usd": @"price"
- }];
- }
- @end

设置全局键映射(应用于所有model)

- [JSONModel setGlobalKeyMapper:[
- [JSONKeyMapper alloc] initWithDictionary:@{
- @"item_id":@"ID",
- @"item.name": @"itemName"
- }]
- ];

设置下划线自动转驼峰
- {
- "order_id": 104,
- "order_product" : @"Product#1",
- "order_price" : 12.95
- }

- @interface OrderModel : JSONModel
- @property (assign, nonatomic) int orderId;
- @property (assign, nonatomic) float orderPrice;
- @property (strong, nonatomic) NSString* orderProduct;
- @end
- @implementation OrderModel
- +(JSONKeyMapper*)keyMapper
- {
- return [JSONKeyMapper mapperFromUnderscoreCaseToCamelCase];
- }
- @end

可选属性 (就是说这个属性可以为null或者为空)
- {
- "id": "123",
- "name": null,
- "price": 12.95
- }

- @interface ProductModel : JSONModel
- @property (assign, nonatomic) int id;
- @property (strong, nonatomic) NSString<Optional>* name;
- @property (assign, nonatomic) float price;
- @property (strong, nonatomic) NSNumber<Optional>* uuid;
- @end
- @implementation ProductModel
- @end

忽略属性 (就是完全忽略这个属性)

- {
- "id": "123",
- "name": null
- }
- @interface ProductModel : JSONModel
- @property (assign, nonatomic) int id;
- @property (strong, nonatomic) NSString<Ignore>* customProperty;
- @end
- @implementation ProductModel
- @end

设置所有的属性为可选(所有属性值可以为空)

- @implementation ProductModel
- +(BOOL)propertyIsOptional:(NSString*)propertyName
- {
- return YES;
- }
- @end

使用JSONModel自带的 HTTP 请求

- //add extra headers
- [[JSONHTTPClient requestHeaders] setValue:@"MySecret" forKey:@"AuthorizationToken"];
- //make post, get requests
- [JSONHTTPClient postJSONFromURLWithString:@"http://mydomain.com/api"
- params:@{@"postParam1":@"value1"}
- completion:^(id json, JSONModelError *err) {
- //check err, process json ...
- }];

将model转化为字典或者json格式的字符串

- ProductModel* pm = [[ProductModel alloc] initWithString:jsonString error:nil];
- pm.name = @"Changed Name";
- //convert to dictionary
- NSDictionary* dict = [pm toDictionary];
- //convert to text
- NSString* string = [pm toJSONString];

自定义数据的转换

- @implementation JSONValueTransformer (CustomTransformer)
- - (NSDate *)NSDateFromNSString:(NSString*)string {
- NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
- [formatter setDateFormat:APIDateFormat];
- return [formatter dateFromString:string];
- }
- - (NSString *)JSONObjectFromNSDate:(NSDate *)date {
- NSDateFormatter *formatter = [[NSDateFormatter alloc] init];
- [formatter setDateFormat:APIDateFormat];
- return [formatter stringFromDate:date];
- }
- @end

自定义处理指定的属性

- @interface ProductModel : JSONModel
- @property (assign, nonatomic) int id;
- @property (strong, nonatomic) NSString* name;
- @property (assign, nonatomic) float price;
- @property (strong, nonatomic) NSLocale *locale;
- @end
- @implementation ProductModel
- // Convert and assign the locale property
- - (void)setLocaleWithNSString:(NSString*)string {
- self.locale = [NSLocale localeWithLocaleIdentifier:string];
- }
- - (NSString *)JSONObjectForLocale {
- return self.locale.localeIdentifier;
- }
- @end

自定义JSON校验

- @interface ProductModel : JSONModel
- @property (assign, nonatomic) int id;
- @property (strong, nonatomic) NSString* name;
- @property (assign, nonatomic) float price;
- @property (strong, nonatomic) NSLocale *locale;
- @property (strong, nonatomic) NSNumber <Ignore> *minNameLength;
- @end
- @implementation ProductModel
- - (BOOL)validate:(NSError *__autoreleasing *)error {
- BOOL valid = [super validate:error];
- if (self.name.length < self.minNameLength.integerValue) {
- *error = [NSError errorWithDomain:@"me.mycompany.com" code:1 userInfo:nil];
- valid = NO;
- }
- return valid;
- }
- @end

iOS 中JSONModel的使用的更多相关文章
- iOS中JSONModel的使用
iOS中JSONModel的使用 流弊的JSON数据模型框架 https://github.com/jsonmodel/jsonmodel 版本 1.3.0 如果你喜欢JSONModel,并且使用 ...
- iOS 中有用的开源库
youtube下载神器:https://github.com/rg3/youtube-dl vim插件:https://github.com/Valloric/YouCompleteMe vim插件配 ...
- iOS 中 常用的第三方库
现在对于我们 iOS 开发来说,基本上说不可能不使用第三方轮子啦,毕竟没那么多时间,而且自己造的轮子往往想着成为上图中的最后一个,结果却成了上图中第二个或第一个啦,当然大公司另当别论.下面我从之前用过 ...
- iOS中支付宝集成
iOS中支付宝集成 如今各种的App中都使用了三方支付的功能,现在将我在使用支付宝支付集成过程的心得分享一下,希望对大家都能有所帮助 要集成一个支付宝支付过程的环境,大致需要: 1>公司:先与支 ...
- iOS中数据库应用基础
iOS 数据库入门 一.数据库简介 1.什么是数据库? 数据库(Database) 是按照数据结构来组织,存储和管理数据的仓库 数据库可以分为2大种类 关系型数据库(主流) PC端 Oracle My ...
- 正则表达式在iOS中的运用
1.什么是正则表达式 正则表达式,又称正规表示法,是对字符串操作的一种逻辑公式.正则表达式可以检测给定的字符串是否符合我们定义的逻辑,也可以从字符串中获取我们想要的特定部分.它可以迅速地用极简单的方式 ...
- iOS 中的 HotFix 方案总结详解
相信HotFix大家应该都很熟悉了,今天主要对于最近调研的一些方案做一些总结.iOS中的HotFix方案大致可以分为四种: WaxPatch(Alibaba) Dynamic Framework(Ap ...
- iOS中使用正则
一.什么是正则表达式 正则表达式,又称正规表示法,是对字符串操作的一种逻辑公式.正则表达式可以检测给定的字符串是否符合我们定义的逻辑,也可以从字符串中获取我们想要的特定部分.它可以迅速地用极简单的方式 ...
- IOS中div contenteditable=true无法输入
在IOS中<div contenteditable="true"></div>中点击时可以弹出键盘但是无法输入.加一个样式-webkit-user-sele ...
随机推荐
- PHP中使用 JKS(Java Key Store)的方法
PHP语言无法直接读取 JKS中的密钥,需要通过以下方法进行转换 本例以JKS中的私钥为例 首先 使用 KeyStore Explorer工具,打开JKS文件 ,此时可能需要输入 JKS密码 对私钥进 ...
- Swift 多态
前言 同样的操作或者方法,不同的对象在执行时会出现完全不同的行为,这就叫多态. 1.Swift 多态 多态是讲具有同样的父类的一批类之间,都重写了父类的同一个方法实现自己的行为,但是表现出来则各不相同 ...
- [译]async/await中使用阻塞式代码导致死锁 百万数据排序:优化的选择排序(堆排序)
[译]async/await中使用阻塞式代码导致死锁 这篇博文主要是讲解在async/await中使用阻塞式代码导致死锁的问题,以及如何避免出现这种死锁.内容主要是从作者Stephen Cleary的 ...
- Easyui中 messager出现的位置
$.messager.alert 弹出框的位置随页面的长度越大越靠下. $.messager.alert('消息','只能对单个客户进行清款!','info'); 弹出的位置 太靠下方.修改为: $. ...
- openkm预览功能报错:flexpaper License key not accepted(no key passed to viewer)
openkm:6.3.4 使用google浏览器打开,想预览文件,但是pdf.word和图片都不能显示.只是显示空白. 换成IE后,再次尝试,发现了报错信息: 解决方案: 1- Stop openkm ...
- Redis 的安装与使用(单节点)
Redis 的安装与使用(单节点) 环境:CentOS 6.5 Redis 版本:redis-3.0 (考虑到Redis3.0 在集群和性能提升方面的特性,rc 版为正式版的候选版,而且 很快就出 ...
- nginx+php-fpm性能参数优化原则
1.worker_processes 越大越好(一定数量后性能增加不明显) 2.worker_cpu_affinity 所有cpu平分worker_processes 要比每个worker_pro ...
- pthread编译时报错的解决方法
最近在学习POSIX thread编程,今天编译一个程序报如下错误: /tmp/ccXH8mJy.o:在函数‘main’中:deadlock.c:(.text+0xbb):对‘pthread_crea ...
- Android Studio 环境搭建参考,jdk10javac命令提示不是内部或外部命令
https://blog.csdn.net/qq_33658730/article/details/78547789 win10下Android Studio和SDK下载.安装和环境变量配置 http ...
- JEECG中t:dictSelect的extendJson用法
1.t:dictSelect的各个属性值如下: 属性名 类型 描述 是否必须 默认值 title string 标题 否 null field string 控件字段名字 是 null typeGro ...