麻豆小视频在线观看_中文黄色一级片_久久久成人精品_成片免费观看视频大全_午夜精品久久久久久久99热浪潮_成人一区二区三区四区

首頁 > 學院 > 開發設計 > 正文

【iOS】在Swift中使用JSONModel

2019-11-14 19:03:28
字體:
來源:轉載
供稿:網友


前言

首先所有的Model還是使用oc來寫——看到這一句是不是想關網頁了- - #,在swift里面直接寫一直報錯所以就將就用oc來寫了,這里主要是分享一下搭配Alamofire使用的經驗。


聲明
歡迎轉載,但請保留文章原始出處:) 
博客園:http://www.companysz.com
農民伯伯: http://over140.VEVb.com


正文

這里不討論JSONModel和Alamofire這兩個項目,直接上代碼

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,其他寫法都一樣

 

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)
        }
    }

  代碼說明

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、具體用法:

            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)
            }

非常輕松和簡單, 可以少寫很多重復代碼。

 

后期維護

 2015-05-20 Alamofire兼容iOS7有點問題,設置head不管用,請參考我另外一篇文章:【iOS】Alamofire庫在iOS7下設置Head無效的問題

 

結束

以后還會分享更多swift的經驗,歡迎交流! 


發表評論 共有條評論
用戶名: 密碼:
驗證碼: 匿名發表
主站蜘蛛池模板: 中文字幕国 | 欧美精品网址 | 中文在线观看视频 | 色人阁导航 | 91美女视频在线 | 免费一区二区三区 | 毛片免费大全短视频 | 亚洲午夜久久久精品一区二区三区 | 国内精品久久久久影院不卡 | 特黄一级小说 | 中国美女一级黄色大片 | 在线成人看片 | 91久久综合 | 欧美a级毛片 | 日本视频免费观看 | 99亚洲伊人久久精品影院红桃 | 国产精品久久久久久影视 | 久久国产精品久久久久久久久久 | 毛片视频大全 | av手机免费在线观看 | 国产一区二区不卡视频 | 高清成人在线 | 欧美日韩亚洲国产精品 | 欧美亚洲国产成人 | 激情九九| 欧美一级黄色网 | 日本不卡视频在线观看 | 久久久久久久久淑女av国产精品 | 免费观看国产精品视频 | 日韩av官网 | 老女人碰碰在线碰碰视频 | 欧日一级片 | 免费一级毛片在线播放视频 | 91美女视频在线观看 | 成年人视频在线免费观看 | 久久久三区 | 黄色影院在线看 | 精品久久久久久久久久久久久久 | 国产免费高清在线 | 久久久av亚洲男天堂 | 在线播放黄色网址 |