仅当我将手机置于横向模式时,才会加载表格视图

时间:2016-04-01 03:35:26

标签: ios arrays swift tableview

我有一个自定义表格视图,当我运行应用程序时,显示空白,就像它尚未加载,但当我将手机倾斜到横向模式时,条目出现,这对我来说真的没有意义。有什么建议吗?

编辑:这是我的代码

 import UIKit
 import Alamofire
 import ObjectMapper
 class LotteryTableViewController: UITableViewController {
let lotteryMachine = LotteryMachine()

var currentStandings: [Team] = []
var draftStandings: [Team] = []
override func viewDidLoad() {
    super.viewDidLoad()

    let headers = [
        "User-agent": "LotteryMachine/1.0 (nilayneeranjun24@gmail.com)",
               ]
        Alamofire.request(.GET, "https://erikberg.com/nba/standings.json",headers: headers)
            .responseJSON { response in
                let parentJson = Mapper<Standings>().map(response.2.value)
               let standingsArray: [Team] = parentJson!.standing!
                    self.currentStandings=standingsArray
                    self.draftStandings=self.lotteryMachine.setPossibleCombinations(standingsArray)
                    self.draftStandings=self.lotteryMachine.setDraftPositions(self.draftStandings)
                    print (self.draftStandings.toJSON())
                }

    }




    // Uncomment the following line to preserve selection between presentations
    // self.clearsSelectionOnViewWillAppear = false

    // Uncomment the following line to display an Edit button in the navigation bar for this view controller.
    // self.navigationItem.rightBarButtonItem = self.editButtonItem()


override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

// MARK: - Table view data source

override func numberOfSectionsInTableView(tableView: UITableView) -> Int {

    return 1
}

override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

    return draftStandings.count
}


override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
    let cellIdentifier = "LotteryTableViewCell"


    let cell = tableView.dequeueReusableCellWithIdentifier(cellIdentifier, forIndexPath: indexPath) as! LotteryTableViewCell


   let position = self.draftStandings[indexPath.row].draftingPosition!

    let teamName = self.draftStandings[indexPath.row].lastName!
   let record = String(self.draftStandings[indexPath.row].won!) + "-" + String(self.draftStandings[indexPath.row].lost!)

    let player = "Ben Simmons"
    cell.position.text = String(position)
    cell.teamName.text = teamName
    cell.record.text = String(record)
    cell.player.text = player
   cell.teamLogo.image = UIImage(named: "lakers")



    // Configure the cell...

    return cell
}


/*
// Override to support conditional editing of the table view.
override func tableView(tableView: UITableView, canEditRowAtIndexPath indexPath: NSIndexPath) -> Bool {
    // Return false if you do not want the specified item to be editable.
    return true
}
*/

/*
// Override to support editing the table view.
override func tableView(tableView: UITableView, commitEditingStyle editingStyle: UITableViewCellEditingStyle, forRowAtIndexPath indexPath: NSIndexPath) {
    if editingStyle == .Delete {
        // Delete the row from the data source
        tableView.deleteRowsAtIndexPaths([indexPath], withRowAnimation: .Fade)
    } else if editingStyle == .Insert {
        // Create a new instance of the appropriate class, insert it into the array, and add a new row to the table view
    }    
}
*/

/*
// Override to support rearranging the table view.
override func tableView(tableView: UITableView, moveRowAtIndexPath fromIndexPath: NSIndexPath, toIndexPath: NSIndexPath) {

}
*/

/*
// Override to support conditional rearranging of the table view.
override func tableView(tableView: UITableView, canMoveRowAtIndexPath indexPath: NSIndexPath) -> Bool {
    // Return false if you do not want the item to be re-orderable.
    return true
}
*/

/*
// MARK: - Navigation

// In a storyboard-based application, you will often want to do a little preparation before navigation
override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
    // Get the new view controller using segue.destinationViewController.
    // Pass the selected object to the new view controller.
}
*/

}

1 个答案:

答案 0 :(得分:2)

Alamofire.request本质上是异步的。因此,当表首次加载时,请求仍在执行,而draftStandings没有任何数据。旋转时,表格会重新加载,到那时draftStandings确实已经有一些表格显示的数据。

在请求回复中设置tableView.reloadData()后尝试添加draftStandings