Firestore - UITableViewCell 中的 UISlider

Firestore - UISlider inside UITableViewCell

我在 tableView 的自定义单元格中有一个 UISlider。在单元格中还有一个显示滑块值的 UILabel。目前我已经得到它,所以我可以将滑块值更新到 firestore 并更新到标签中。但是,当我关闭 screen/app 并再次加载屏幕时,我无法将之前的滑块值加载到滑块中。我仍然可以更新滑块值,它仍然会转移到 firestore 并且一切正常。我曾尝试在屏幕首次启动时将 firestore 中的值加载到滑块中,效果很好,但它不允许我在执行此操作时更新屏幕上的滑块,但它会在 firestore 上更新。完美的是,当屏幕首次加载时,数据从 firestore 加载,然后我可以更新滑块,它将在应用程序和 firestore 中工作。任何帮助将不胜感激!非常感谢!!

ViewController

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! TableViewCell

    cell.slider.tag = indexPath.row
    cell.slider.addTarget(self, action: #selector(ViewController.sliderChange(sender:)), for: .valueChanged)

    cell.sliderLabel.text = String(Int(cell.slider.value))

    // code that loads values when screen is first launched but then doesn't let me update the onscreen values
    cell.slider.value = Float(array[indexPath.row].number)

    return cell
}

 @objc func sliderChange(sender: UISlider) {
    let currentValue = Int(sender.value)
    let row = sender.tag
    let Id = array[row].documentID

    let userRef = db.collection("Users").document(user!)
    userRef.collection("Friends").document(Id).updateData(["number" : currentValue]) {
        error in
        if let error = error {
            print("Error adding document: \(error.localizedDescription)")
        } else {
            print(currentValue)
        }
    }

    self.tableView.reloadData()

}

TableViewCell

class TableViewCell: UITableViewCell {

@IBOutlet weak var sliderLabel: UILabel!
@IBOutlet weak var slider: UISlider!

override func awakeFromNib() {
    super.awakeFromNib()
    // Initialization code

}

override func setSelected(_ selected: Bool, animated: Bool) {
    super.setSelected(selected, animated: animated)

    // Configure the view for the selected state
}

将方法重构为此,请注意更新代码是异步的,您必须将更改的数据反映到 table 数据源数组并重新加载成功部分中的 table

 @objc func sliderChange(sender: UISlider) {

    let currentValue = Int(sender.value)
    let row = sender.tag
    let Id = array[row].documentID

    let userRef = db.collection("Users").document(user!)
    userRef.collection("Friends").document(Id).updateData(["number" : currentValue]) {
        error in
        if let error = error {
            print("Error adding document: \(error.localizedDescription)")
        } else {
            print(currentValue)
            array[indexPath.row].number = sender.value // set it according to type of number property 
            self.tableView.reloadData()  
        }

    }

}