我有一个带有 UISegmentedControl 的 UIViewController ,当我点击 UITableViewController code>segmentedControl 段。我遇到的问题是当我点击一个片段时,弹出框开始加载,但在加载 myPopoverTableViewController 时崩溃。它崩溃了
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell ,说我的PopoverTableViewCell 的属性是nil .
为简单起见,我将在此处引用我的类:
myViewController: MyViewController
myPopoverTVController: PopoverTableViewController
myPopoverTVCell: PopoverTableViewCell
在 lldb 中,我检查了单元格的值 dataSource ,似乎唯一为零的是 myPopoverTVCell ,我在 myPopoverTVController 的 viewWillAppear 中注册了以下行:
tableView.register(PopoverTableViewCell.self, forCellReuseIdentifier: "cell")
myPopoverTVController 没有通过 popover segue(尽管我已经尝试过)连接到 myViewController 。我检查了 myPopoverTVController's 原型(prototype)单元的类中是否引用了 PopoverTableViewCell 。我已经仔细检查了从单元到 PopoverTableViewCell 类的连接。我检查了我已在 Storyboard 上将 Table View Cell 的标识符设置为 cell 。
下面是我如何从 myViewController 开始弹出窗口,跟在 Apple's code 之后:
@IBAction func segmentedControlAction(_ sender: UISegmentedControl) {
// instantiate the PopoverTableViewController
let popoverTVC = PopoverTableViewController()
// set variables on it
popoverTVC.selectedSegmentIndex = sender.selectedSegmentIndex
popoverTVC.currentRegion = currentRegion
// disignate presentation style as a popover
popoverTVC.modalPresentationStyle = .popover
present(popoverTVC, animated: true, completion: nil)
let presentationController = UIPopoverPresentationController(presentedViewController: popoverTVC, presenting: self)
presentationController.permittedArrowDirections = .up
presentationController.sourceView = view
presentationController.sourceRect = segmentedControl.frame
}
在 myPopoverTVController 上,这是我的 cellForRowAt indexPath 的样子:
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
// let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! PopoverTableViewCell
let cell = tableView.dequeueReusableCell(withIdentifier: "cell") as! PopoverTableViewCell
// Configure the cell...
switch selectedSegmentIndex {
case 0, 1:
cell.areaLabel.text = popoverStringArray[indexPath.row]
case 2:
let countryList = locationManager.countryList
let countryCodes = locationManager.countryCodes
cell.areaLabel?.text = countryList[indexPath.row]
cell.flagLabel?.text = countryCodes[indexPath.row]
default:
break
}
return cell
}
我检查了在 myViewController 上实例化时设置的变量,它们都有值。只是 tableViewCell 属性是 nil --当我键入 po cell 时,lldb 返回单元格的内存地址>。我已经设置了 UITableViews 一百万次,但我无法弄清楚这件事。任何建议:非常感谢我做错了什么。我会放心,我的问题是我的一个令人吃惊的愚蠢遗漏。感谢您的阅读。
Best Answer-推荐答案 strong>
我放弃了尝试使用 Apple 的代码,并想出了一种替代方法来让弹出框工作。
我在 Storyboard 中 ctrl+dragged 从我的 myViewController 到 myPopoverTVController 。我将 segue identifier 设置为 popoverSegue 并将其设置为显示为弹出框。我还指定了一个 anchor 。
从那里,我删除了 segmentedControlAction() 中的代码,将其替换为以下内容:
@IBAction func segmentedControlAction(_ sender: UISegmentedControl) {
self.performSegue(withIdentifier: "popoverSegue", sender: segmentedControl.selectedSegmentIndex)
}
我在 myViewController 上的 prepareForSegue 中添加了以下代码:
override func prepare(for segue: UIStoryboardSegue, sender: Any?) {
if segue.identifier == "popoverSegue" {
let destinationViewController = segue.destination as! PopoverTableViewController
destinationViewController.selectedSegmentIndex = sender as! Int
destinationViewController.currentRegion = currentRegion
let popoverController = destinationViewController.popoverPresentationController
if popoverController != nil {
popoverController?.delegate = self
}
}
}
我还向 myViewController 添加了一个委托(delegate)方法,并带有扩展名:
extension MyViewController: UIPopoverPresentationControllerDelegate {
func adaptivePresentationStyle(for controller: UIPresentationController) -> UIModalPresentationStyle {
return .none
}
}
最后,我在 myPopoverTVController 中取出了对数据源的本地引用,所以它现在看起来像这样:
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) as! PopoverTableViewCell
// Configure the cell...
switch selectedSegmentIndex {
case 0:
cell.areaLabel.text = locationManager.cityList(geographicRegion: currentRegion!)[indexPath.row]
cell.flagLabel.isHidden = true
case 1:
cell.areaLabel.text = locationManager.stateList(geographicRegion: currentRegion!)[indexPath.row]
cell.flagLabel.isHidden = true
case 2:
cell.areaLabel?.text = locationManager.countryList[indexPath.row]
cell.flagLabel?.text = locationManager.countryCodes[indexPath.row].flag()
default:
break
}
return cell
}
...它奏效了。
结束 ;)
关于ios - 将 UITableView 实例化为弹出框时,UITableViewCell 的属性为零,我们在Stack Overflow上找到一个类似的问题:
https://stackoverflow.com/questions/40918663/
|