gpt4 book ai didi

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

转载 作者:行者123 更新时间:2023-11-30 14:04:06 25 4
gpt4 key购买 nike

我能够添加所有核心数据并保存它,甚至将其全部打印到日志中。然而,当我尝试获取核心数据并将其加载到表格 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/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com