我想为我的 UICollectionView 实现 IgListKit。这个库要求我使用“类模型:ListDiffable”
根据我当前的架构,我有“结构模型:可解码”当我在 NetworkService 中使用 JSON 解码器来检索数据时,我有 2 个结构,1 个用于根,2 个用于我的数组。
struct Talents : Decodable {
let status : String?
let error : String?
let response : String?
}
struct Talent: Decodable {
let id: String
let name : String
let smallDesc: String
let largeDesc : String
}
\\I also have enum CodingKeys to match the keys for both structs
以下是结构输出,可以在我的 UICollectionView 中使用
当我将这些结构更改为类时
class Talents : Decodable {
var status : String?
var error : String?
var response : String?
init( status : String,error : String, response : String){
self.status = status
self.error = error
self.response = response
}
}
这是我得到的类输出,我不知道如何使用。
为了解决这个问题,我应该做些什么改变,并将 ListDiffable 协议存根应用于我的模型类?
带有实例的服务文件,在我的 CollectionVC 的 viewDidLoad 中,我将数据放入数组中。
static func getCategoryTalents(category:String,completion: @escaping (Bool, [Talent]?, Error?) -> Void) {
let parameters: Parameters = [
"filter": category,
"shuffle": 1
]
AF.request(Constants.baseUrl,
parameters : parameters ).response { response in
guard let data = response.data else {
DispatchQueue.main.async {
print("\(Error.self)")
completion(false, nil, Error.self as? Error)
}
return}
do {
let talentsResponse = try JSONDecoder().decode(Talents.self, from: data)
print(talentsResponse)
let firstJSONString = talentsResponse.response?.replacingOccurrences(of: "\\", with: "")
let secondJSONString = firstJSONString?.replacingOccurrences(of: "\"{", with: "{").replacingOccurrences(of: "}\"", with: "}")
guard let talentArray = try! JSONDecoder().decode([Talent]?.self, from: (secondJSONString?.data(using: .utf8)!)!) else {
return }
print(talentArray)
var talents = [Talent]()
for talent in talentArray {
guard let individualTalent = talent as Talent? else { continue }
talents.append(individualTalent)
}
DispatchQueue.main.async {
completion(true, talents, nil)
}
} catch {
DispatchQueue.main.async {
completion(false, nil, error)
}
}
}
}