StoryBoard vs Code
iOS 프로젝트를 처음 그리고 초반에 진행을 할 때는 무조건 스토리보드로 UI를 작성하고 ViewController와 연동하였다.
why?
쉬우니까! 간편하니까! 내가 작성한 것이니 내가 제일 잘 아니 헷갈리지도 않으니까!
BUT!
혹시라도 2명이상과 프로젝트를 진행하게 된다면 스토리보드의 가장 큰 단점이 보인다.
- 하나의 스토리보드로 함께 작업시에 충돌할 가능성이 진부함
- 스토리보드를 나눠서 작업을 해도 굳이 하나의 스토리보드에 들어갈 화면들이 나눠짐 -> 이후에 다시 합쳐야 하는 불편함
- 이후에 다시 합치는 과정에서도 Ctrl+C/V를 하더라도 다시 AutoLayout을 위한 Constraint를 지정해주는 것이 어렵다!
- 물론 정리된 문서가 있으면 금방할 수 있다고 생각했지만, 아니었다...
- 내가 UI Component들에 지정한 이름을 보고 이게 이거였나? 이게 이거였겠지? 하면서 헷갈리는 순간 시간이 굉장히 딜레이됐다.
그래서 이후로는 UI Component들의 이름도... 어떠한 체계로 명확히 작성해야한다는 것을 꺠달았따...
TabBar
목표 : 이처럼 TabBarVC를 가지고 있고 2개의 VC를 삽입하여 간단한 TabBar를 구현하는 것!!
class TabBarViewController: UITabBarController{
override func viewDidLoad() {
super.viewDidLoad()
let profileVC = ProfileViewController()
let vc2 = VC2()
let icon1 = UITabBarItem(title: "프로필", image: UIImage(systemName: "person.circle"), selectedImage: UIImage(systemName: "person.circle"))
let icon2 = UITabBarItem(title: "VC2", image: UIImage(systemName: "person.circle"), selectedImage: UIImage(systemName: "person.circle"))
profileVC.tabBarItem = icon1
vc2.tabBarItem = icon2
let vcArr = [profileVC, vc2]
self.setViewControllers(vcArr, animated: true)
}
}
- TabBarVC라는 ContainerVC에 들어갈 ProfileVC, VC2를 생성한다.
- 각각의 VC들이 TabBar에서 보일 Item을 만든다.
- 2번에 이어서 붙여준다.
- VC들을 TabBarVC의 VC들로 지정한다.
이과정을 진행하면 문제없이 시뮬레이터에서 실행이될 것이다.
보라! 정상적으로 TabBar가 구현되었다!!
응??? 근데 뭔가 이상하다??
스토리보드에 있는 ProfileVC에는 ㅋㅋㅋㅋㅋㅋㅋㅋㅋㅋ라고 적힌 Label이 있는데??
아! ProfileVC에 Outlet으로 가져오면 되겠구나!
class ProfileViewController: UIViewController {
@IBOutlet weak var label: UILabel!
override func viewDidLoad() {
super.viewDidLoad()
self.view.backgroundColor = .white
}
override func viewDidAppear(_ animated: Bool) {
super.viewDidAppear(animated)
self.label.text = "aa"
}
}
하고 실행!
엥? 아직도 안뜨네? 거기다가
Fatal error: Unexpectedly found nil while implicitly unwrapping an Optional value 라는 에러도 나타났다.
이 에러는 타입에 !를 선언해주고 nil에 접근했을 때 나타나는 건데....
스토리보드에서 profileVC와 ProfileViewController를 연결하고 Outlet에 Label을 연결했고! 아무 문제가 없어야하는데 문제가 발생??
해결 방법
guard let profileVC = self.storyboard?.instantiateViewController(withIdentifier: "ProfileVC") else { return }
위 코드처럼 바꿔주면된다.
해석하자면
- self가 존재하는 스토리보드에 있는 VC들 중에 "ProfileVC"라는 ID를 가진 VC를 가져온다.
스토리보드에 UI Component들을 작업하고 그 컴포넌트들을 코드로 생성한 VC에서 사용하고 싶으면 이런 방법을 써야한다.
물론 스토리보드에 UI Component들을 넣지 않고 코드로
let label = UILabel() 로 선언한 후에
text와 constraint들을 지정해 줘도 되지만... 아직까지는 그렇게 익숙하지 않으니 이 방법도 알아보게 되었다.