JSON 数据未显示在 UITableView 上
Posted
技术标签:
【中文标题】JSON 数据未显示在 UITableView 上【英文标题】:JSON data not showing up on UITableView 【发布时间】:2016-07-02 20:54:42 【问题描述】:我正在使用 Alamofire 解析 JSON,并在控制台上检索到正确的 JSON 结果,但它没有显示在 UITableView 上。我认为这是竞争条件,但我不知道如何解决它。
WeatherViewController.swift
import Foundation
import UIKit
class WeatherViewController: UITableViewController
var weatherStore: WeatherStore!
var weather: Weather!
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int
print(weatherStore.allWeathers.count)
return weatherStore.allWeathers.count
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell
let cell = tableView.dequeueReusableCellWithIdentifier("UITableViewCell", forIndexPath: indexPath)
let weather = weatherStore.allWeathers[indexPath.row]
cell.textLabel?.text = String(weather.id)
cell.detailTextLabel?.text = weather.main
return cell
override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath)
override func viewDidLoad()
super.viewDidLoad()
weatherStore.createWeather (fetchedWeather: Weather) in
self.weatherStore.allWeather.append(fetchedWeather)
tableView.reloadData()
let statusNarHeight = UIApplication.sharedApplication().statusBarFrame.height
let insets = UIEdgeInsets(top: statusNarHeight, left: 0, bottom: 0, right: 0)
tableView.contentInset = insets
tableView.scrollIndicatorInsets = insets
tableView.reloadData()
WeatherStore.swift
编辑:我注释掉 afterWeatherCreated(newWeather!) 因为在 Harshai 评论之后我发现我不需要它。
import Foundation
import Alamofire
class WeatherStore
var allWeather = [Weather]()
func createWeather(afterWeatherCreated: (Weather) -> Void)
var id: Int = 9
var main: String = ""
var newWeather: Weather?
Alamofire.request(.GET, "http://api.openweathermap.org/data/2.5/weather?xyz")
.responseJSON(completionHandler: response in
if let JSON = response.result.value
// id = JSON["id"] as! Int
//main = JSON["main"] as! String
let dataArray: NSArray = JSON["weather"] as! NSArray
for item in dataArray
let obj = item as! NSDictionary
for (key, value) in obj
if key.isEqual("id")
id = value as! Int
if key.isEqual("main")
main = value as! String
newWeather = Weather(id: id, main: main)
//afterWeatherCreated(newWeather!)
)
AppDeleage.swift
func application(application: UIApplication, didFinishLaunchingWithOptions launchOptions: [NSObject: AnyObject]?) -> Bool
// Override point for customization after application launch.
let weatherStore = WeatherStore()
let weatherController = window!.rootViewController as! WeatherViewController
weatherController.weatherStore = weatherStore
return true
【问题讨论】:
这个方法是做什么的? afterWeatherCreated(newWeather!) @HarshalBhavsar 我可能不需要那种方法。但我仍然没有找到解决问题的方法。 你的网络请求是异步的,所以你需要在获取数据后重新加载你的tableView。您可以在afterWeatherCreated
closure 的代码中添加它。
【参考方案1】:
试试这个:
override func viewDidLoad()
super.viewDidLoad()
weatherStore.createWeather (fetchedWeather: Weather) in
self.weatherStore.allWeather.append(fetchedWeather)'
self.tableView.reloadData()
let statusNarHeight = UIApplication.sharedApplication().statusBarFrame.height
let insets = UIEdgeInsets(top: statusNarHeight, left: 0, bottom: 0, right: 0)
tableView.contentInset = insets
tableView.scrollIndicatorInsets = insets
tableView.reloadData()
【讨论】:
谢谢,这成功了!只是想知道,你应该调用 reloadData() 两次吗?如果是,那为什么。 这不是要调用它两次,而是因为它是异步调用,因此您必须在获取数据时重新加载数据。以上是关于JSON 数据未显示在 UITableView 上的主要内容,如果未能解决你的问题,请参考以下文章