您好我正在尝试将以下目标C代码转换为swift,以便在单击按钮时从一个视图控制器导航到另一个视图控制器。任何帮助将不胜感激
这取自苹果的编程指南
- (void)add:(id)sender {
// Create the root view controller for the navigation controller
// The new view controller configures a Cancel and Done button for the
// navigation bar.
RecipeAddViewController *addController = [[RecipeAddViewController alloc]
init];
// Configure the RecipeAddViewController. In this case, it reports any
// changes to a custom delegate object.
addController.delegate = self;
// Create the navigation controller and present it.
UINavigationController *navigationController = [[UINavigationController alloc]
initWithRootViewController:addController];
[self presentViewController:navigationController animated:YES completion: nil];
}
我的代码如下所示,但不确定如何在导航控制器中实现,在故事板中我的mainSectionViewController嵌入了导航控制器
func sectionBtnClicked (sender: UIButton!) {
let sectionController = self.storyboard?.instantiateViewControllerWithIdentifier("mainSectionsVC") as mainSectionViewController
let navController = UINavigationcontroler. ///not sure what actually comes here, any help would be appreciated
self.presentViewController(navController, animated: true, completion: nil)
}
答案 0 :(得分:18)
你想以模态方式呈现navController吗?
如果是,这就是答案
self.presentViewController(navController, animated: true, completion: nil)
“self”是将呈现navController的当前视图控制器
就这样说,
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
var theButton = UIButton()
// Add the event to button
theButton.addTarget(self, action: "buttonTouchInside:", forControlEvents: .TouchUpInside)
self.view.addSubview(theButton)
}
func buttonTouchInside(sender:UIButton!)
{
// When the button is touched, we're going to present the view controller
// 1. Wrap your view controller within the navigation controller
let navController = UINavigationController(rootViewController: yourViewController)
// 2. Present the navigation controller
self.presentViewController(navController, animated: true, completion: nil)
}
}
但是,
如果要在navigationController中的viewController之间导航,可以使用
self.navigationController.pushViewController(viewControllerToPush, animated: true)
答案 1 :(得分:14)
我做了一个简单的解决方案。这是......
func actioncall () {
let loginPageView = self.storyboard?.instantiateViewControllerWithIdentifier("LoginPageID") as! ViewController
self.presentViewController(loginPageView, animated: true, completion: nil)
}