如何在Swift 5中将数据从UITableViewCell发送到ViewController

时间:2019-03-21 17:19:40

标签: uitableview swift5

我有一个UISlider和一个UILabel。我想将值从该UISlider反映到我的UILabel。 我有一个都有两个插座的UITableViewCell,还有一个我连接了Slider的ViewController,并创建了一个动作函数(ValueChanged)。我在该函数中执行了逻辑,但无法正常工作,因为它说我的出路是NIL。 谁能帮助我正确传递此数据? 也许可以用代表来完成,但我不知道该怎么做。

这是我的UITableViewCell代码:

import UIKit

class SliderCell: UITableViewCell {

    // Interface Links
    @IBOutlet weak var slider: UISlider!
    @IBOutlet weak var progressLabel: UILabel!

    override func awakeFromNib() {
        super.awakeFromNib()
    }

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

这是控制器:

import UIKit

// Table View with Dynamic Cells
class MainViewController: UITableViewController {

    var sliderCell: SliderCell!

    override func viewDidLoad() {
        super.viewDidLoad()

        sliderCell = SliderCell()
    }

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

        switch indexPath.row {
        // Row 0  -  My Slider
        case 0:
            let cell = tableView.dequeueReusableCell(withIdentifier: "sliderCell", for: indexPath) as! SliderCell
            return cell
        default:
            return UITableViewCell()
        }
    }

    override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return 1
    }

    override func tableView(_ tableView: UITableView, heightForRowAt indexPath: IndexPath) -> CGFloat {

        // Set the height for slider cell to 200 pixels
        switch indexPath.row {
        case 0:
            return 200
        default:
            return 200
        }
    }

    // Reflect the value of Slider to ProgressLabel
    @IBAction func sliderValueChanged(_ sender: UISlider) {

        var currentValue = Int(sender.value)
        let stepSize:Int = 10
        currentValue = (currentValue - currentValue % stepSize)
        DispatchQueue.main.async {
            self.sliderCell.progressLabel.text = "\(currentValue)%"
        }
    }
}

如果您正在阅读本文,请先感谢!

1 个答案:

答案 0 :(得分:1)

不要在此处添加对您的单元格的引用

sliderCell = SliderCell()

但是在cellForRowAt中使用委托,就像

  let cell = 
  cell.delegate = self

然后在单元格内发送任何内容

delegate?.sendSliderValue()

您还可以在vc之类的内部添加滑块操作实现

let cell = //
cell.slider.addTarget ////
cell.slider.tag = indexPath.row

 @objc func sliderChanged(_ slider:UISlider) { 
     print(slider.value,slider.tag)
     if let cell = tableView.cellForRow(at:IndexPath(row:slider.tag,section:0)) as? SliderCell {
         var currentValue = Int(sender.value)
         let stepSize:Int = 10
         currentValue = (currentValue - currentValue % stepSize)
         cell.progressLabel.text = "\(currentValue)"
     }

     // or 

     if let cell = tableView.visibleCells.first as? SliderCell {
       //////
     }
 }