Switch another navigation programmatically swift
I ignore storyboard and create UINavigationController
in AppDelegate.swift
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
window = UIWindow(frame: UIScreen.main.bounds)
window?.makeKeyAndVisible()
let layout = UICollectionViewFlowLayout()
layout.scrollDirection = .horizontal
window?.rootViewController = UINavigationController(rootViewController: HomeController(collectionViewLayout: layout))//make the ViewController class to be the root
return true
}
I have leftBarButton
which switches to another UINavigationController
or UICollectionViewController
(according to your advice)
override func viewDidLoad() {
super.viewDidLoad()
let parentMenuButton = UIButton(frame: CGRect(x: 0, y: 0, width: 34, height: 34))
parentMenuButton.addTarget(self, action: #selector(self.menuButtonOnClicked), for: .touchUpInside)
navigationItem.leftBarButtonItem = UIBarButtonItem(customView: parentMenuButton)
}
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
}
How can I achieve this programmatically?(switch another navigation area by pressing menu button)
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewController(withIdentifier: "SecondViewController") as! SecondViewController
self.navigationController!.pushViewController(secondViewController, animated: true)
Error:
Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'Storyboard () doesn't contain a view controller with identifier 'SecondViewController''
I create SecondViewController:
import UIKit
class SecondViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
}
}
Is there a way to do it without messing with storyboard?(only programatically)
ios swift uinavigationcontroller
add a comment |
I ignore storyboard and create UINavigationController
in AppDelegate.swift
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
window = UIWindow(frame: UIScreen.main.bounds)
window?.makeKeyAndVisible()
let layout = UICollectionViewFlowLayout()
layout.scrollDirection = .horizontal
window?.rootViewController = UINavigationController(rootViewController: HomeController(collectionViewLayout: layout))//make the ViewController class to be the root
return true
}
I have leftBarButton
which switches to another UINavigationController
or UICollectionViewController
(according to your advice)
override func viewDidLoad() {
super.viewDidLoad()
let parentMenuButton = UIButton(frame: CGRect(x: 0, y: 0, width: 34, height: 34))
parentMenuButton.addTarget(self, action: #selector(self.menuButtonOnClicked), for: .touchUpInside)
navigationItem.leftBarButtonItem = UIBarButtonItem(customView: parentMenuButton)
}
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
}
How can I achieve this programmatically?(switch another navigation area by pressing menu button)
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewController(withIdentifier: "SecondViewController") as! SecondViewController
self.navigationController!.pushViewController(secondViewController, animated: true)
Error:
Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'Storyboard () doesn't contain a view controller with identifier 'SecondViewController''
I create SecondViewController:
import UIKit
class SecondViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
}
}
Is there a way to do it without messing with storyboard?(only programatically)
ios swift uinavigationcontroller
add a comment |
I ignore storyboard and create UINavigationController
in AppDelegate.swift
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
window = UIWindow(frame: UIScreen.main.bounds)
window?.makeKeyAndVisible()
let layout = UICollectionViewFlowLayout()
layout.scrollDirection = .horizontal
window?.rootViewController = UINavigationController(rootViewController: HomeController(collectionViewLayout: layout))//make the ViewController class to be the root
return true
}
I have leftBarButton
which switches to another UINavigationController
or UICollectionViewController
(according to your advice)
override func viewDidLoad() {
super.viewDidLoad()
let parentMenuButton = UIButton(frame: CGRect(x: 0, y: 0, width: 34, height: 34))
parentMenuButton.addTarget(self, action: #selector(self.menuButtonOnClicked), for: .touchUpInside)
navigationItem.leftBarButtonItem = UIBarButtonItem(customView: parentMenuButton)
}
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
}
How can I achieve this programmatically?(switch another navigation area by pressing menu button)
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewController(withIdentifier: "SecondViewController") as! SecondViewController
self.navigationController!.pushViewController(secondViewController, animated: true)
Error:
Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'Storyboard () doesn't contain a view controller with identifier 'SecondViewController''
I create SecondViewController:
import UIKit
class SecondViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
}
}
Is there a way to do it without messing with storyboard?(only programatically)
ios swift uinavigationcontroller
I ignore storyboard and create UINavigationController
in AppDelegate.swift
func application(_ application: UIApplication, didFinishLaunchingWithOptions launchOptions: [UIApplication.LaunchOptionsKey: Any]?) -> Bool {
// Override point for customization after application launch.
window = UIWindow(frame: UIScreen.main.bounds)
window?.makeKeyAndVisible()
let layout = UICollectionViewFlowLayout()
layout.scrollDirection = .horizontal
window?.rootViewController = UINavigationController(rootViewController: HomeController(collectionViewLayout: layout))//make the ViewController class to be the root
return true
}
I have leftBarButton
which switches to another UINavigationController
or UICollectionViewController
(according to your advice)
override func viewDidLoad() {
super.viewDidLoad()
let parentMenuButton = UIButton(frame: CGRect(x: 0, y: 0, width: 34, height: 34))
parentMenuButton.addTarget(self, action: #selector(self.menuButtonOnClicked), for: .touchUpInside)
navigationItem.leftBarButtonItem = UIBarButtonItem(customView: parentMenuButton)
}
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
}
How can I achieve this programmatically?(switch another navigation area by pressing menu button)
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewController(withIdentifier: "SecondViewController") as! SecondViewController
self.navigationController!.pushViewController(secondViewController, animated: true)
Error:
Terminating app due to uncaught exception 'NSInvalidArgumentException', reason: 'Storyboard () doesn't contain a view controller with identifier 'SecondViewController''
I create SecondViewController:
import UIKit
class SecondViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view.
}
}
Is there a way to do it without messing with storyboard?(only programatically)
ios swift uinavigationcontroller
ios swift uinavigationcontroller
edited Nov 23 '18 at 14:07
asked Nov 23 '18 at 13:39
Qwe Qwe
438
438
add a comment |
add a comment |
1 Answer
1
active
oldest
votes
You need to call push method in your menuButtonOnClicked()
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewControllerWithIdentifier("SecondViewController") as SecondViewController
self.navigationController.pushViewController(secondViewController, animated: true)
}
your code not working according to xcode advice, I change your code to question
– Qwe Qwe
Nov 23 '18 at 13:57
you need to set identifier of your viewController.. check the updated answer just go in your storyboard give the class and storyboard idSecondViewController
– wings
Nov 23 '18 at 14:00
Is there a way to do it without messing with storyboard?(Updated question)
– Qwe Qwe
Nov 23 '18 at 14:07
no you can't :( you need to set it in interface builder
– wings
Nov 23 '18 at 14:09
add a comment |
Your Answer
StackExchange.ifUsing("editor", function () {
StackExchange.using("externalEditor", function () {
StackExchange.using("snippets", function () {
StackExchange.snippets.init();
});
});
}, "code-snippets");
StackExchange.ready(function() {
var channelOptions = {
tags: "".split(" "),
id: "1"
};
initTagRenderer("".split(" "), "".split(" "), channelOptions);
StackExchange.using("externalEditor", function() {
// Have to fire editor after snippets, if snippets enabled
if (StackExchange.settings.snippets.snippetsEnabled) {
StackExchange.using("snippets", function() {
createEditor();
});
}
else {
createEditor();
}
});
function createEditor() {
StackExchange.prepareEditor({
heartbeatType: 'answer',
autoActivateHeartbeat: false,
convertImagesToLinks: true,
noModals: true,
showLowRepImageUploadWarning: true,
reputationToPostImages: 10,
bindNavPrevention: true,
postfix: "",
imageUploader: {
brandingHtml: "Powered by u003ca class="icon-imgur-white" href="https://imgur.com/"u003eu003c/au003e",
contentPolicyHtml: "User contributions licensed under u003ca href="https://creativecommons.org/licenses/by-sa/3.0/"u003ecc by-sa 3.0 with attribution requiredu003c/au003e u003ca href="https://stackoverflow.com/legal/content-policy"u003e(content policy)u003c/au003e",
allowUrls: true
},
onDemand: true,
discardSelector: ".discard-answer"
,immediatelyShowMarkdownHelp:true
});
}
});
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53447780%2fswitch-another-navigation-programmatically-swift%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
1 Answer
1
active
oldest
votes
1 Answer
1
active
oldest
votes
active
oldest
votes
active
oldest
votes
You need to call push method in your menuButtonOnClicked()
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewControllerWithIdentifier("SecondViewController") as SecondViewController
self.navigationController.pushViewController(secondViewController, animated: true)
}
your code not working according to xcode advice, I change your code to question
– Qwe Qwe
Nov 23 '18 at 13:57
you need to set identifier of your viewController.. check the updated answer just go in your storyboard give the class and storyboard idSecondViewController
– wings
Nov 23 '18 at 14:00
Is there a way to do it without messing with storyboard?(Updated question)
– Qwe Qwe
Nov 23 '18 at 14:07
no you can't :( you need to set it in interface builder
– wings
Nov 23 '18 at 14:09
add a comment |
You need to call push method in your menuButtonOnClicked()
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewControllerWithIdentifier("SecondViewController") as SecondViewController
self.navigationController.pushViewController(secondViewController, animated: true)
}
your code not working according to xcode advice, I change your code to question
– Qwe Qwe
Nov 23 '18 at 13:57
you need to set identifier of your viewController.. check the updated answer just go in your storyboard give the class and storyboard idSecondViewController
– wings
Nov 23 '18 at 14:00
Is there a way to do it without messing with storyboard?(Updated question)
– Qwe Qwe
Nov 23 '18 at 14:07
no you can't :( you need to set it in interface builder
– wings
Nov 23 '18 at 14:09
add a comment |
You need to call push method in your menuButtonOnClicked()
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewControllerWithIdentifier("SecondViewController") as SecondViewController
self.navigationController.pushViewController(secondViewController, animated: true)
}
You need to call push method in your menuButtonOnClicked()
@objc func menuButtonOnClicked(){
print("menuButtonOnClicked button is pressed")
let storyboard = UIStoryboard(name: "Main", bundle: nil)
let secondViewController = storyboard.instantiateViewControllerWithIdentifier("SecondViewController") as SecondViewController
self.navigationController.pushViewController(secondViewController, animated: true)
}
edited Nov 23 '18 at 14:02
answered Nov 23 '18 at 13:43
wings
1,042422
1,042422
your code not working according to xcode advice, I change your code to question
– Qwe Qwe
Nov 23 '18 at 13:57
you need to set identifier of your viewController.. check the updated answer just go in your storyboard give the class and storyboard idSecondViewController
– wings
Nov 23 '18 at 14:00
Is there a way to do it without messing with storyboard?(Updated question)
– Qwe Qwe
Nov 23 '18 at 14:07
no you can't :( you need to set it in interface builder
– wings
Nov 23 '18 at 14:09
add a comment |
your code not working according to xcode advice, I change your code to question
– Qwe Qwe
Nov 23 '18 at 13:57
you need to set identifier of your viewController.. check the updated answer just go in your storyboard give the class and storyboard idSecondViewController
– wings
Nov 23 '18 at 14:00
Is there a way to do it without messing with storyboard?(Updated question)
– Qwe Qwe
Nov 23 '18 at 14:07
no you can't :( you need to set it in interface builder
– wings
Nov 23 '18 at 14:09
your code not working according to xcode advice, I change your code to question
– Qwe Qwe
Nov 23 '18 at 13:57
your code not working according to xcode advice, I change your code to question
– Qwe Qwe
Nov 23 '18 at 13:57
you need to set identifier of your viewController.. check the updated answer just go in your storyboard give the class and storyboard id
SecondViewController
– wings
Nov 23 '18 at 14:00
you need to set identifier of your viewController.. check the updated answer just go in your storyboard give the class and storyboard id
SecondViewController
– wings
Nov 23 '18 at 14:00
Is there a way to do it without messing with storyboard?(Updated question)
– Qwe Qwe
Nov 23 '18 at 14:07
Is there a way to do it without messing with storyboard?(Updated question)
– Qwe Qwe
Nov 23 '18 at 14:07
no you can't :( you need to set it in interface builder
– wings
Nov 23 '18 at 14:09
no you can't :( you need to set it in interface builder
– wings
Nov 23 '18 at 14:09
add a comment |
Thanks for contributing an answer to Stack Overflow!
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Some of your past answers have not been well-received, and you're in danger of being blocked from answering.
Please pay close attention to the following guidance:
- Please be sure to answer the question. Provide details and share your research!
But avoid …
- Asking for help, clarification, or responding to other answers.
- Making statements based on opinion; back them up with references or personal experience.
To learn more, see our tips on writing great answers.
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
StackExchange.ready(
function () {
StackExchange.openid.initPostLogin('.new-post-login', 'https%3a%2f%2fstackoverflow.com%2fquestions%2f53447780%2fswitch-another-navigation-programmatically-swift%23new-answer', 'question_page');
}
);
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Sign up or log in
StackExchange.ready(function () {
StackExchange.helpers.onClickDraftSave('#login-link');
});
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Sign up using Google
Sign up using Facebook
Sign up using Email and Password
Post as a guest
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown
Required, but never shown