關(guān)于Swift 4.1中的Codable改進(jìn)詳解
前言
Apple 在 Swift 4.0 中作了很多的改進(jìn),其中我個人最喜歡的就是 Codable 協(xié)議的出現(xiàn)。它讓 Swift 自帶了 JSON 、 XML 結(jié)構(gòu)化數(shù)據(jù)和 Model 的映射和轉(zhuǎn)換能力。
Codable 最常見的使用場景就是:APP 發(fā)起網(wǎng)絡(luò)請求,然后我們將服務(wù)端響應(yīng)的 JSON 數(shù)據(jù)轉(zhuǎn)換為對應(yīng)的 Model 實體。由于服務(wù)端的編程規(guī)范可能與客戶端存在差異, Codable 默認(rèn)數(shù)據(jù)轉(zhuǎn)換實現(xiàn)可能不再適用。例如,服務(wù)端可能使用的蛇形命名方式而客戶端使用的是駝峰。此時我們就需要在客戶端自己動手實現(xiàn)映射關(guān)系。
struct Mac: Codable { var name: String var screenSize: Int var cpuCount: Int } let jsonString = """ [ { "name": "MacBook Pro", "screen_size": 15, "cpu_count": 4 }, { "name": "iMac Pro", "screen_size": 27, "cpu_count": 18 } ] """ let jsonData = Data(jsonString.utf8) let decoder = JSONDecoder() do { let macs = try decoder.decode([Mac].self, from: jsonData) print(macs) } catch { print(error.localizedDescription) }
上訴代碼并不能完成理想的解碼操作,因為 Codable 的默認(rèn)實現(xiàn)無法將蛇形變量名映射到對應(yīng)的駝峰屬性上。所以在 Swift 4.0 中我們需要對 Mac 進(jìn)行部分改造:
struct Mac: Codable { var name: String var screenSize: Int var cpuCount: Int enum CodingKeys : String, CodingKey { case name case screenSize = "screen_size" case cpuCount = "cpu_count" } }
好在 Swift 4.1 對此作出了改進(jìn)?,F(xiàn)在我們可以通過設(shè)置 JSONDecoder 的 keyDecodingStrategy 就能實現(xiàn)不同編程規(guī)范之間解碼操作了。與之對應(yīng),JSONEncoder 也有一個 keyEncodingStrategy 屬性用于不同編程規(guī)范之間的編碼操作。所以上訴代碼可以簡化為:
struct Mac: Codable { var name: String var screenSize: Int var cpuCount: Int } let jsonString = """ [ { "name": "MacBook Pro", "screen_size": 15, "cpu_count": 4 }, { "name": "iMac Pro", "screen_size": 27, "cpu_count": 18 } ] """ let jsonData = Data(jsonString.utf8) let decoder = JSONDecoder() decoder.keyDecodingStrategy = .convertFromSnakeCase do { let macs = try decoder.decode([Mac].self, from: jsonData) print(macs) } catch { print(error.localizedDescription) }
如果你想進(jìn)行反向轉(zhuǎn)換操作的話,代碼也非常簡單:
let encoder = JSONEncoder() encoder.keyEncodingStrategy = .convertToSnakeCase let encoded = try encoder.encode(macs)
當(dāng)然,我們還可以對轉(zhuǎn)換策略進(jìn)行自定義實現(xiàn)以其實現(xiàn)一些特定需求。具體的使用方式可以參照代碼
總結(jié)
以上就是這篇文章的全部內(nèi)容了,希望本文的內(nèi)容對大家的學(xué)習(xí)或者工作具有一定的參考學(xué)習(xí)價值,如果有疑問大家可以留言交流,謝謝大家對腳本之家的支持。
相關(guān)文章
Swift 中如何使用 Option Pattern 改善可選項的 API 設(shè)計
這篇文章主要介紹了Swift 中如何使用 Option Pattern 改善可選項的 API 設(shè)計,幫助大家更好的進(jìn)行ios開發(fā),感興趣的朋友可以了解下2020-10-10Objective-c代碼如何移植為Swift代碼 Objective-c代碼轉(zhuǎn)移到Swift過程介紹
這篇文章主要介紹了Objective-c代碼如何移植為Swift代碼,Objective-c代碼轉(zhuǎn)移到Swift過程介紹,需要的朋友可以參考下2014-07-07Swift教程之基礎(chǔ)數(shù)據(jù)類型詳解
這篇文章主要介紹了Swift教程之基礎(chǔ)數(shù)據(jù)類型詳解,本文詳細(xì)講解了Swift中的基本數(shù)據(jù)類型和基本語法,例如常量和變量、注釋、分號、整數(shù)、數(shù)值類型轉(zhuǎn)換等內(nèi)容,需要的朋友可以參考下2015-01-01swift實現(xiàn)自定義圓環(huán)進(jìn)度提示效果
這篇文章主要為大家詳細(xì)介紹了swift實現(xiàn)自定義圓環(huán)進(jìn)度提示效果,具有一定的參考價值,感興趣的小伙伴們可以參考一下2016-05-05