我正在尝试将一个原型单元连接到两个不同的segue路径,每个路径都通向另一个视图控制器。我在另一篇帖子中读到,必须从源视图控制器本身到目标视图控制器,而不是原型单元到视图控制器,完成连接segue。
我的源视图控制器名为BuildsViewController,其中填充了tableview单元格。我正在开发一个应用程序,单击单元格将打开目标视图控制器,具体取决于是否在根视图控制器上单击了登录或访客按钮。 (buttonClicked是一个实例变量,用于存储用户在根视图控制器上单击的按钮)。
然而,当我点击BuildsViewController上的单元格时,没有任何反应。我哪里做错了?请注意,登录按钮的标记为0,而访客按钮的标记为1.
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
switch self.buttonClicked?.tag {
case 0?:
performSegue(withIdentifier: "showLogin", sender: self)
break;
case 1?:
performSegue(withIdentifier: "showGuest", sender: self)
break;
default:
preconditionFailure()
}
}
override func prepare (for segue: UIStoryboardSegue, sender: Any?) {
switch segue.identifier {
case "showLogin"?:
if let row = self.tableView.indexPathForSelectedRow?.row {
let build = self.buildStore.allBuilds [row]
let detailBuildsViewController = segue.destination as! BuildDetailViewController
detailBuildsViewController.build = build
break;
}
case "showGuest"?:
if let row = self.tableView.indexPathForSelectedRow?.row {
let build = self.buildStore.allBuilds [row]
let detailBuildsViewControllerGuest = segue.destination as! BuildDetailViewControllerGuest
detailBuildsViewControllerGuest.build = build
break;
}
default:
preconditionFailure("Unexpected segue identifier")
}
}
override func tableView (_ tableView: UITableView,
cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "UITableViewCell", for: indexPath)
let build = buildStore.allBuilds [indexPath.row]
cell.textLabel?.text = build.name
return cell
}
谢谢!
答案 0 :(得分:0)
Swift 3修改了didSelectRowAtIndexPath方法的签名。您需要在方法名称中添加覆盖以覆盖超类方法。
替换:
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath)
带
override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath)