iOS 효율 적 인 페이지 로 딩 구현 예제
1.tableview 의 페이지 별로 불 러 오 는 코드 비교
최적화 되 지 않 은 이전 코드 는 다음 과 같 습 니 다.
[strongSelf.tableView.mj_footer endRefreshing];
[strongSelf.articleArr addObjectsFromArray:feedList];
[strongSelf.tableView reloadData];
최적화 후의 코드 는 다음 과 같다.
NSMutableArray *indexPaths = [NSMutableArray array];
[feedList enumerateObjectsUsingBlock:^(id obj, NSUInteger idx, BOOL *stop) {
NSIndexPath *indexPath = [NSIndexPath indexPathForRow:(strongSelf.articleArr.count + idx) inSection:0];
[indexPaths addObject:indexPath];
}];
[strongSelf.tableView.mj_footer endRefreshing];
[strongSelf.articleArr addObjectsFromArray:feedList];
[strongSelf.tableView beginUpdates];
[strongSelf.tableView insertRowsAtIndexPaths:indexPaths withRowAnimation:UITableViewRowAnimationNone];
[strongSelf.tableView endUpdates];
2.collectonview 의 페이지 별로 불 러 오 는 코드 비교최적화 되 지 않 은 이전 코드 는 다음 과 같 습 니 다.
[strongSelf.feedList addObjectsFromArray:feedList];
if (feedList.count < kPageSize) {
[strongSelf.collectionView.mj_footer endRefreshingWithNoMoreData];
}else{
[strongSelf.collectionView.mj_footer resetNoMoreData];
}
[strongSelf.collectionView reloadData];
최적화 후의 코드 는 다음 과 같다.
NSMutableArray *indexPaths = [NSMutableArray array];
[feedList enumerateObjectsUsingBlock:^(id _Nonnull obj, NSUInteger idx, BOOL * _Nonnull stop) {
[indexPaths addObject:[NSIndexPath indexPathForItem:(strongSelf.feedList.count + idx) inSection:0]];
}];
[strongSelf.feedList addObjectsFromArray:feedList];
if (feedList.count < kPageSize) {
[strongSelf.collectionView.mj_footer endRefreshingWithNoMoreData];
}else{
[strongSelf.collectionView.mj_footer resetNoMoreData];
}
[strongSelf.collectionView insertItemsAtIndexPaths:indexPaths];
결론:비교 해 보면 최적화 한 후에 코드 량 이 약간 증가 한 것 처럼 보이 지만 이론 적 으로 페이지 를 나 누 어 로드 하 는 성능 이 더욱 좋다.이전 페이지 로 딩 에 사 용 된 전역 새로 고침 을 최적화 한 후 부분 새로 고침 으로 바 꾸 었 습 니 다.성능 이 향상 된다.이상 이 바로 본 고의 모든 내용 입 니 다.여러분 의 학습 에 도움 이 되 고 저 희 를 많이 응원 해 주 셨 으 면 좋 겠 습 니 다.
이 내용에 흥미가 있습니까?
현재 기사가 여러분의 문제를 해결하지 못하는 경우 AI 엔진은 머신러닝 분석(스마트 모델이 방금 만들어져 부정확한 경우가 있을 수 있음)을 통해 가장 유사한 기사를 추천합니다:
View의 레이아웃 방법을 AutoLayout에서 따뜻한 손 계산으로 하면 성능이 9.26배로 된 이야기이 기사는 의 15 일째 기사입니다. 어제는 에서 이었습니다. 손 계산을 권하는 의도는 없고, 특수한 상황하에서 계측한 내용입니다 화면 높이의 10 배 정도의 contentView가있는 UIScrollView 레이아...
텍스트를 자유롭게 공유하거나 복사할 수 있습니다.하지만 이 문서의 URL은 참조 URL로 남겨 두십시오.
CC BY-SA 2.5, CC BY-SA 3.0 및 CC BY-SA 4.0에 따라 라이센스가 부여됩니다.