ios - 并非所有单元格都加载到表格 View 中,而是出现空白屏幕。 Xcode/Swift

标签 ios swift uitableview swift2 xcode7

我能够添加所有核心数据并保存它,甚至将其全部打印到日志中。然而,当我尝试获取核心数据并将其加载到表格 View 时,只有前几个单元格实际加载,而加载单元格下方的所有内容都只是一个空白屏幕。

这是我的 View Controller :

class MasterViewController: UITableViewController, NSFetchedResultsControllerDelegate {

var loggedIn = false

var managedObjectContext: NSManagedObjectContext? = nil
var detailViewController: DetailViewController? = nil

@IBOutlet var tableViewLoginButton: UIBarButtonItem!

@IBAction func tableViewLoginButtonAction(sender: AnyObject) {

    shouldPerformSegueWithIdentifier("loginSegue", sender: nil)

}


override func shouldPerformSegueWithIdentifier(identifier: String?, sender: AnyObject?) -> Bool {

    if let ident = identifier {

        if ident == "loginSegue" {


            if loggedIn == true {

                PFUser.logOutInBackgroundWithBlock({ (error) -> Void in

                    self.checkForUser()

                })


                return false
            }

        }

    }
    return true
}


func checkForUser() {

    let currentUser = PFUser.currentUser()
    if (currentUser != nil) {

        loggedIn = true
        tableViewLoginButton.title = "Logout"

    } else {

        loggedIn = false
        tableViewLoginButton.title = "Login"

    }

}

override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view, typically from a nib.

    // Code for Login and Sign Up

    checkForUser()

    coreDataSetup()


}

func coreDataSetup() {

    // Code for fetching json data, saving as core data and loading to table view

    let appDel: AppDelegate = UIApplication.sharedApplication().delegate as! AppDelegate

    let context : NSManagedObjectContext = appDel.managedObjectContext

    let url = NSURL(string: "https://www.kimonolabs.com/api/6tewont8?apikey=CPMj8n9tabsEUqUjKEPiHOmVir5gZjfq")

    let session = NSURLSession.sharedSession()

    let task = session.dataTaskWithURL(url!) { (data, response, error) -> Void in

        if error != nil {

            print(error)

        } else {

            // print(NSString(data: data!, encoding: NSUTF8StringEncoding))

            do {

                let jsonResult = try NSJSONSerialization.JSONObjectWithData(data!, options: NSJSONReadingOptions.MutableContainers) as! NSDictionary

                if jsonResult.count > 0 {

                    if let results = jsonResult["results"] as? NSDictionary {

                        if let eventData = results["collection1"] as? NSArray {

                            let request = NSFetchRequest(entityName: "ForumEvents")

                            request.returnsObjectsAsFaults = false

                            do {

                                let results = try context.executeFetchRequest(request)

                                if results.count > 0 {

                                    for result in results {

                                        context.deleteObject(result as! NSManagedObject)

                                        do { try context.save() } catch {}

                                    }

                                }

                            } catch {}

                            for event in eventData {

                                if let eventTitle = event["EventTitle"] as? NSDictionary {

                                    if let eventTitleText = eventTitle["text"] as? String {

                                        if let eventDate = event["EventDate"] as? String {

                                            if let eventTicketLink = event["EventTicketLink"] as? NSDictionary {

                                                if let eventLink = eventTicketLink["href"] as? String {

                                                    let newEvent : NSManagedObject = NSEntityDescription.insertNewObjectForEntityForName("ForumEvents", inManagedObjectContext: context)

                                                    newEvent.setValue(eventTitleText, forKey: "eventTitle")

                                                    newEvent.setValue(eventDate, forKey: "eventDate")

                                                    newEvent.setValue(eventLink, forKey: "eventLink")

                                                    do { try context.save() } catch {}



                                                }

                                            }

                                        }

                                    }

                                }

                            }

                        }

                    }

                }

                self.tableView.reloadData()

            } catch {}

        }

    }

    task.resume()

}

override func viewWillAppear(animated: Bool) {
    self.clearsSelectionOnViewWillAppear = self.splitViewController!.collapsed
    super.viewWillAppear(animated)
}

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

// MARK: - Segues

