在Swift中使用JSONModel 实例代码

本文主要介绍在Swift中使用JSONModel,这里给大家提供代码实例做参考,希望能帮助有需要的小伙伴

前言

 首先所有的Model还是使用oc来写——看到这一句是不是想关网页了- - #,在swift里面直接写一直报错所以就将就用oc来写了,这里主要是分享一下搭配Alamofire使用的经验。

正文

 这里不讨论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)
      }

以上就是在Swift中使用JSONModel 实例代码,有需要的朋友可以参考下。

本站部分内容来源互联网,如果有图片或者内容侵犯您的权益请联系我们删除!

相关文档推荐

刚刚进入iOS开发行业,发现开发中要用到大量的block回调,由此可见它的重要性。本文主要讲的是 Block 回调的使用,以及 Block 是如何实现这种神奇的回调两部分来讲的,下面来一起看看吧。
这篇文章给大家分享了iOS中修改UITextField占位符字体颜色的三个方法,分别是使用attributedPlaceholder属性、重写drawPlaceholderInRect方法和修改UITextField内部placeholderLaber的颜色,下面我们一起来看看详细的方法介绍。
这篇文章主要介绍了iOS逆向工程使用dumpdecrypted工具给App脱壳的相关资料,本文图文并茂给大家介绍的非常详细,具有参考借鉴价值,需要的朋友可以参考下
这篇文章主要为大家详细介绍了使用iOS推送时警告错误的解决方法,感兴趣的小伙伴们可以参考一下
这篇文章主要介绍了iOS逆向工程使用LLDB的USB连接调试第三方App,具有一定的参考价值,感兴趣的小伙伴们可以参考一下
学会使用别人的Pods依赖库以后,你一定对创建自己的依赖库跃跃欲试,今天就来揭开Pods依赖库创建过程的神秘面纱