Таким образом, похоже, что табличное представление в Swift динамически перезагружает данные на экран в зависимости от положения прокрутки. Однако в моем случае я не хочу, чтобы механизм работал таким образом, поскольку элементы в моем табличном представлении обновляют общую стоимость заказа пользователя и излишне искажают общее значение цены. Когда я прокручиваю вверх или вниз, ячейки, в которых вызываются данные перезагрузки, повторно выполняют математику и приводят к неправильной общей цене.
Мое желание состоит в том, чтобы пересчитывать цену с помощью функции reloadData()
только тогда, когда UIStepper нажимается на определенную ячейку, а не при прокрутке. Я сделал это с помощью функции IBAction, которая вызывает reloadData
при нажатии шагового двигателя. Проблема с математикой и внутренними данными возникает, когда представление таблицы прокручивается и неоднократно вызывает функцию reloadData
по мере изменения видимых ячеек, чего я не хочу делать для какой-либо формы прокрутки.
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let add_on = JSON(self.add_ons[indexPath.row])
let cell = tableView.dequeueReusableCell(withIdentifier: "AddOnCell", for: indexPath) as! AddOnTableViewCell
quantities[indexPath.row] = cell.quantity
//cell.quantityLabel.text = String(quantities[indexPath.row])
let price = Double(add_on["price"].int!)/100.0
let quantity:Double = Double(quantityLabel.text!)!
//when user tries to increase add-on quantity beyond ticket quantity
if(Int(quantity) < cell.quantity){
print("QUANTITY UPDATED")
cell.quantity -= 1
quantities[indexPath.row] = cell.quantity
}
self.addOnPrice = updateTotal(quantities: self.quantities)
totalPriceLabel.text = (Double(event_subtotal * quantity) + addOnPrice).dollarRound()
cell.addonLabel?.text = add_on["name"].string! + " (+$\(price.roundTo(places: 2))" + ")"
return cell
}
func updateTotal(quantities: [Int]) -> Double{
var result:Double = 0.0
for i in 0..<quantities.count{
let curr_addon = JSON(self.add_ons[i])
let price = Double(curr_addon["price"].int!)/100.0
result += Double(quantities[i]) * price
}
return result.dollarRoundDouble()
}
@IBAction func stepperClicked(_ sender: UIStepper) {
self.addOnPrice = 0.0
AddOnTableView.reloadData()
}
Ниже представлена модель данных ячейки:
class AddOnTableViewCell: UITableViewCell{
@IBOutlet weak var addonLabel: UILabel!
@IBOutlet weak var quantityLabel: UILabel!
@IBOutlet weak var quantityStepper: UIStepper!
var quantity : Int = 0 {
didSet{
self.quantityLabel.text = String(quantity)
self.quantityStepper.value = Double(quantity)
}
}
//ref: https://stackoverflow.com/questions/42876739/swift-increment-label-with-stepper-in-tableview-cell
@IBAction func quantityStep(_ sender: UIStepper) {
self.quantity = Int(sender.value)
self.quantityLabel.text = String(quantity)
}
}
Поведение: при прокрутке вычисленная общая цена меняется без пошагового взаимодействия. В зависимости от положения прокрутки количество для 1 элемента «заменяет» значение количества на другой элемент. Количество первого элемента, ставшее 1, по какой-то причине обновляет количество последнего элемента. Не удалось отладить это поведение.
totalPriceLabel
— это метка, содержащая общую цену.self.addOnPrice
— это то, что добавляется к промежуточной сумме для расчета общей цены. - person btrballin   schedule 05.05.2019