使用Swift和Parse时,如果没有特定的objectId错误,则无法更新

时间:2015-06-02 09:50:25

标签: ios swift parse-platform voting voting-system

我使用手势识别器来增加后端的投票,然后使用它来更新页面和每个单元格。我试图将图像与objectId链接,以便有一种方法来更新每个图像投票。问题不断出现我的updateVote函数,因为我似乎无法从后端检索与图像关联的objectId。继承我更新投票的代码和手势识别器:

 var swipeRight = UISwipeGestureRecognizer(target: self, action: "respondToSwipeGesture:")
    swipeRight.direction = UISwipeGestureRecognizerDirection.Right
    myCell.postedImage.userInteractionEnabled = true;
    myCell.postedImage.addGestureRecognizer(swipeRight)

    var swipeLeft = UISwipeGestureRecognizer(target: self, action: "respondToSwipeGesture:")
    swipeRight.direction = UISwipeGestureRecognizerDirection.Left
    myCell.postedImage.userInteractionEnabled = true;
    myCell.postedImage.addGestureRecognizer(swipeLeft)



    return myCell

}
    func respondToSwipeGesture(gesture: UIGestureRecognizer) {

    if let swipeGesture = gesture as? UISwipeGestureRecognizer {
        switch swipeGesture.direction {
            case UISwipeGestureRecognizerDirection.Right:
            updateVote(true, objectId: String())
            println("Swiped right")
            case UISwipeGestureRecognizerDirection.Left:
            updateVote(false, objectId: String())
            println("Swiped Left")
            default:
                break
            }
        }
    }

func updateVote(increment: Bool, objectId : String) {
    // Create a pointer to an object of class Posts with id 'objectId'
    var object = PFObject(withoutDataWithClassName: "Post", objectId: objectId)

    // Increment the current value of the quantity key by 1
    if increment == true {
        object.incrementKey("count", byAmount: 1)
    } else {
        object.incrementKey("count", byAmount: -1)
    }

    // Save
    object.saveInBackgroundWithBlock(nil)
}

如何检索objectId,因为无论何时我运行这个我一直得到错误无法更新没有特定的objectId?我得到了println("向右或向左滑动")但我无法通过投票来增加如何实现这一目标?

        import UIKit
        import Parse


        class HomePage: UITableViewController {

            var images = [UIImage]()
            var titles = [String]()
            var imageFile = [PFFile]()
            var votingObjects: [PFObject] = []
            var objectIds = [""]

         override func viewDidLoad() {
            super.viewDidLoad()

            println(PFUser.currentUser())

            println(PFUser.currentUser())

            var query = PFQuery(className:"Post")
            query.orderByDescending("createdAt")
            query.limit = 15
            query.findObjectsInBackgroundWithBlock {
                (objects: [AnyObject]?, error: NSError?) -> Void in
                if error == nil  {
                    println("Successfully retrieved \(objects!.count) scores.")
                    println(objects!)
                    for objectRow in objects! {
                        let object = objectRow as! PFObject


                        if let objectIds = object["objectId"] as? String {
                            self.objectIds.append(objectIds)

                        }





                        //objectIds.append(object.objectId as? String)
                        // Adding them to the array

                        if let title = object["Title"] as? String {
                            self.titles.append(title)
                        }
                        if let imgFile = object["imageFile"] as? PFFile {
                            self.imageFile.append(imgFile)
                        }
                        self.votingObjects.append(object)
                    }
                    dispatch_async(dispatch_get_main_queue(), {
                        self.tableView.reloadData() // Updating the tableView on the main thread - important. Do some research on Grand Central Dispatch :)

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

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

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        return titles.count

    }

    override func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat {
        return 500

    }

    override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {

        var myCell:cell = self.tableView.dequeueReusableCellWithIdentifier("myCell") as! cell

        myCell.rank.text = "21"
        myCell.votes.text = votingObjects[indexPath.row]["Post"] as? String
        myCell.postDescription.text = titles[indexPath.row]

        imageFile[indexPath.row].getDataInBackgroundWithBlock { (data, error) -> Void in

            if let downloadedImage = UIImage(data: data!) {

                myCell.postedImage.image = downloadedImage

            }
        }

这是我在该页面上的其余代码如何从数组中检索objectId?

import UIKit
import Parse
import Foundation

class cell: UITableViewCell {

    @IBOutlet weak var rank: UILabel!
    @IBOutlet weak var votes: UILabel!
    @IBOutlet weak var postedImage: UIImageView!
    @IBOutlet weak var creditLink: UIButton!
    @IBOutlet weak var addButton: UIButton!
    @IBOutlet weak var postDescription: UITextView!

}

我的手机课

1 个答案:

答案 0 :(得分:1)

您正在传递一个空字符串作为objectID objectId: String()"所以你没有选择要更新的任何行。

您的函数应传递行的objectID,以便解析可以更新它

enter image description here