[英]Table View Data Loading Multiple Times After Dismissing Modal View Controller
我有一個表視圖,顯示來自Parse的對象。 我有一個按鈕,該按鈕以模態顯示另一個用於添加新對象的視圖控制器。 當選擇了表格視圖中的一行時,它會模態呈現一個視圖控制器以顯示對象信息並允許編輯對象。 我遇到的問題是,當我添加新項目或編輯項目然后關閉模式控制器時,表視圖將重新加載並多次顯示數據。 我做錯了什么?
這些功能在presenting視圖控制器(我的表視圖控制器)中。 顯然,問題必須在didDismissViewController()中。
func getItems() {
// activityIndicator?.startAnimating()
let query = PFQuery(className: "Items")
query.whereKey("user", equalTo: PFUser.currentUser()!)
query.whereKey("collection", equalTo: self.title!)
query.orderByAscending("item")
query.limit = limit
query.skip = skip
query.findObjectsInBackgroundWithBlock( {
(objects, error) -> Void in
if error == nil {
if let objects = objects as [PFObject]! {
for object in objects {
self.itemNames.append(object["item"] as! String)
self.objectID.append(object.objectId!)
self.itemUPC.append(object["upc"] as! String)
self.model.append(object["model"] as! String)
self.pricePaid.append(object["pricePaid"] as! String)
// self.imagesArray.append(object["images"])
if object["images"] == nil {
self.imagesArray.append(nil)
} else {
self.imagesArray.append(object["images"])
}
}
}
// print(self.imagesArray)
/*
if objects!.count == self.limit {
self.skip += self.limit
self.getCollections()
}
*/
dispatch_async(dispatch_get_main_queue()) {
self.tableView.reloadData()
// self.activityIndicator!.stopAnimating()
print(self.itemNames)
}
} else {
var errorString = String()
if let message = error!.userInfo["error"] {
errorString = message as! String
}
print(errorString)
}
})
}
func createItem() {
let createVC = CreateItemViewController(nibName: "CreateItemViewController", bundle: nil)
let navController = NavController(rootViewController: createVC)
navController.modalPresentationStyle = .OverCurrentContext
createVC.collectionString = self.title!
NSNotificationCenter.defaultCenter().addObserver(self, selector: "didDismissViewController", name: "ItemAdded", object: nil)
self.presentViewController(navController, animated: true, completion: nil)
}
func didDismissViewController() {
objectID.removeAll()
itemNames.removeAll()
itemUPC.removeAll()
pricePaid.removeAll()
model.removeAll()
imagesArray.removeAll()
itemImages.removeAll()
getItems()
}
該功能位於以模態形式顯示的視圖控制器中,您可以在其中輸入要創建的Parse對象的項目詳細信息。
func done() {
// Save the item data...
if itemImageView.image != nil {
let pictureData = UIImageJPEGRepresentation(itemImageView.image!, 0.05)
image = PFFile(name: "img", data: pictureData!)
} else {
image = nil
}
let newItem = PFObject(className: "Items")
newItem["item"] = itemNameTextField.text
newItem["upc"] = upcTextField.text
newItem["model"] = modelTextField.text
newItem["pricePaid"] = pricePaidTextField.text
newItem["user"] = PFUser.currentUser()
newItem["collection"] = collectionString
newItem["images"] = itemImages
newItem.saveInBackgroundWithBlock( {
(succeeded, error) -> Void in
if error == nil {
NSNotificationCenter.defaultCenter().postNotificationName("ItemAdded", object: nil, userInfo: nil)
self.presentingViewController?.dismissViewControllerAnimated(true, completion: nil)
} else {
var alert: UIAlertController?
let errorOK = UIAlertAction(title: "OK", style: .Default, handler: {
(action) -> Void in
alert?.dismissViewControllerAnimated(true, completion: nil)
})
var errorString = String()
if let message = error!.userInfo["error"] {
errorString = message as! String
}
alert = UIAlertController(title: "Error", message: errorString, preferredStyle: .Alert)
alert!.addAction(errorOK)
self.presentViewController(alert!, animated: true, completion: nil)
}
})
}
看來您正在添加觀察者,但沒有刪除他們。
聲明:本站的技術帖子網頁,遵循CC BY-SA 4.0協議,如果您需要轉載,請注明本站網址或者原文地址。任何問題請咨詢:yoyou2525@163.com.