在Swift中使用JSONModel 實(shí)例代碼
前言
首先所有的Model還是使用oc來(lái)寫(xiě)——看到這一句是不是想關(guān)網(wǎng)頁(yè)了- - #,在swift里面直接寫(xiě)一直報(bào)錯(cuò)所以就將就用oc來(lái)寫(xiě)了,這里主要是分享一下搭配Alamofire使用的經(jīng)驗(yàn)。
正文
這里不討論JSONModel和Alamofire這兩個(gè)項(xiàng)目,直接上代碼,BaseModel.h
#import "JSONModel.h" @interface BaseModel : JSONModel -(instancetype)initWithDictionary:(NSDictionary*)dict; @end
BaseModel.m
#import "BaseModel.h" @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,其他寫(xiě)法都一樣
BaseAPI.swift
internal func requestModel<T: BaseModel>(method: Method, _ URLString: URLStringConvertible, parameters: [String: AnyObject]? = nil, success: (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 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) } }
代碼說(shuō)明
1、mHttpManager這個(gè)是Alamofire的Manager對(duì)象
2、注意服務(wù)端的返回的數(shù)據(jù)格式,這里支持Model和Array<Model>
3、注意在Swift里面NSDictionary轉(zhuǎn)Model,用T(dictionary: dict as [NSObject : AnyObject]),這個(gè)T就是具體的泛型類型
4、注意在Swift里面NSArray轉(zhuǎn)Model數(shù)組,用T.arrayOfModelsFromDictionaries(array as [AnyObject]).copy() as? Array<T>,注意不要用BaseModel. arrayOfModelsFromDictionaries(編譯不會(huì)報(bào)錯(cuò)但是類型轉(zhuǎn)不出來(lái))
5、具體用法:
public func casts(success: (Array<CustomModel>) -> Void, failure: (NSError?) -> Void) { 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) }
以上就是在Swift中使用JSONModel 實(shí)例代碼,有需要的朋友可以參考下。
相關(guān)文章
iOS遠(yuǎn)程推送Push開(kāi)發(fā)教程
這篇文章主要為大家詳細(xì)介紹了iOS遠(yuǎn)程推送Push開(kāi)發(fā)教程,具有一定的參考價(jià)值,感興趣的小伙伴們可以參考一下2016-09-09iOS開(kāi)發(fā)之WKWebViewJavascriptBridge Xcode9中導(dǎo)致crash的解決
大家都知道WebViewJavascriptBridge它主要幫助我們優(yōu)雅的實(shí)現(xiàn)OC與JS的交互,下面這篇文章主要給大家介紹了關(guān)于iOS開(kāi)發(fā)之WKWebViewJavascriptBridge Xcode9中導(dǎo)致crash的解決方法,需要的朋友可以參考借鑒,下面來(lái)一起看看吧。2017-10-10詳解iOS如何讓Lottie使用網(wǎng)絡(luò)資源做動(dòng)畫(huà)的實(shí)現(xiàn)
這篇文章主要為大家介紹了iOS如何讓Lottie使用網(wǎng)絡(luò)資源做動(dòng)畫(huà)實(shí)現(xiàn)詳解,有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪2023-02-02詳解iOS 用于解決循環(huán)引用的block timer
這篇文章主要介紹了詳解iOS 用于解決循環(huán)引用的block timer,小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,也給大家做個(gè)參考。一起跟隨小編過(guò)來(lái)看看吧2018-12-12詳解IOS開(kāi)發(fā)之實(shí)現(xiàn)App消息推送(最新)
這篇文章主要介紹了詳解IOS開(kāi)發(fā)之實(shí)現(xiàn)App消息推送(最新),具有一定的參考價(jià)值,有興趣的可以了解一下。2016-12-12設(shè)計(jì)模式中的Memento備忘錄模式的在iOS App開(kāi)發(fā)中的運(yùn)用
這篇文章主要介紹了設(shè)計(jì)模式中的Memento備忘錄模式的在iOS App開(kāi)發(fā)中的運(yùn)用,Memento著重于捕獲和具體化當(dāng)前對(duì)象的內(nèi)部狀態(tài),需要的朋友可以參考下2016-03-03