我正在尝试为餐馆订购食品应用程序,当我第一次将商品添加到购物车中时,表格视图会加载我制作的单例数组。但是,当我返回菜单并选择另一个项目时,数组会更新,但购物车的表视图不会更新,我使用的是tabbarcontroller。试图在不同的地方使用tableview.reloadData()仍然没有出现添加到数组的新数据
class CartVC: UIViewController, UITableViewDelegate, UITableViewDataSource{
@IBOutlet weak var priceLbl: UILabel!
@IBOutlet weak var tableView: UITableView!
override func viewDidLoad() {
super.viewDidLoad()
tableView.reloadData()
// Do any additional setup after loading the view.
tableView.delegate = self
tableView.dataSource = self
tableView.reloadData()
updateView()
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return DataService.instance.cartItems.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
if let cell = tableView.dequeueReusableCell(withIdentifier: "cartCell") as? CartCell{
let item = DataService.instance.cartItems[indexPath.row]
cell.configCell(cart: item)
return cell
} else {
return UITableViewCell()
}
}
func numberOfSections(in tableView: UITableView) -> Int {
return 1
}
func tableView(_ tableView: UITableView, canEditRowAt indexPath: IndexPath) -> Bool {
return true
}
func tableView(_ tableView: UITableView, commit editingStyle: UITableViewCell.EditingStyle, forRowAt indexPath: IndexPath) {
if editingStyle == .delete {
DataService.instance.cartItems.remove(at: indexPath.row)
tableView.beginUpdates()
tableView.deleteRows(at: [indexPath], with: .automatic)
updateView()
tableView.endUpdates()
}
}
func updateView(){
var sum = 0
for item in DataService.instance.cartItems{
sum += item.itemPrice * item.quantity
print(item.itemPrice)
}
priceLbl.text = "$\(sum)"
}
@IBAction func orderPressed(_ sender: Any) {
// upload order to firebase, clear cart and move to orderVC
}
}
答案 0 :(得分:0)
UITableViewDelegate不起作用。要更新tableView内容时(在更新DataService.instance值时),必须调用reloadData()。
在MVP世界中,您的“添加”操作将向演示者触发一个事件。在更新您的DataService之后,演示者将向该视图发送回操作以更新tableView。
也许您应该看看RxSwift/ReactiveCocoa,它提供了API,可以自动将DataService.instance
数组绑定到UITableView中呈现的单元格。
答案 1 :(得分:0)
每次未viewDidLoad
调用时在选项卡中,因此您需要重新加载viewWillAppear
或viewDidAppear
中的数据。这是参考。
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
tableView.delegate = self
tableView.dataSource = self
updateView()
}
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
tableView.reloadData()
}