Прокрутка табличного представления для загрузки сверху не прекращает загрузку после достижения лимита страниц - PullRequest
0 голосов
/ 23 декабря 2018

Ниже приведен мой код, в котором я загружаю больше контента сверху вниз.Когда я дохожу до последней страницы и снова нажимаю, она продолжает вызывать 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

1 Ответ

0 голосов
/ 23 декабря 2018

Попробуйте это:

if page < self.totalPages
...