



Установка • Использование • Лицензия
Dynamicjson - это динамически напечатанный диапазон JSON, построенный на новой функции @dynamicMemberLookup , представленной Крисом Латтнером в Swift 4.2. Это позволяет нам получить доступ к произвольным элементам объекта, которые разрешаются во время выполнения, что позволяет Swift быть таким же гибким, как JavaScript, когда дело доходит до JSON.
if let jsonObject = try ? JSONSerialization . jsonObject ( with : data , options : [ ] ) as? [ String : Any ] ,
let user = jsonObject [ " user " ] as? [ String : Any ] ,
let username = user [ " username " ] as? String {
// ...
} let username = JSON ( data ) . user . username . string pod 'DynamicJSON' , '~> 2.0.2' (Если вы столкнетесь с проблемами, pod repo update и попробуйте еще раз)
github "saoudrizwan/DynamicJSON"DynamicJSON.swift в свой проект. И import DynamicJSON в файлы, которые вы хотите использовать.
Бросить Any в объект JSON , чтобы начать
let json = JSON ( Data ( ) )
JSON ( 123 )
JSON ( [ " key " : " value " ] )
JSON ( [ " element " , 1 ] )
JSON ( " Hello world " )
JSON ( false ) ... или бросить буквальный как JSON
let json = " Hello world " as JSON
123 as JSON
[ 1 , 2 , 3 ] as JSON
let user : JSON = [
" username " : " Saoud " ,
" age " : 21 ,
" address " : [
" zip " : " 12345 " ,
" city " : " San Diego "
]
] Относитесь к объектам JSON , как на JavaScript Land
let dictionary = json . dictionary
let array = json [ 0 ] . cars . array
let string = json . users [ 1 ] . username . string
let nsnumber = json . creditCard . pin . number
let double = json [ 3 ] [ 1 ] . height . double
let int = json [ 0 ] . age . int
let bool = json . biography . isHuman . bool Обратите внимание, что JSON на самом деле нет свойств, таких как cars или users , вместо этого он использует динамический поиск членов, чтобы пройти через связанные с ними данные JSON, чтобы найти объект, который вы ищете.
В случае, если у вас есть ключ, который является фактическим свойством JSON , например, number или description , просто используйте аксессу с подписью STRING, как SO:
let number = json . account . contact [ " number " ] . number
let description = json . user . biography [ " description " ] . string JSON соответствует Comparable
let json1 = JSON ( jsonData1 )
let json2 = JSON ( jsonData2 )
// Equality applies to all types (Dictionary, Array, String, NSNumber, Bool, NSNull)
let isEqual = json1 == json2
// Less/greater than only applies to NSNumbers (Double, Int) and Strings
let isLessThan = json1 < json2
let isLessThanOrEqual = json1 <= json2
let isGreaterThan = json1 > json2
let isGreaterThanOrEqual = json1 >= json2Довольно печать для отладочных целей
print ( json )Преобразовать в необработанный объект
let anyObject = json . object Преобразовать в Data
let data = json . data ( ) // optionally specify options...Dynamicjson использует лицензию MIT. Пожалуйста, подайте проблему, если у вас есть какие -либо вопросы или если вы хотите поделиться тем, как вы используете DynamicJson.
Dynamicjson находится в зачаточном состоянии, но обеспечивает голые революционные способы работы с JSON в Swift. Пожалуйста, не стесняйтесь отправлять запросы на привлечение любых функций, которые, по вашему мнению, добавит Dynamicjson и его философии.
Свяжитесь со мной по электронной почте [email protected], или по Twitter @sdrzn. Пожалуйста, создайте проблему, если вы столкнетесь с ошибкой или хотите добавить функцию.
@dynamicMemberLookup