스유에서는 List 유킷에서는 TableView가 있는데 개인적인 생각으로 정~~말 많이 사용하는 거 같음
근데 맨날천날 까먹어서 한번 정리해 보도록 하겠습니다!! (사실 잘 몰라서 공부하면서 계속 추가할꺼임)
기본
- 여러 Cell을 이용해 하나의 열, 다수의 행을 이용해 수직 스크롤 테이블을 만듬
- 섹션으로 행을 그룹화하여 콘텐츠를 묶을 수 있음 (아이폰의 설정앱 마냥)
- 섹션에는 header와 footer를 붙혀 추가 정보를 표현할 수 있음
Delegate, DataSource
- DataSource는 데이터를 받아 View를 그려줌
- Delegate는 테이블 뷰 동작과 외관을 담당함 .
- View가 변경되는 사항을 Delegate가 담당하고 View는 Delegate를 의존해 업데이트함.
- DataSource는 총 섹션 개수, 섹션 행에 어떤 정보를 표시할지 등 결정이 가능.
- Delegate는 행의 높이 선택 시 액션 등을 결정 가능함
DataSource
- UITableViewDataSource
- TableView를 생성하고 수정하는데 필요한 정보를 TableView 객체에 제공
- numberOfRowInSection - 각 세션에 표시할 행의 개수를 묻는 메서드 (필수)
- cellForRowAt - 특정 인덱스 Row의 Cell에 대한 정보를 넣어 Cell을 반환하는 메서드 (필수)
- numberOfSections - 총 섹션의 개수를 묻는 메서드
- titleForHeaderInSection - 특정 세션의 Header 타이틀을 묻는 메서드
- titleForFooterInSection - 특정 세션의 Footer 타이틀을 묻는 메서드
- canEditRowAt - 특정 위치의 행이 편집이 가능한지 묻는 메서드
- canMoveRowAt - 특정 위치의 행을 재정렬할 수 있는지 묻는 메서드
- sectionIndexTitles - Table view 섹션 인덱스 타이틀을 묻는 메서드
- sectionForSectionIndexTitle - 인덱스에 해당하는 섹션을 알려주는 메서드
- commitforRowAt - 스와이프모드, 편집 모드에서 버튼을 선택하면 호출되는 메서드
- moveRowAt - 행이 다른 위치로 이동되면 어디에서 어디로 이동했는지 알려주는 메서드
Delegate
- UITableViewDelegate
- TableView의 시각적인 부분을 설정, 행의 액션 관리, 액세서리 뷰 지원, 테이블 뷰의 개별 행 편집을 도움
- 필수 구현해야 할 메서드는 없음
- didSelectRowAt - 행이 선택되었을 때 호출되는 메서드
- didDeselectRowAt - 행이 선택 해제되었을 때 호출되는 메서드
- heightForRowAt - 특정 위치 행의 높이를 묻는 메서드
- viewForHeaderInSection - 지정된 섹션의 Header 뷰에 표시한 View가 어떤 건지 묻는 메서드
- viewForFooterInSection - 지정된 섹션의 Footer 뷰에 표시한 View가 어떤 건지 묻는 메서드
- heightForHeaderinSection - 지정된 섹션의 Header 뷰의 높이를 묻는 메서드
- heightForFooterInSection- 지정된 섹션의 Footer 뷰의 높이를 묻는 메서드
- willBeginEditingRowAt - 테이블 뷰가 편집 모드에 들어갔을 때 호출되는 메서드
- didEndEditingRowAt - ??????
- willDisplay - 테이블 뷰가 셀을 사용하여 행을 그리기 직전에 호출되는 메서드
- didEndDisplaying - 테이블 뷰로부터 셀이 화면에 사라지면 호출되는 메서드
TableView 란
Data Source와 TableView를 연동하는 과정은 UITableViewDataSource 라는 프로토콜에 의존함.
위의 프로토콜을 참고해 메소드 호출 → 데이터 소스와 테이블 뷰를 연동함.
- 테이블뷰에 데이터 소스를 연동할 때에는 다음과 같은 내용이 필요하다.
- 테이블이 몇 개의 행으로 구성되는지
- 각 행의 내용은 어떻게 구성되는지
필요한 기본 메소드는 다음과 같음.
tableView(_:numberOfRowsInSection:)
tableView(_:cellForRowAt:)
tableView(_:numberOfRowsInSection:)
이 메소드는 테이블 뷰가 생성할 Row의 개수를 반환함.
테이블 뷰를 구성하기 위해 필수적이다.
→ 몇 개의 행을 생성해야 할지 개발자가 시스템에 알려줌
사용되는 파라미터로는 1. 테이블 뷰 객체 정보 2. 섹션 정보가 있다.
override func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 테이블 뷰의 목록 길이
}
- 테이블 뷰 객체 정보
- 이 메소드를 호출한 테이블 뷰 객체에 대한 정보
- 만약 테이블 뷰가 여러개일 경우 구분하기 위해서
- 섹션 정보
- 섹션에 대한 정보
tableView(_:cellForRowAt:)
각 행이 화면에 표현해야 할 내용을 구성.
반환값은 전체 테이블 뷰 목록이 아닌 개별적인 테이블 셀 객체이다.
이는 화면에 표현해야 할 목록의 수만큼 이 메소드가 반복 호출된다는 의미.
override func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
return 테이블 뷰 셀 인스턴스
}
- 구성할 테이블 뷰 객체에 대한 참조
- 구성할 행에 대한 참조 정보
- indexPath를 통해 몇 번째 행을 구성하기 위한 호출인지 구분 가능
tableView(_:didSelectRowAt:)
- UITableViewDelegate 에 정의되어 있으며, 사용자가 특정 행을 선택했을 때 호출
- 사용자가 선택한 내용에 맞는 액션을 처리하는 용도임!!!!!
- 행 선택 시 액션이 필요할 경우 이 메소드 내부에 로직 구성
override func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
}
- 사용자가 터치한 테이블 뷰에 대한 참조값
- 터치된 행에 대한 정보
- 이러한 인자를 통해 어느 테이블의 몇 번째 행을 선택했는지 확인
Reusable Queue
- 테이블 뷰 셀 객체 생성 시 필요한 방법
- 셀 객체를 직접 생성할 수도 있지만 메소드로 생성시 사용되는 메소드가 바로 다음임.
- dequeueReusableCell(withIdentifier:)
- 인자값으로 입력받은 아이디로 스토리보드에 정의된 셀을 찾은 후, 인스턴스로 생성
- 스토리 보드의 셀에 설정한 Identifier 속성으로 셀을 식별함
- 여기서 재사용 큐는 셀 인스턴스가 한차례 사용된 후에도 재사용을 위해 대기하는 공간임.
- 위 메소드에서 입력된 id의 큐가 있을 경우 재사용, 없으면 새로 생성하는 방식으로 동작
iOS Study (Chapter 8 - 테이블 뷰와 데이터 소스 연동)
iOS Study (Chapter 8 - 테이블 뷰와 데이터 소스 연동)
이 포스트는 꼼꼼한 재은씨의 스위프트 기본편을 보고 스스로 공부한 내용을 정리한 포스트 입니다.
vincentgeranium.github.io
[iOS/Swift] TableView | Delegate, DataSource 메서드 정리
[iOS/Swift] TableView | Delegate, DataSource 메서드 정리
모든 내용은 FastCampus “30개 프로젝트로 배우는 iOS 앱 개발 with Swift 초격차 패키지 Online.” 강의에서 알려준 내용입니다. TableView 구현을 다루는 문서가 아닌 TableView에서 가능한 메서드들을 정리
jiwift.tistory.com
UITableView | Apple Developer Documentation
UITableView | Apple Developer Documentation
A view that presents data using rows in a single column.
developer.apple.com
[UIKit] UITableView 기초부터 다시 살펴보기
[UIKit] UITableView 기초부터 다시 살펴보기
안녕하세요 이누입니다. UITableView, UICollectionView 둘다 상황에 따라 많이 사용하는 View죠. 그런데 저는 지금까지 프로젝트에서 적용하기에만 급급해서인지 사용과정 및 원리가 머릿속에서 정리되
inuplace.tistory.com
'iOS > UIKit' 카테고리의 다른 글
UIKit Delegate 패턴 뿌수다 부서지기... (1) | 2023.11.01 |
---|---|
[Swift] Singleton Pattern (1) | 2023.08.15 |
UIKit ViewController Lifecycle (1) | 2023.07.23 |