簡體   English   中英

關閉模態視圖控制器后多次加載表視圖數據

[英]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.

 
粵ICP備18138465號  © 2020-2024 STACKOOM.COM