티스토리 뷰
학원 과제로 plist 파일로 저장한 BTS 멤버의 목록을 TableView 에 불러오고 멤버를 추가하는 기능을 완성하고있다.
storyboard 기반 개발을 많이 안해봐서 이왕 연습하는거 잔뜩해보자! 하는 마음으로 하고있는데
문득 performSegue 메서드의 sender 가 Any? 타입인데 왜 nil 을 보내면 안되는지 궁금해졌다.
만능 GPT4.0 선생님께 즉시 질문
🤖
performSegue(withIdentifier:sender:) 메서드에서 sender 파라미터는 세그웨이를 트리거하는 객체를 참조합니다.
이 파라미터는 세그웨이가 시작된 위치를 식별하는 데 사용되며, 주로 어떤 UI 요소(예: 버튼, 셀 등)가 세그웨이를 트리거했는지를 알려주는 데 사용됩니다. 이 정보는 prepare(for:sender:) 메서드 내에서 다운캐스팅을 통해 해당 객체에 접근하거나 추가적인 정보를 얻는 데 사용될 수 있습니다. sender: self를 사용하는 경우, 이는 세그웨이를 트리거하는 객체가 현재의 뷰 컨트롤러(self)임을 나타냅니다. 이는 prepare(for:sender:) 메서드에서 sender 파라미터를 통해 현재 뷰 컨트롤러에 대한 참조를 얻을 수 있음을 의미합니다.
만약 sender 파라미터를 nil로 설정한다면, 세그웨이를 트리거하는 객체에 대한 정보가 없음을 의미합니다. 이 경우에도 세그웨이는 정상적으로 실행되지만, prepare(for:sender:) 메서드 내에서 sender를 통해 특정 객체에 접근하려 할 때 그 객체를 식별할 수 없습니다.
즉, sender를 nil로 설정해도 세그웨이 자체의 동작에는 지장이 없으나, 특정 객체를 기반으로 추가 작업을 수행하고자 할 때는 sender를 적절히 설정해 주는 것이 좋습니다.
요약하자면, sender: self는 세그웨이를 트리거하는 객체가 현재 뷰 컨트롤러임을 명시하는 것이며, 이를 통해 prepare(for:sender:) 메서드에서 현재 뷰 컨트롤러에 접근할 수 있는 기회를 제공합니다. sender를 nil로 설정해도 세그웨이는 실행되지만, 특정 객체에 기반한 추가적인 처리를 할 수 없게 됩니다.
캡쳐본
'Apple > iOS' 카테고리의 다른 글
[SwiftUI] .shadow 보라색 오류 해결하기 : overlay? drawingGroup? 🙄 (1) | 2024.07.20 |
---|---|
[Swift/iOS] UITableViewCell 4가지 Style 살펴보기 (0) | 2024.03.14 |
공지사항
최근에 올라온 글
최근에 달린 댓글
- Total
- Today
- Yesterday
링크
TAG
- jsonkey
- ios
- 오블완
- SWIFT
- llm 설치
- flutter
- swiftmigration
- 플러터
- 티스토리챌린지
- sliver
- tojson()
- sliverlist
- flutter updates
- flutter_lints
- 플러터 업데이트
- flutter 3.7
- 플러터네이티브
- 다트문법
- jsonserializable
- analysis_options
- slivers
- 렌더링최적화
- 오블완챌린지
- 플러터ios애니메이션
- flutter3.7
- fromjson()
- 개발신입
- lints
- 낙관적 업데이트 패턴
- 플러터업데이트
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
1 | 2 | 3 | 4 | 5 | ||
6 | 7 | 8 | 9 | 10 | 11 | 12 |
13 | 14 | 15 | 16 | 17 | 18 | 19 |
20 | 21 | 22 | 23 | 24 | 25 | 26 |
27 | 28 | 29 | 30 | 31 |
글 보관함