【iOS】在Swift中使用JSONModel
这里不讨论JSONModel和Alamofire这两个项目,直接上代码
BaseModel.h
@interface BaseModel : JSONModel
-(instancetype)initWithDictionary:(NSDictionary*)dict;
@end
BaseModel.m
@implementation BaseModel
// Make all model properties optional (avoid if possible)
+(BOOL)propertyIsOptional:(NSString*)propertyName
{
return YES;
}
-(instancetype)initWithDictionary:(NSDictionary*)dict {
return (self = [[super init] initWithDictionary:dict error:nil]);
}
@end
所有的Model都要继承BaseModel,其他写法都一样
BaseAPI.swift
mHttpManager.request(method, URLString , parameters: parameters, encoding: ParameterEncoding.JSON)
.responseJSON { (request, response, data, error) in
if error == nil {
if let dict = data as? NSDictionary {
if let model = T(dictionary: dict as [NSObject : AnyObject]) {
success(model)
return
}
}
}
failure(error)
}
}
internal func requestArray<T: BaseModel>(method: Method, _ URLString: URLStringConvertible, parameters: [String: AnyObject]? = nil, success: (Array<T>) -> Void, failure: (NSError?) -> Void) {
mHttpManager.request(method, URLString , parameters: parameters, encoding: ParameterEncoding.JSON)
.responseJSON { (request, response, data, error) in
if error == nil {
if let array = data as? NSArray {
if let result = T.arrayOfModelsFromDictionaries(array as [AnyObject]).copy() as? Array<T>{
success(result)
return
}
}
}
failure(error)
}
}
代码说明
1、mHttpManager这个是Alamofire的Manager对象
2、注意服务端的返回的数据格式,这里支持Model和Array<Model>
3、注意在Swift里面NSDictionary转Model,用T(dictionary: dict as [NSObject : AnyObject]),这个T就是具体的泛型类型
4、注意在Swift里面NSArray转Model数组,用T.arrayOfModelsFromDictionaries(array as [AnyObject]).copy() as? Array<T>,注意不要用BaseModel. arrayOfModelsFromDictionaries(编译不会报错但是类型转不出来)
5、具体用法:
requestArray(Method.GET, URL_CASTS, parameters: nil, success: success, failure: failure)
}
public func like(id: String, success: (CustomModel) -> Void, failure: (NSError?) -> Void) {
requestModel(Method.PATCH, String(format: URL_CASTS_LIKE, id), parameters: nil, success: success, failure: failure)
}
非常轻松和简单, 可以少写很多重复代码。
后期维护
2015-05-20 Alamofire兼容iOS7有点问题,设置head不管用,请参考我另外一篇文章:【iOS】Alamofire库在iOS7下设置Head无效的问题
2016-04-21
错误:fatal error: NSArray element failed to match the Swift Array Element type,参考帖子这里。
Swift 中使用不支持嵌套 JSONModel 数组
@property (strong, nonatomic) NSArray<User *> *users;
解决办法:
@property (strong, nonatomic) NSArray<NSDictionary *> *users;
然后在 Swift 这边转一下
self.apps = apps.map{ App(dictionary: $ 0 ) }
本文转自博客园农民伯伯的博客,原文链接:【iOS】在Swift中使用JSONModel,如需转载请自行联系原博主。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
-
上一篇
【iOS】Alamofire库在iOS7下设置Head无效的问题
同样的代码在iOS8下没有问题,iOS7就取不到数据(会包Cocoa Error 3840之类的错误),跟踪发现请求Head参数设置不管用,根据文字底部的参考改了一下兼容代码: privatefuncgetRequest(method:Method,_URLString:URLStringConvertible,parameters:[String:AnyObject]?=nil)->NSMutableURLRequest{ letrequest=NSMutableURLRequest(URL:NSURL( string:URLString.URLString)!) request.HTTPMethod=method.rawValue ifparameters!=nil{ request.HTTPBody=NSJSONSerialization.dataWithJSONObject(parameters!,options:nil,error:nil) } request.setValue(API_UA,forHTTPHeaderField: " User-Agent ") ...
-
下一篇
【读书笔记】100个Switf必备tips
1、Selector 在Swift中可以用字符串常量来构造Selector,例如: NSNotificationCenter.defaultCenter().addObserver(self,selector: " handleMoviePlayerLoadStateDidChange: ",name:MPMoviePlayerLoadStateDidChangeNotification, object:nil) funchandleMoviePlayerLoadStateDidChange(notification:NSNotification) 注意这个字符串常量最后的那个冒号,如果有一个参数就加1个冒号,没有就不加,多参数则在第一个冒号的后面接上参数名并再加一个冒号,类似于"method:param2:param3:"。 2、使用多元组(Tuple)交换变量的值 funcswapMe<T>(inouta:T,inoutb:T){ (a,b)=(b,a) } 3、"="不支持操作符重载(——好像不是本书的内容,暂时一并写在这一起了) 4、func的参数默认是le...
相关文章
文章评论
共有0条评论来说两句吧...