CaesarParser - Swift中的JSON模型解析器
CaesarParser
CaesarParser 是一個框架采用 Swift 開發,用于解析JSON模型。
特性
- JSON deserialization, parse JSON to Model
- JSON serialization, parse Model to JSON
- Support nested class, stand along, in arrays or in dictionaries
- Custom converter during parsing
- Support struct, primitive type, raw representable enum
要
Cocoa Touch Framework requires iOS 8 or later.
Manual add CaesarParser to your project requires iOS 7 or later.
基本用法
Any type that confirm Deserializable
or Convertible
protocol can be parse. Besides you can use custom value converter during parsing.
/// Use for Class, Nested Type
public protocol Deserializable {
init(json: JSONDictionary)
}
/// Use for Primitive Type
public protocol Convertible {
static func convert(json: JSONObject) -> Self?
}
Any type that confirm Serializable
can be parse to JSON.
/// convert to JSON object
public protocol Serializable {
func toJSONObject() -> JSONObject
}
Build-in Support
- Int
- String
- Double
- Float
- Bool
- NSURL
- NSDate (unix_timestamp to NSDate, can be custom by build-in DateFormatConverter)
- NSURL (string to URL)
- Raw representable enums which raw value confirm to
Convertible
- Array<Convertible or Deserializable>
- Dictionary<Convertible and Hashable, Convertible or Deserializable>
Demo Code
enum Sex: Int {
case Unknown = 0
case Male = 1
case Female = 2
}
class Person: Deserializable, Serializable {
var name: String
var age: Int
var birthday: Double
var weight: Float
var adult: Bool = false
var sex: Sex = .Unknown
var girlFriend: Person?
var friends = [Person]()
var luckyNumbers = [Int]()
var favouredSingers = [String: Person]()
var vips = [Int: Person]()
var preferNumbers = [Int: Int]()
var orientation = [Sex]()
init(json: JSONDictionary) {
name <-- json["name"]
age <-- json["age"]
birthday <-- json["birthday"]
weight <-- json["weight"]
adult <-- json["adult"]
sex <-- json["sex"]
girlFriend <-- json["girlFriend"]
friends <-- json["friends"]
luckyNumbers <-- json["luckyNumbers"]
favouredSingers <-- json["favouredSingers"]
vips <-- json["vips"]
preferNumbers <-- json["preferNumbers"]
orientation <-- json["orientation"]
}
func toJSONObject() -> JSONObject {
var json = JSONDictionary()
name --> json["name"]
age --> json["age"]
birthday --> json["birthday"]
weight --> json["weight"]
adult --> json["adult"]
sex --> json["sex"]
girlFriend --> json["girlFriend"]
friends --> json["friends"]
luckyNumbers --> json["luckyNumbers"]
favouredSingers --> json["favouredSingers"]
vips --> json["vips"]
preferNumbers --> json["preferNumbers"]
orientation --> json["orientation"]
return json
}
}
Acknowledgements
- JSONHelper CaesarParser is inspired by JSONHelper a lot, thanks for their great work.
License
CaesarParser is available under the MIT license.
本文由用戶 jopen 自行上傳分享,僅供網友學習交流。所有權歸原作者,若您的權利被侵害,請聯系管理員。
轉載本站原創文章,請注明出處,并保留原始鏈接、圖片水印。
本站是一個以用戶分享為主的開源技術平臺,歡迎各類分享!