最近我将Codable
合并到一个项目中,并从符合JSON
的类型中获取Encodable
对象,我想出了这个扩展名,
extension Encodable {
/// Converting object to postable JSON
func toJSON(_ encoder: JSONEncoder = JSONEncoder()) -> [String: Any] {
guard let data = try? encoder.encode(self) else { return [:] }
guard let object = try? JSONSerialization.jsonObject(with: data, options: .allowFragments) else { return [:] }
guard let json = object as? [String: Any] else { return [:] }
return json
}
}
这很好,但是有没有更好的方法可以达到相同目的呢?我感觉到频繁jsonObject(with:
具有较大data
的对象的调用gridster
可能会有性能问题。
答案 0 :(得分:1)
我的建议是命名函数toDictionary
并将可能的错误移交给调用方。有条件的向下失败(类型不匹配)被包装在typeMismatch
de 编码错误中。
extension Encodable {
/// Converting object to postable dictionary
func toDictionary(_ encoder: JSONEncoder = JSONEncoder()) throws -> [String: Any] {
let data = try encoder.encode(self)
let object = try JSONSerialization.jsonObject(with: data)
guard let json = object as? [String: Any] else {
let context = DecodingError.Context(codingPath: [], debugDescription: "Deserialized object is not a dictionary")
throw DecodingError.typeMismatch(type(of: object), context)
}
return json
}
}