Notice
Recent Posts
Recent Comments
Link
일 | 월 | 화 | 수 | 목 | 금 | 토 |
---|---|---|---|---|---|---|
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 |
Tags
- SWIFT
- ios
- swiftUI
- 리펙터링
- 스위프트
- collectionview
- uiscrollview
- Refactoring
- 애니메이션
- Protocol
- uitableview
- ribs
- MVVM
- HIG
- 클린 코드
- 리팩토링
- Xcode
- Clean Code
- tableView
- swift documentation
- clean architecture
- UITextView
- RxCocoa
- UICollectionView
- Observable
- combine
- 리펙토링
- map
- Human interface guide
- rxswift
Archives
- Today
- Total
김종권의 iOS 앱 개발 알아가기
[iOS - swift] UITableView 데이터 추가 할 때 reloadData대신 insertRows 사용하기 본문
iOS 응용 (swift)
[iOS - swift] UITableView 데이터 추가 할 때 reloadData대신 insertRows 사용하기
jake-kim 2024. 7. 31. 01:16UITableView 데이터 추가하기
- UITableView에서 스크롤하면서 동시에 아래에 데이터를 계속해서 추가해주어야하는 페이지네이션 UI가 존재
- 페이지네이션 UI 구현 방법은 이전 포스팅 글 참고
- ex) 페이징 관련 코드
- 마지막 셀이 보여질 때 로딩 뷰, footerView를 추가하고 아이템을 로드하고난 후에 다시 footerView를 제거한 다음 reloadData()호출
extension ViewController: UITableViewDelegate {
func tableView(
_ tableView: UITableView,
willDisplay cell: UITableViewCell,
forRowAt indexPath: IndexPath
) {
let isLastCursor = indexPath.row == dataSource.count - 1
guard isLastCursor else { return }
tableView.tableFooterView = FooterView(frame: .init(x: 0, y: 0, width: 0, height: 72))
loadMoreItem {
tableView.tableFooterView = nil
tableView.reloadData()
}
}
private func loadMoreItem(completion: @escaping () -> ()) {
DispatchQueue.main.asyncAfter(deadline: .now() + 1) {
let curCount = self.dataSource.count
self.dataSource.append(contentsOf: (1+curCount...10+curCount).map(String.init))
completion()
}
}
}
- 데이터가 수정된 후 UI에 반영할 때 보통 reloadData를 호출하여 cellForRowAt 델리게이트 메소드가 불리게하여 셀을 업데이트하지만, reloadData를 사용하면 애니메이션이 없는 단점이 존재
- 때문에 데이터를 단순히 추가할때는 reloadData보단 performBatch와 insertRows를 사용할 것
- *단, performBatchUpdates가 여러곳에서 insertRows, deleteRows가 거의 동시에 일어나는 이벤트가 있으면 불안정하기에 복잡한 상황에서는 지양할 것
loadMoreItem { indexPaths in
tableView.performBatchUpdates {
tableView.insertRows(at: indexPaths, with: .fade)
}
tableView.tableFooterView = nil
}
적용)
'iOS 응용 (swift)' 카테고리의 다른 글
Comments