将Json字符串解码为类对象Swift

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)

pre*_*rex 5

如果您尝试解码任何类型的对象,请使用这些技术

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)

  • 可编码错误非常具有描述性,没有代码,最重要的信息在“context”属性中。 (2认同)