XMLMapper 未在 UITableView 中显示结果

XMLMapper not showing result in UITableView

我遇到无法从 XMLMapper (objectmapper) 获取 responseData 到 UITableView 的问题。 Tableview 显示 5 个空单元格。谁能帮我解决这个问题?

我正在尝试完成一个表格视图,其中 IDNR(字符串)显示为标签,有效性显示为 DetailTextView

此致,

帕特里克

class PersonDetailsView: UITableViewController {
    
    let redirector = Redirector(behavior: .doNotFollow)
    let RequestUrl = "https://apiurlexample.com/api" 
    var personID:String = ""
    
    var schedules: [cardResult]?
    @IBOutlet weak var tableViewData: UITableView!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        GetCardNumbers()
    }
    
    class cardResult: XMLMappable {
        
        var nodeName: String!
        
        var error: String?
        var cardrowset: cardRowset?
        
        required init?(map: XMLMap) {}
        
        func mapping(map: XMLMap) {
            error <- map.attributes["error"]
            cardrowset <- map["ROWSET"]
        }
    }
    //
    
    class cardRowset: XMLMappable {
        var nodeName: String!
        
        var cardrows: [cardRow]?
        
        required init?(map: XMLMap) {}
        
        func mapping(map: XMLMap) {
            cardrows <- map["ROW"]
        }
    }
    
    class cardRow: XMLMappable {
        var nodeName: String!
        
        var rcn: String?
        var valid: String?
        
        required init?(map: XMLMap) {}
        
        func mapping(map: XMLMap) {
            rcn <- map["IDNR"]
            valid <- map["VALIDITY"]
        }
    }
    
    func GetCardNumbers() {
        
        //
        class personDetails: XMLMappable {
            var nodeName: String!
            var sql: String?
            
            init() {}
            
            required init?(map: XMLMap) {}
            
            func mapping(map: XMLMap) {
                sql <- (map["sql"], XMLCDATATransform())
            }
        }
        
        let persondetails = personDetails()
        persondetails.nodeName = "query"
        persondetails.sql = "select IDNR, Validity from accesskey WHERE personid=\(personID)"
        
        
        AF.request(RequestUrl, method: .post, parameters: persondetails.toXML(), encoding: XMLEncoding.default)
            .redirect(using: redirector)
            .responseXMLObject { (response: DataResponse<cardResult, AFError>) in
                
                
                switch response.result {
                
                case .success(let value):
                    
                    debugPrint(value)
                    print("AF-Success")
                    
                case .failure(let error):
                    
                    print("AF-Error")
                    print(error)
                    
                }
            }
    }
    
    override func numberOfSections(in tableView: UITableView) -> Int {
        return 1
    }
    
    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // return the number of rows
        return 5
    }
    
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)

        let person = schedules?[indexPath.row].cardrowset?.cardrows
        cell.textLabel?.text = person?[indexPath.row].valid

        return cell
    }

首先,最好遵循Swift的API Design Guidelines:

Follow case conventions. Names of types and protocols are UpperCamelCase. Everything else is lowerCamelCase.

此外,要在您的 UITableView 中显示 CardRow 元素的数组,您需要将该数组保存在视图控制器中。相反,你声明了一个 CardResult 元素数组,这是不正确的,因为只有一个 CardResult 对象。

也就是说,您的视图控制器应该是这样的:

class PersonDetailsView: UITableViewController {
    
    let redirector = Redirector(behavior: .doNotFollow)
    let requestUrl = "https://apiurlexample.com/api"
    var personID: String = ""
    
    var cardRows: [CardRow] = []
    @IBOutlet weak var tableViewData: UITableView!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        
        getCardNumbers()
    }
    
    class CardResult: XMLMappable {
        var nodeName: String!
        
        var error: String?
        var cardrowset: CardRowset?
        
        required init?(map: XMLMap) {}
        
        func mapping(map: XMLMap) {
            error <- map.attributes["error"]
            cardrowset <- map["ROWSET"]
        }
    }
    
    class CardRowset: XMLMappable {
        var nodeName: String!
        
        var cardrows: [CardRow]?
        
        required init?(map: XMLMap) {}
        
        func mapping(map: XMLMap) {
            cardrows <- map["ROW"]
        }
    }
    
    class CardRow: XMLMappable {
        var nodeName: String!
        
        var rcn: String?
        var valid: String?
        
        required init?(map: XMLMap) {}
        
        func mapping(map: XMLMap) {
            rcn <- map["IDNR"]
            valid <- map["VALIDITY"]
        }
    }
    
    func getCardNumbers() {
        class PersonDetails: XMLMappable {
            var nodeName: String!
            var sql: String?
            
            init() {}
            
            required init?(map: XMLMap) {}
            
            func mapping(map: XMLMap) {
                sql <- (map["sql"], XMLCDATATransform())
            }
        }
        
        let persondetails = PersonDetails()
        persondetails.nodeName = "query"
        persondetails.sql = "select IDNR, Validity from accesskey WHERE personid=\(personID)"
        
        
        AF.request(requestUrl, method: .post, parameters: persondetails.toXML(), encoding: XMLEncoding.default)
            .redirect(using: redirector)
            .responseXMLObject { (response: DataResponse<CardResult, AFError>) in
                switch response.result {
                case .success(let value):
                    debugPrint(value)
                    print("AF-Success")
                    
                    self.cardRows = value.cardrowset?.cardrows ?? []
                    self.tableView.reloadData()
                case .failure(let error):
                    print("AF-Error")
                    print(error)
                }
            }
    }
    
    // numberOfSections(in:) doesn't actually needed here since by default UITableView has one section
    
    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // Here you need to return the count of the cardRows array
        return cardRows.count
    }
    
    override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

        let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath)

        let person = cardRows[indexPath.row]
        cell.textLabel?.text = person.valid

        return cell
    }
}