Swift 4 tableView API分页
我已经成功地解析和解码了JSON数据,它显示在控制台中。我不知道如何使用api设置分页,并在向下滚动tableView时显示所有数据。我使用的API是。提前感谢您的帮助 这是我的主ViewController中的代码Swift 4 tableView API分页,api,uitableview,pagination,swift4,Api,Uitableview,Pagination,Swift4,我已经成功地解析和解码了JSON数据,它显示在控制台中。我不知道如何使用api设置分页,并在向下滚动tableView时显示所有数据。我使用的API是。提前感谢您的帮助 这是我的主ViewController中的代码 import UIKit struct PagedCharacters: Codable { struct Info: Codable { let count: Int let pages: Int let next: St
import UIKit
struct PagedCharacters: Codable {
struct Info: Codable {
let count: Int
let pages: Int
let next: String
let prev: String
}
struct Results: Codable {
let name: String
let status: String
let species: String
}
let info: Info
let results: [Results]
}
class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {
@IBOutlet var uiTableView: UITableView!
override func viewDidLoad() {
super.viewDidLoad()
getRickAndMortyData()
self.uiTableView.dataSource = self
self.uiTableView.delegate = self
// Do any additional setup after loading the view.
}
func getRickAndMortyData() {
//create instance of the url
let url = "https://rickandmortyapi.com/api/character/"
//construct the url, use guard to avoid nonoptional
guard let urlObj = URL(string: url) else
{ return }
//fetch data
URLSession.shared.dataTask(with: urlObj) {(data, response, error) in
//to avoid non optional in JSONDecoder
guard let data = data else { return }
do {
//decode object
let downloadedRickAndMorty = try JSONDecoder().decode(PagedCharacters.self, from: data)
DispatchQueue.main.async {
self.uiTableView.reloadData()
}
print(downloadedRickAndMorty)
} catch {
print(error)
}
}.resume()
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
// #warning Incomplete implementation, return the number of rows
return 0
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
guard let cell = tableView.dequeueReusableCell(withIdentifier: "rickandmortyCell") as? CharacterTableViewCell else { return UITableViewCell() }
cell.nameLabel.text = "Name: " + PagedCharacters.Results[indexPath.row].name
return cell
}
}
这是我的tableviewcell课程
import UIKit
class CharacterTableViewCell: UITableViewCell {
@IBOutlet weak var nameLabel: UILabel!
override func awakeFromNib() {
super.awakeFromNib()
// Initialization code
}
override func setSelected(_ selected: Bool, animated: Bool) {
super.setSelected(selected, animated: animated)
// Configure the view for the selected state
}
}
这是我在控制台中打印解析数据时得到的数据。我仍然没有从不同的页面获得所有的数据
PagedCharacters(信息:API_Practice.PagedCharacters.info(计数:493,
页码:25,下一页:,
上一页:),结果:[API_Practice.PagedCharacters.results(名称::]
桑切斯,“状态:“活着”,物种:“人类”),
API_Practice.PagedCharacters.Results(名称:“Morty Smith”),状态:
“活着”,物种:“人类”,API_Practice.PagedCharacters.Results(名称:
“夏史密斯”,状态:“活着”,物种:“人类”),
API_Practice.PagedCharacters.Results(名称:“Beth Smith”,状态:
“活着”,物种:“人类”,API_Practice.PagedCharacters.Results(名称:
“杰瑞·史密斯”,身份:“活着”,物种:“人类”),
API_Practice.PagedCharacters.Results(名称:“Abadango群集
公主”,身份:“活着”,物种:“外星人”),
API_Practice.PagedCharacters.Results(名称:“Abradolf Lincler”),状态:
“未知”,物种:“人类”),
API_Practice.PagedCharacters.Results(名称:“裁判员Rick”,状态:
“死亡”,物种:“人类”,API_Practice.PagedCharacters.Results(名称:
“机构主管”,身份:“死亡”,物种:“人类”),
API_Practice.PagedCharacters.Results(名称:“Alan Rails”,状态:
“死亡”,物种:“人类”,API_Practice.PagedCharacters.Results(名称:
“阿尔伯特·爱因斯坦”,身份:“死亡”,物种:“人类”),
API_Practice.PagedCharacters.Results(名称:“Alexander”,状态:
“死亡”,物种:“人类”,API_Practice.PagedCharacters.Results(名称:
“外来古加”,身份:“未知”,物种:“外来”),
API_Practice.PagedCharacters.Results(名称:“Alien Morty”,状态:
“未知”,物种:“外来”),
API_Practice.PagedCharacters.Results(名称:“Alien Rick”,状态:
“未知”,物种:“外来”),
API_Practice.PagedCharacters.Results(名称:“阿米什机器人”,状态:
“死亡”,物种:“外星人”,API_Practice.PagedCharacters.Results(名称:
“安妮”,身份:“活着”,物种:“人类”),
API_Practice.PagedCharacters.Results(名称:“天线莫蒂”),状态:
“活着”,物种:“人类”,API_Practice.PagedCharacters.Results(名称:
“天线瑞克”,状态:“未知”,物种:“人类”),
API_Practice.PagedCharacters.Results(名称:“我眼中的蚂蚁”,
状态:“未知”,物种:“人类”)])
如果你还需要什么,请告诉我。谢谢大家! 你的逻辑有很多缺陷,所以我用最小的改动重写了它。现在它将满足你的目的
import UIKit
struct PagedCharacters: Codable {
let info: Info
let results: [Results]
}
struct Info: Codable {
let count: Int
let pages: Int
let next: String
let prev: String
}
struct Results: Codable {
let name: String
let status: String
let species: String
}
下面是view controller类的代码:
class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {
@IBOutlet var uiTableView: UITableView!
var aryDownloadedData:[Results]?
var nextPageUrl:String!
override func viewDidLoad() {
super.viewDidLoad()
getIntitalRickAndMortyData()
self.uiTableView.dataSource = self
self.uiTableView.delegate = self
// Do any additional setup after loading the view.
}
func getIntitalRickAndMortyData(){
aryDownloadedData = []
//here first page is next page
nextPageUrl = "https://rickandmortyapi.com/api/character/"
getRickAndMortyData()
}
func getRickAndMortyData() {
//construct the url, use guard to avoid nonoptional
guard let urlObj = URL(string: nextPageUrl) else
{ return }
//fetch data
URLSession.shared.dataTask(with: urlObj) {[weak self](data, response, error) in
//to avoid non optional in JSONDecoder
guard let data = data else { return }
do {
//decode object
let downloadedRickAndMorty = try JSONDecoder().decode(PagedCharacters.self, from: data)
self?.aryDownloadedData?.append(contentsOf: downloadedRickAndMorty.results)
self?.nextPageUrl = downloadedRickAndMorty.info.next
DispatchQueue.main.async {
self?.uiTableView.reloadData()
}
print(self?.aryDownloadedData as Any)
} catch {
print(error)
}
}.resume()
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return self.aryDownloadedData?.count ?? 0
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
if let count = aryDownloadedData?.count, count>1{
let lastElement = count - 1
if indexPath.row == lastElement {
//call get api for next page
getRickAndMortyData()
}
}
guard let cell = tableView.dequeueReusableCell(withIdentifier: "rickandmortyCell") as? CharacterTableViewCell else { return UITableViewCell() }
cell.nameLabel.text = "Name: " + (self.aryDownloadedData?[indexPath.row].name ?? "default")
return cell
}
}
@AaronTreinish:如果这是你正在寻找的解决方案,请投票并接受答案。谢谢,代码仍然只从第一页获取数据,而不从其他页获取数据。要从其他页面获取数据,我还需要做些什么吗?tableView(tableView:willDisplayCell:)会为您做这件事。当您到达列表的末尾时,它将触发下一页url的api调用。我按您的方式运行代码,当我滚动到底部时,它不会触发下一页url的api调用。它在tableview上只有一个初始页面。我如何一次解析来自不同页面的所有数据,而不是在到达tableview底部时进行解析?我已经实现了一个搜索控制器,但是我没有从api的其他页面获得结果,因为我还没有浏览所有页面。