override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
    if segue.identifier == "showDetail" {

        if let indexPath = self.tableView.indexPathForSelectedRow {
            let object = self.fetchedResultsController.objectAtIndexPath(indexPath)
            let controller = (segue.destinationViewController as! UINavigationController).topViewController as! DetailViewController
            controller.detailItem = object
            controller.navigationItem.leftBarButtonItem = self.splitViewController?.displayModeButtonItem()
            controller.navigationItem.leftItemsSupplementBackButton = true
        }

    }

    if segue.identifier == "loginSegue" {

        checkForUser()

    }

}

// MARK: - Table View

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

override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    let sectionInfo = self.fetchedResultsController.sections![section]
    return sectionInfo.numberOfObjects
    // Tried: return self.fetchedResultsController.fetchedObjects!.count
}

override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
    let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath)

    self.configureCell(cell, atIndexPath: indexPath)

    return cell
}

func configureCell(cell: UITableViewCell, atIndexPath indexPath: NSIndexPath) {
    let object = self.fetchedResultsController.objectAtIndexPath(indexPath)
    cell.textLabel!.text = object.valueForKey("eventTitle")!.description

}

override func tableView(tableView: UITableView, canEditRowAtIndexPath indexPath: NSIndexPath) -> Bool {
    // Return false if you do not want the specified item to be editable.
    return false
}

var fetchedResultsController: NSFetchedResultsController {
    if _fetchedResultsController != nil {
        return _fetchedResultsController!
    }

    let fetchRequest = NSFetchRequest()
    // Edit the entity name as appropriate.
    let entity = NSEntityDescription.entityForName("ForumEvents", inManagedObjectContext: self.managedObjectContext!)
    fetchRequest.entity = entity

    // Set the batch size to a suitable number.
    fetchRequest.fetchBatchSize = 20

    // Edit the sort key as appropriate.
    let sortDescriptor = NSSortDescriptor(key: "eventTitle", ascending: false)

    fetchRequest.sortDescriptors = [sortDescriptor]

    // Edit the section name key path and cache name if appropriate.
    // nil for section name key path means "no sections".
    let aFetchedResultsController = NSFetchedResultsController(fetchRequest: fetchRequest, managedObjectContext: self.managedObjectContext!, sectionNameKeyPath: nil, cacheName: "Master")
    aFetchedResultsController.delegate = self
    _fetchedResultsController = aFetchedResultsController

    do {
        try _fetchedResultsController!.performFetch()
    } catch {
        // Replace this implementation with code to handle the error appropriately.
        // abort() causes the application to generate a crash log and terminate. You should not use this function in a shipping application, although it may be useful during development.
        //print("Unresolved error \(error), \(error.userInfo)")
        abort()
    }

    return _fetchedResultsController!
}
var _fetchedResultsController: NSFetchedResultsController? = nil

func controllerWillChangeContent(controller: NSFetchedResultsController) {
    self.tableView.beginUpdates()
}

}

以下是加载单元格结果的屏幕截图:

screenshot of the blank screen

我已经尝试了所有方法,但不知道下一步该尝试什么!

预先感谢您的帮助。

最佳答案

确保 CoreData 正确。然后试试这个:

改变

override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    let sectionInfo = self.fetchedResultsController.sections![section]
    return sectionInfo.numberOfObjects
}

进入

override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
    return self.fetchResultController.fetchedObjects!.count
}

关于ios - 并非所有单元格都加载到表格 View 中,而是出现空白屏幕。 Xcode/Swift,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32620573/

相关文章:

iOS 模糊效果到 ImageView 与 Swift

Swift 4. 使用 PAT。允许相互引用的协议(protocol)吗?我收到一个我不明白的错误

swift - 在结构中创建 UIButton

iphone - SearchBar 从 iOS 7 的 headerview 中消失

ios - 修改导航栏外观时与 NSAppearance 相关的 NSInternalInconsistencyException

iphone - 禁用/启用 IBOutlet 决定我是否得到触摸?

swift - 类型 'StorageMetadata' 的值没有成员 'downloadURL'

ios - 核心数据一对多 Swift

ios - UITableView 中最后选择的行

iphone - 读取 iPhone 上安装的证书