【发布时间】:2020-03-20 01:17:00
【问题描述】:
我正在尝试使用委托将数据从一个视图控制器传递到另一个视图控制器
现在我在按下 CartCell 中的 modifyButton 时正在努力将数据从 CartVC 传递到 ModifyVC。这与我之前提出的前一个问题类似(参见下面的链接)。我只是在努力将数据传递给 ModifyVC,因为我一直收到错误消息 Thread 1: Fatal error: Unexpectedly found nil while implicitly unwrap an Optional value 并关闭模拟器
modifybtn 为 CartVC 中选择的 cel 传递单元格数据
我不想使用 didSelectRowAt 来传递单元格数据,因为我使用 CartCell 中的 modifyBtn 来使用 ModifyDelegate 传递数据
我知道我已经接近完成这项工作的解决方案。我只是收到一个错误,阻止我将数据传递给 ModifyVC
How pass data from button in TableViewCell to View Controller?
class CartViewController: UIViewController, UITableViewDelegate, UITableViewDataSource{
var selectedProduct: Items!
var modifyItems: Cart?
var cart: [Cart] = []
var groupedItems: [String: [Cart]] = [:]
var brands: [String] = []
@IBOutlet weak var cartTableView: UITableView!
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
}
override func prepare(for segue: UIStoryboardSegue, sender: Any?) { //segue code for delegate
if let vc = segue.destination as? ModifyViewController {
vc.modifyItems = self.modifyItems
}
}
func numberOfSections(in tableView: UITableView) -> Int {
return brands.count
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
let brand = brands[section]
return groupedCartItems[brand]!.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cartCell = tableView.dequeueReusableCell(withIdentifier: "CartCell") as! CartCell
let brand = brands[indexPath.section]
let itemsToDisplay = groupedItems[brand]![indexPath.row]
cartCell.configure(withCartItems: itemsToDisplay.cart)
cartCell.modifyDelegate = self
cartCell.modifyItems = self.modifyItems
return cartCell
}
func tableView(_ tableView: UITableView, viewForHeaderInSection section: Int) -> UIView? {
let cartHeader = tableView.dequeueReusableCell(withIdentifier: "CartHeader") as! CartHeader
let headerTitle = brands[section]
cartHeader.brandName.text = "Brand: \(headerTitle)"
return cartHeader
}
}
class ModifyViewController: UIViewController {
private var counterValue = 1
var lastSelectedWeightButton = RoundButton()
var modifyItems: Cart!
@IBOutlet weak var price1: UILabel!
@IBOutlet weak var price2: UILabel!
@IBOutlet weak var price3: UILabel!
@IBOutlet weak var weight1: UILabel!
@IBOutlet weak var weight2: UILabel!
@IBOutlet weak var weight3: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
let formatter = NumberFormatter()
formatter.maximumFractionDigits = 2
formatter.numberStyle = .decimal
price1.text = "$\(formatter.string(for: modifyItems.cart.price1)!)" // getting the error right here that causes the simulator to close out and prevents me from viewing the modify VC
price2.text = "$\(formatter.string(for: modifyItems.cart.price2)!)"
price3.text = "$\(formatter.string(for: modifyItems.cart.price3)!)"
weight1.text = modifyItems.cart.weight1
weight2.text = modifyItems.cart.weight2
weight3.text = modifyItems.cart.weight3
}
}
旁注:CartVC 单元格数据是从 HomeVc 填充的,当一个项目被选中时,它作为一个单元格发布到 CartVC 中。 Items 类填充 HomeVC 中的单元格。
【问题讨论】:
-
这能回答你的问题吗? Passing Data between View Controllers
-
@Magnas,这个答案不适用于我的解决方案,因为我的大部分数据都是从云 Firestore 中检索的。
标签: ios swift iphone uitableview delegates