



Instalação • Uso • Licença
O Dynamicjson é um analisador JSON dinamicamente tipado, construído sobre o novo recurso @dynamicMemberLookup , introduzido por Chris Lattner no Swift 4.2. Isso nos permite acessar os membros do objeto arbitrário que são resolvidos em tempo de execução, permitindo que o SWIFT seja tão flexível quanto o JavaScript quando se trata do 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' (Se você tiver problemas, pod repo update e tentar novamente)
github "saoudrizwan/DynamicJSON"DynamicJSON.swift em seu projeto. E import DynamicJSON nos arquivos que você deseja usá -los.
Jogue Any coisa em um objeto JSON para começar
let json = JSON ( Data ( ) )
JSON ( 123 )
JSON ( [ " key " : " value " ] )
JSON ( [ " element " , 1 ] )
JSON ( " Hello world " )
JSON ( false ) ... ou lançar um literal como 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 "
]
] Trate objetos JSON como você está em 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 Observe como JSON não possui propriedades como cars ou users ; em vez disso, ele usa a pesquisa de membros dinâmicos para atravessar seus dados JSON associados para encontrar o objeto que você está procurando.
Caso você tenha uma chave que seja uma propriedade real do JSON , como number ou description , por exemplo, basta usar o acessador subscrito de string como assim:
let number = json . account . contact [ " number " ] . number
let description = json . user . biography [ " description " ] . string JSON está em conformidade com 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 >= json2Pretada impressão para fins de depuração
print ( json )Converter em objeto bruto
let anyObject = json . object Converter em Data
let data = json . data ( ) // optionally specify options...Dynamicjson usa a licença do MIT. Por favor, arquive um problema se você tiver alguma dúvida ou se quiser compartilhar como está usando o Dynamicjson.
A Dynamicjson está em sua infância, mas fornece os barcos de uma nova maneira revolucionária de trabalhar com o JSON em Swift. Sinta -se à vontade para enviar solicitações de puxar de todos os recursos que você acha que adicionariam ao Dynamicjson e sua filosofia.
Entre em contato comigo por e -mail [email protected] ou pelo Twitter @sdrzn. Crie um problema se você encontrar um bug ou desejar um recurso a ser adicionado.
@dynamicMemberLookup