0


我想为我的 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)
                        }
                    }

        }
    }

4

2 回答 2

0

因为使用 srtucts 制作服务模型需要大量工作,如此处所示

我更改了我的课程以使其与 IGListKit 一起使用。

import Foundation
import IGListKit


class Talents: NSObject,Decodable {
    let status : String
    let error : String
    let response : String

    init(status:String,error:String,response:String) {
        self.status   = status
        self.error    = error
        self.response = response
    }

}
extension NSObject: ListDiffable {
  public func diffIdentifier() -> NSObjectProtocol {
    return self
  }

  public func isEqual(toDiffableObject object: ListDiffable?) -> Bool {
    return isEqual(object)
  }
}

于 2020-05-21T09:21:06.843 回答
0

您不需要更改现有的structclass创建一个新的class并制作一个接受struct作为参数的初始化程序:

struct TalentDataModel: Decodable {
    let status : String?
    let error : String?
    let response : String?
}
class Talents: Decodable {
    var status : String?
    var error : String?
    var response : String?

    init(dataModel: TalentDataModel) {
        status   = dataModel.status
        error    = dataModel.error
        response = dataModel.response
    }
}
于 2020-05-20T07:51:07.277 回答