Список ключей для кодирования / декодирования контролируется вызываемым типом CodingKeys
(обратите внимание на s
значок в конце). Компилятор может синтезировать это за вас, но всегда может это отменить.
Допустим, вы хотите исключить свойство nickname
как из кодирования, так и из декодирования:
struct Person: Codable {
var firstName: String
var lastName: String
var nickname: String?
private enum CodingKeys: String, CodingKey {
case firstName, lastName
}
}
Если вы хотите, чтобы он был асимметричным (т.е. кодировал, но не декодировал, или наоборот), вы должны предоставить свои собственные реализации encode(with encoder: )
и init(from decoder: )
:
struct Person: Codable {
var firstName: String
var lastName: String
var fullName: String {
return firstName + " " + lastName
}
private enum CodingKeys: String, CodingKey {
case firstName
case lastName
case fullName
}
init(from decoder: Decoder) throws {
let container = try decoder.container(keyedBy: CodingKeys.self)
firstName = try container.decode(String.self, forKey: .firstName)
lastName = try container.decode(String.self, forKey: .lastName)
}
func encode(to encoder: Encoder) throws {
var container = encoder.container(keyedBy: CodingKeys.self)
try container.encode(firstName, forKey: .firstName)
try container.encode(lastName, forKey: .lastName)
try container.encode(fullName, forKey: .fullName)
}
}
CodingKeys
перечисления.