



التثبيت • الاستخدام • الترخيص
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 كما كنت في جافا سكريبت لاند
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 على سبيل المثال ، فقط استخدم ملحق Corrcriptive 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] ، أو عن طريق TwitterSdrzn. يرجى إنشاء مشكلة إذا واجهت خطأ أو ترغب في إضافة ميزة.
@dynamicMemberLookup