Jeśli nie przeszkadza trochę przesunięcia danych wokół można użyć coś takiego:
extension Encodable {
func asDictionary() throws -> [String: Any] {
let data = try JSONEncoder().encode(self)
guard let dictionary = try JSONSerialization.jsonObject(with: data, options: .allowFragments) as? [String: Any] else {
throw NSError()
}
return dictionary
}
}
lub opcjonalnego varient
extension Encodable {
var dictionary: [String: Any]? {
guard let data = try? JSONEncoder().encode(self) else { return nil }
return (try? JSONSerialization.jsonObject(with: data, options: .allowFragments)).flatMap { $0 as? [String: Any] }
}
}
Zakładając Foo
zgodny Codable
czy naprawdę Encodable
możesz to zrobić.
let struct = Foo(a: 1, b: 2)
let dict = try struct.asDictionary()
let optionalDict = struct.dictionary
Jeśli chcesz iść w drugą stronę (init(any)
), przyjrzeć się tej Init an object conforming to Codable with a dictionary/array
Działa to tylko w przypadku obiektów o wszystkich właściwościach tego samego rodzaju –