ios - 具有不同数组的多个 TableView

标签 ios swift uitableview cocoa-touch

我有一个详细 View ,显示事件的详细信息、参与人员和要求参与的人员。我创建了两个不同类型的数组,但它们具有相同的字段,只是第一个结构代表“status_confirm”字段等于 1 的用户(因此是“接受的用户”),而另一个结构的“status_confirm”字段等于 0(用户等待接受)。我声明了两个数组,第一个:var arrayUserAccepted = [User_accepted] ()。 第二个:var arrayUserWaiting = [User_waiting] ()Struct Image 下一步:我通过 php 脚本填充这些结构

func getData(){
    let url = URL(string: “MYURL”)
    URLSession.shared.dataTask(with:url!, completionHandler: {(data, response, error) in
    guard let data = data, error == nil else { return }
    do {
        let json = try JSONSerialization.jsonObject(with: data, options: []) as! [String:AnyObject]
        print("JSON: \n\(json)\n")
        let waiting = json["waiting"] as! [AnyObject]
        let accepted = json["accepted"] as! [AnyObject]
        DispatchQueue.main.async {
            for list_user_waiting in waiting {
                let id_user_waiting = list_user_waiting["id_user”] as! String
                let name_user_waiting = list_user_waiting[“name_user”] as! String
                let email_user_waiting = list_user_waiting["email"] as! String
                var photo_user_waiting = list_user_waiting[“photo”]
                let status_user_waiting = list_user_waiting["status”] as! String
                if photo_user_waiting is NSNull {
                    photo_user_waiting = ""
                }
                let listUserWaiting = User_waiting(id_user_waiting: id_user_waiting, name_user_waiting: name_user_waiting, email_user_waiting: email_utente_attesa, foto_waiting: photo_user_waiting as! String, status_waiting: status_user_waiting)
                self.arrayUserWaiting.append(listUserWaiting)
                self.tableViewListUserWaiting.reloadData()
            }

            for list_user_accepted in accepted {
                let id_user_accepted = list_user_accepted["id_utente"] as! String
                let name_user_accepted = list_user_accepted["name_utente"] as! String
                let email_user_accepted = list_user_accepted["email"] as! String
                var photo_user_accepted = list_user_accepted[“photo"]
                let status_user_accepted = list_user_accepted["status”] as! String
                if photo_user_accepted is NSNull {
                    photo_user_accepted = ""
                }
                let listUserAccepted = User_accepted(id_user: id_user_accepted, nome_utente: name_user_accepted, email: email_user_accepted, foto: photo_user_accepted as! String, stato: status_user_accepted)
                self.arrayUserAccepted.append(listUserAccepted)
                self.tableViewListUserAccepted.reloadData()
            }
        }
    } catch let error as NSError {
        print(error)
    }
}).resume()}

上面是我在 viewDidLoad() 中调用的函数。下一步是使用 TableView 的功能,我认为这里有禁令

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    var count: Int?
    if tableView == self.tableViewListUserAccepted {
        count = arrayUserAccepted.count
    }
    if tableView == self.tableViewListUserWaiting {
        count = arrayUserWaiting.count
    }
    return count!
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! TableViewCell
    if tableView == self.tableViewListUserAccepted {
        cell.imageProfileUserAccepted.image = UIImage(named: "imageDefault")
        cell.valueSliderUserAccepted.value = Float(50) //JUST FOR POPULATE THE INTERFACE
        cell.name_user_accepted.text = arrayUserAccepted[indexPath.row].name_user
    } 
    if tableView == self.tableViewListUserWaiting {
        cell.imageProfileUserWaiting.image = UIImage(named: "imageDefault")
        cell.valueSliderUserWaiting.value = Float(23) //JUST FOR POPULATE THE INTERFACE
        cell.name_user_waiting.text = arrayUserWaiting[indexPath.row].name_user_waiting
    }
    return cell
}

完成这一轮后,我启动了应用程序,但什么也没启动。 table 是空的。在控制台中,脚本正确地回答了我,所以我无法弄清楚错误可能出在哪里。不用说,我已经在 Main.Storyboard 和代码中声明了两个表的 .delegate 和 .dataSource。

最佳答案

一切都很好,只需更改 IF 条件的格式即可。

func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    var count: Int?
    if tableView == self.tableViewListUserAccepted {
        count = arrayUserAccepted.count
    } else {
        count = arrayUserWaiting.count
    }
    return count!
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {

    if tableView == self.tableViewListUserAccepted {
        let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! TableViewCell
        cell.imageProfileUserAccepted.image = UIImage(named: "imageDefault")
        cell.valueSliderUserAccepted.value = Float(50) //JUST FOR POPULATE THE INTERFACE
        cell.name_user_accepted.text = arrayUserAccepted[indexPath.row].name_user
        return cell
    } else {
        let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! TableViewCell
        cell.imageProfileUserWaiting.image = UIImage(named: "imageDefault")
        cell.valueSliderUserWaiting.value = Float(23) //JUST FOR POPULATE THE INTERFACE
        cell.name_user_waiting.text = arrayUserWaiting[indexPath.row].name_user_waiting
        return cell
    }

}

还要检查两个 tableViewdatasourcedelegate 是否已设置。最后,在 viewDidLoad() 方法中填充数组后,在两个 TableView 上调用 tableView.reloadTable() 方法。

关于ios - 具有不同数组的多个 TableView ,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54797239/

相关文章:

ios - UISegmentedControl filter Table View data JSON 错误

ios - 如何提交与旧版本 iOS 不兼容的新版本应用程序?

ios - UILongPressGestureRecognizer 不做任何事情

ios - 将 UIImage 传递到另一个 View Controller 的 Cell

触摸时未检测到 Swift/Spritekit SKNode

ios - UISearchController 不会向上移动我的 UITableView

ios - pod 更新在 iOS 终端中执行时出现错误

ios - 使用 OSX 在 vi​​rtualbox 上运行 xcode

swift - 在主应用程序和今日小部件 macOS 之间共享数据

ios - 如果/否则基于数组中对象的存在?