表视图不更新
tableview does not update
我正在尝试为餐厅制作一个点餐应用程序,当我第一次将商品添加到购物车时 table 视图加载了我制作的单例数组。但是当我返回菜单并选择另一个项目时,数组已更新但购物车的 table 视图没有,我正在使用 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
}
}
UITableViewDelegate 不是反应性的。当您想要更新 tableView 内容时(当您的 DataService.instance 值更新时),您必须调用 reloadData()。
在 MVP 世界中,您的 "add" 操作将触发演示者的事件。在更新您的 DataService 之后,演示者会向视图发送一个更新 tableView 的操作。
也许您应该看看 RxSwift/ReactiveCocoa,它提供了 API 来自动将您的 DataService.instance
数组绑定到 UITableView 中呈现的单元格。
tabbar 每次 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()
}
我正在尝试为餐厅制作一个点餐应用程序,当我第一次将商品添加到购物车时 table 视图加载了我制作的单例数组。但是当我返回菜单并选择另一个项目时,数组已更新但购物车的 table 视图没有,我正在使用 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
}
}
UITableViewDelegate 不是反应性的。当您想要更新 tableView 内容时(当您的 DataService.instance 值更新时),您必须调用 reloadData()。
在 MVP 世界中,您的 "add" 操作将触发演示者的事件。在更新您的 DataService 之后,演示者会向视图发送一个更新 tableView 的操作。
也许您应该看看 RxSwift/ReactiveCocoa,它提供了 API 来自动将您的 DataService.instance
数组绑定到 UITableView 中呈现的单元格。
tabbar 每次 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()
}