Kas*_*ake 4 decode swift codable
private func createWeatherObjectWith(json: Data, x:Any.Type ,completion: @escaping (_ data: Any?, _ error: Error?) -> Void) {
do {
let decoder = JSONDecoder()
decoder.keyDecodingStrategy = .convertFromSnakeCase
let weather = try decoder.decode(x.self, from: json)
return completion(weather, nil)
} catch let error {
print("Error creating current weather from JSON because: \(error.localizedDescription)")
return completion(nil, error)
}
}
Run Code Online (Sandbox Code Playgroud)
在这里,我编写上面的代码,通过传递类类型将Json字符串解码为类对象.但是它给出了以下错误
Cannot invoke 'decode' with an argument list of type '(Any.Type, from: Data)'
Run Code Online (Sandbox Code Playgroud)
如果您尝试解码任何类型的对象,请使用这些技术
1.泛型功能
private func createWeatherObjectWith<T: Decodable>(json: Data, Object:T.Type ,completion: @escaping (_ data: T?, _ error: Error?) -> Void) {
do {
let decoder = JSONDecoder()
decoder.keyDecodingStrategy = .convertFromSnakeCase
let weather = try decoder.decode(T.self, from: json)
return completion(weather, nil)
} catch let error {
return completion(nil, error)
}
}
Run Code Online (Sandbox Code Playgroud)
2.扩展可解码
extension Decodable {
static func map(JSONString:String) -> Self? {
do {
let decoder = JSONDecoder()
decoder.keyDecodingStrategy = .convertFromSnakeCase
return try decoder.decode(Self.self, from: Data(JSONString.utf8))
} catch let error {
print(error)
return nil
}
}
}
Run Code Online (Sandbox Code Playgroud)
使用:
let user = User.map(JSONString:"your JSON string")
let users = [User].map(JSONString:"your JSON string")
Run Code Online (Sandbox Code Playgroud)