为了将数据对象话,通常需要将网络请求的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)
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的过程时调用。
}