J'essaye d'implémenter des données de chargement à partir du serveur d'analyse après avoir appuyé sur un bouton sur postVC pour charger des données et naviguer vers guestVC. Ça fonctionnait bien et à un moment donné a commencé à planter l'application ... pas sûr pourquoi? Je reçois l'erreur fatale: inattendue trouvé tout en déballant une valeur facultative ... Toute direction ou aide serait grandement appréciée. Merci!trouvé de manière inattendue nil tout en déballant une valeur facultative dispatch-async
import UIKit
import Parse
var postuuid = [String]()
class postVC: UITableViewController {
//postVC button click function
//clicked username button from post
@IBAction func usernameBtn_click(sender: AnyObject) {
let i = sender.layer.valueForKey("index") as! NSIndexPath
let cell = tableView.cellForRowAtIndexPath(i) as! postCell
// if user tapped on himself go home, else go guest
if cell.usernameBtn.titleLabel?.text == PFUser.currentUser()?.username {
let home = self.storyboard?.instantiateViewControllerWithIdentifier("homeVC") as! homeVC
self.navigationController?.pushViewController(home, animated: true)
} else {
let guest = self.storyboard?.instantiateViewControllerWithIdentifier("guestVC") as! guestVC
self.navigationController?.pushViewController(guest, animated: true)
}
}
// guestVC relevant code
import UIKit
import Parse
var guestname = [String]()
class guestVC: UICollectionViewController {
var uuidArray = [String]()
var picArray = [PFFile]()
// posts loading function
func loadPosts() {
let query = PFQuery(className: "posts")
// app keeps crashing in line below when I try to load data to guestVC
query.whereKey("username", equalTo: guestname.last!)
query.limit = self.page
query.findObjectsInBackgroundWithBlock({ (objects:[PFObject]?, error:NSError?) -> Void in
if error == nil {
self.uuidArray.removeAll(keepCapacity: false)
self.picArray.removeAll(keepCapacity: false)
for object in objects! {
self.uuidArray.append(object.valueForKey("uuid") as! String)
self.picArray.append(object.valueForKey("pic") as! PFFile)
}
self.collectionView?.reloadData()
} else {
print(error!.localizedDescription)
}
dispatch_async(dispatch_get_main_queue(), {() -> Void in
// code here will be executed as the main queue
})
})
}
Ok, merci. Alors qu'est-ce que je retourne dans l'autre déclaration? J'ai quelques instances qui obtiennent des erreurs lorsque je renvoie une requête en utilisant guestname.last lorsque je consulte le guestVC. – user3708224
L'application se bloque car guestname.las est nul (guestname est vide) mais vous essayez de le déplier. Dans l'autre, vous pouvez gérer le cas lorsque guestname est vide (peut-être afficher une erreur dans une vue d'alerte) –