iOS 模型转换

为了将数据对象话,通常需要将网络请求的JSON数据或者字典转换为模型。

json数据一般有两种类型,第一种json字符串,需要解析出来,第二种json对象如:字典、数组   补充,网络传输一般使用的是jsonDate数据

一、不使用第三方库转换

1.字典转模型(定义模型类)

a.普通对应转换: 模型类.objectWithKeyValues(dic) as? 模型类

b.字典包裹模型数组时转换: 字典中包含数组时,模型类必须遵守DictModelProtocol 协议,并实现customClassMapping方法[作用指定数组中的元素类型]

class UserGroup: NSObject,DictModelProtocol {
    var groupName:String?;            //团队名称
    var numbers:NSArray?              //成员,又是一个模型类
    static func customClassMapping() -> [String: String]?{
        return ["numbers":"User"];   //指定numbers数组中的元素类型是User
    }
}

作者:hejunm

c.字典数组转换为模型数组  : 字典数组.objectArrayWithKeyValuesArray(arrayOfStatus)

详细参考:【字典模型互转--hejunm

2.模型转字典

a.普通 :  模型实例.keyValues 即可得到 如:let dic:Dictionary =  user.keyValues  //获得模型的字典模式

b.模型数组转字典:  模型数组.keyValusArray 如: let dic: Dictionary = userArr.keyValusArray

二、使用常用第三个库转换

常用数模转换库:yyModel   MJExtension  ObjectMapper(swift)

ObjectMapper使用   [git地址]

yyModel使用


objectMaper 使用简介

模型类遵循Mappable 

实现init?(map:Map)方法 可以下此方法中过滤一些脏数据(如,某个属性没有值,则返回nil)

required init?(map: Map){
	// check if a required "name" property exists within the JSON.
	if map.JSON["name"] == nil {
		return nil
	}
}

实现 mutating func mapping(map:Map)方法

 // Mappable
    func mapping(map: Map) {
        username    <- map["username"]
        age         <- map["age"]
        weight      <- map["weight"]
        array       <- map["arr"]
        dictionary  <- map["dict"]
        bestFriend  <- map["best_friend"]
        friends     <- map["friends"]
        birthday    <- (map["birthday"], DateTransform())
    }


提示,可以自定义转化类型,在mapping中使用

//自定义转换类型 需要的是自定义State enum类型, 后台传过来的是Int
        let stateTransformer = TransformOf<OrderState, Int>(fromJSON: { (value: Int?) -> OrderState? in
            return OrderState(rawValue: value ?? -1)//返回所需的类型【将后台的Int转换为OrderSate】  从json中的数据类型转换为模型所需类型
        }) { (state) -> Int? in
            return state?.rawValue  //存在着将对象转换为json的过程时调用。
        }


  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值