Ниже приведен мой код, в котором я загружаю больше контента сверху вниз.Когда я дохожу до последней страницы и снова нажимаю, она продолжает вызывать fetchMessagesКак остановить этот код, показывающий загрузку дополнительных ячеек и прекращение выборки большего количества данных при достижении предела страницы?
class ViewController: UIViewController {
@IBOutlet weak var messagesTable: UITableView!
private var messageArray: [String] = []
let pageSize: Int = 20
let totalPages: Int = 3
var currentPage: Int = 0
var isLoading: Bool = false
var hasMore: Bool = true
private func loadMoreMessages() {
if self.isLoading {
return
}
if self.currentPage < 1 {
self.loadMessagesFirstTime()
return
}
self.isLoading = true
fetchMessages(page: self.currentPage + 1) { (messages) in
if messages.count > 0 {
for message in messages {
self.messageArray.insert(message, at: 0)
}
self.messagesTable.reloadData()
let lastIndexPath = IndexPath(row: messages.count - 1, section: 0)
self.messagesTable.scrollToRow(at: lastIndexPath, at: UITableViewScrollPosition.top, animated: false)
self.currentPage += 1
} else {
self.hasMore = false
self.messagesTable.reloadData()
}
self.isLoading = false
}
}
private func loadMessagesFirstTime() {
print("loadMesagesFirstTime")
self.isLoading = true
self.hasMore = true
self.currentPage = 1
fetchMessages(page: 1) { (messages) in
self.messageArray.removeAll()
if messages.count > 0 {
self.messageArray.append(contentsOf: messages.reversed())
self.messagesTable.reloadData()
let lastIndexPath = IndexPath(row: self.messagesTable.numberOfRows(inSection: 0) - 1, section: 0)
self.messagesTable.scrollToRow(at: lastIndexPath, at: UITableViewScrollPosition.bottom, animated: false)
} else {
self.hasMore = false
self.messagesTable.reloadData()
}
self.isLoading = false
}
}
}
extension ViewController {
func fetchMessages(page: Int, completed: @escaping ([String]) -> Swift.Void) {
print("fetchMessages, page: \(page)")
DispatchQueue.global().async {
sleep(1)
DispatchQueue.main.async {
var messages: [String] = []
if page <= self.totalPages {
for index in 0..<self.pageSize {
messages.append("Row \((page-1) * self.pageSize + index)")
}
}
completed(messages)
}
}
}
}
extension ViewController: UITableViewDataSource, UITableViewDelegate {
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
if self.hasMore {
return self.messageArray.count + 1
} else {
return self.messageArray.count
}
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
var row = indexPath.row
if self.hasMore {
if row == 0 {
let reusableIdentifier = "LoadingCell"
let cell = tableView.dequeueReusableCell(withIdentifier: reusableIdentifier) ??
UITableViewCell(style: UITableViewCellStyle.default, reuseIdentifier: reusableIdentifier)
cell.textLabel?.text = "Loading ..."
return cell
}
row -= 1
}
let reusableIdentifier = "MessageTableViewCell"
let cell = tableView.dequeueReusableCell(withIdentifier: reusableIdentifier) ??
UITableViewCell(style: UITableViewCellStyle.default, reuseIdentifier: reusableIdentifier)
cell.textLabel?.text = self.messageArray[row]
return cell
}
func tableView(_ tableView: UITableView, willDisplay cell: UITableViewCell, forRowAt indexPath: IndexPath) {
if indexPath.row == 0 {
loadMoreMessages()
}
}
}
Вывод:
loadMesagesFirstTime
fetchMessages, page: 1
fetchMessages, страница: 2
fetchMessages, страница: 3
fetchMessages, страница: 4 <== это не должно вызываться, поскольку мы достигли предела страницы. </p>
fetchMessages, страница: 4
fetchMessages, страница: 4
fetchMessages, страница: 4
fetchMessages, страница: 4