这是我的问题的.gif:http://g.recordit.co/LnslGAaWwK.gif
首先,我可以使用增加或减少按钮来增加或减少值。但是在将表格视图滚动到底部然后又回到我之前更改过的步进器之后,看来递减按钮不起作用,计数器标签上的值仍然保持不变
但是,如果我点击递增按钮,它可以工作,但是仍然给出错误的值,它将重新从1开始,滚动前不会继续该值。
我怀疑问题出在这里(完整代码在下面):
override func awakeFromNib() {
super.awakeFromNib()
setStepper()
}
在滚动到表格视图的底部之后,似乎setStepper()
中的awakeFromNib()
将再次被触发,这意味着步进器(stepper.value = 0)
的初始值将再次返回设为零,这也许就是为什么如果我按下增量按钮,它将给出1,而不是在滚动之前继续该值
这是我的表格视图单元格中的代码
import UIKit
import KWStepper
protocol CounterDelegate{
func incrementOrDecrementButtonDidTapped(at selectedIndexPath:IndexPath, counterValue: Int)
}
class CheckOutCell: UITableViewCell {
var stepper: KWStepper?
var indexPath: IndexPath?
var delegate: CounterDelegate?
@IBOutlet weak var counterLabel: UILabel!
@IBOutlet weak var decrementButton: UIButton!
@IBOutlet weak var incrementButton: UIButton!
var productData : Product? {
didSet {
updateUI()
}
}
override func awakeFromNib() {
super.awakeFromNib()
setStepper()
}
func setStepper() {
stepper = KWStepper(decrementButton: decrementButton, incrementButton: incrementButton)
guard let stepper = stepper else {return}
stepper.autoRepeat = false
stepper.wraps = false
stepper.minimumValue = 0
stepper.value = 0
stepper.incrementStepValue = 1
stepper.decrementStepValue = 1
stepper.valueChangedCallback = { stepper in
let stepperValue = Int(stepper.value)
// send data to CheckoutVC
guard let indexPath = self.indexPath else {return}
self.delegate?.incrementOrDecrementButtonDidTapped(at: indexPath, counterValue: stepperValue)
print(stepperValue)
}
}
func updateUI() {
guard let productData = productData else {return}
counterLabel.text = "\(productData.quantity)"
}
}
那么如何解决这个问题呢?将表格视图滚动到底部后,如何使值继续?
答案 0 :(得分:3)
您需要重新考虑您的策略。
TableView只是其数据源中数据的直观表示,并且一次只能看到一部分数据源。
因此,TableViewCell显示的数据应存储在数据源中,而不是存储在单元格中。
在数组中组织数据,然后让TableViews数据源指向该数组。您需要实现UITableViewDatasource协议(numberOfSections
,numberOfRowsInSection
)的方法。
然后,覆盖cellForRowAtIndexPath
,在该位置用来自数据源数组的数据在indexPath.row
的索引处设置单元格。
使用步进器进行的更改应在数据源中进行。
希望您能明白。