【问题标题】:Update DetailViewController with Selected PFUser content from UICollectionViewCell使用 UICollectionViewCell 中选定的 PFUser 内容更新 DetailViewController
【发布时间】:2015-08-23 11:46:56
【问题描述】:

我正在构建一个社交网络应用程序,目前我想在 PFUser.CurrentUser() 从 UICollectionView 中选择另一个用户的单元格时在 HomeViewController 和 OtherUserViewController 之间创建一个 segue。 segue 运行良好,但 otherUserName 标签未更新所选 PFUser 的名称。

我已经生成了所有用户的列表,并将每个用户放在自己的单元格中。

var userListData = [String]()
var userListUserNames = [String]()

@IBOutlet weak var userCollectionView: UICollectionView!

override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view.

    userCollectionView.delegate = self
    userCollectionView.dataSource = self
    loadData()
}
func loadData (){
    var userListQuery = PFUser.query()
    userListQuery?.findObjectsInBackgroundWithBlock({ (objects, error) -> Void in
        if error == nil {

            if let objects = objects {

                for object in objects {

                    if let user = object as? PFUser {

                        if user.objectId != PFUser.currentUser()?.objectId {

                            self.userListData.append(user.objectId!)
                            self.userListUserNames.append(user.username!)
                            self.userCollectionView.reloadData()
                        }
                    }
                }
            }
        }
    })
}

之后我创建了单元格。

func numberOfSectionsInCollectionView(collectionView: UICollectionView) -> Int {
    return 1
}

func collectionView(collectionView: UICollectionView, numberOfItemsInSection section: Int) -> Int {
    return userListData.count

}

func collectionView(collectionView: UICollectionView, cellForItemAtIndexPath indexPath: NSIndexPath) -> UICollectionViewCell {
    let cell = collectionView.dequeueReusableCellWithReuseIdentifier("homeCollectionViewCell", forIndexPath: indexPath) as! HomeCollectionViewCell

    var names = self.userListUserNames[indexPath.row]
    cell.profileNameButtonOutlet.setTitle(names.lowercaseString, forState: UIControlState.Normal)

    return cell
}

然后我为单元格创建了 prepareForSegue 方法和 didDeselectItemAtIndexPath。

override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) {
    var currentOtherUser: PFObject?
    if let object = sender as? PFObject {

        currentOtherUser = sender as? PFObject
    } else {
        println("there is no currentOtherUser")
    }
    var otherUserScene = segue.destinationViewController as! OtherUserViewController
    otherUserScene.currentOtherUser = (currentOtherUser)
}

func collectionView(collectionView: UICollectionView, didDeselectItemAtIndexPath indexPath: NSIndexPath) {
    let currentOtherUser = userListUserNames[indexPath.row]
    self.performSegueWithIdentifier("homeToOtherUser", sender: currentOtherUser)
}

在我的详细控制器中,我设置了信息检索。

class OtherUserViewController: UIViewController {

var currentOtherUser : PFObject?

@IBOutlet weak var otherUserName: UILabel!

var otherUser: PFUser?

override func viewDidLoad() {
    super.viewDidLoad()

    if let object = currentOtherUser {
        if let value = object["username"] as? String {

            otherUserName.text = value

        }
    } else {
        println("no name to display")
    }
}
}

prepareForSegue 的返回值始终为零,OtherUserViewController 的 ViewDidLoad 也是如此。

我做错了什么,如何正确设置 segue?

【问题讨论】:

    标签: swift parse-platform uiviewcontroller uicollectionview segue


    【解决方案1】:

    基本上你所做的在逻辑上是好的,segues 没有问题。然而问题是:

      var userListUserNames = [String]()   // This is not [PFOBject]
    

    但是在为 segue 做准备时,您正在检查:

     if let object = sender as? PFObject {
        //which will never be called because sender is of type <String>
        currentOtherUser = sender as? PFObject
    } else {
        println("there is no currentOtherUser")  //this is what is being displayed right now
    }
    

    那是因为:

      func collectionView(collectionView: UICollectionView, didDeselectItemAtIndexPath indexPath: NSIndexPath) {
    let currentOtherUser = userListUserNames[indexPath.row]  //This is String
    self.performSegueWithIdentifier("homeToOtherUser", sender: currentOtherUser)
    

    }

    这就是问题所在。

    解决方案要么是 String 类型,如果你这样做,你会得到名称,但你可能会丢失 otherUser 的其他相关属性,这些属性可能在以后需要。如果是这种情况,我建议将整个 PFObject 存储在数组中并使用它,这样你就不必一次又一次地调用 Parse,但你会使用一些内存。

    但您的代码中也潜藏着危险。不要从单独的线程调用 UI 更新。如果我是正确的,解析块是从一个单独的线程执行的,建议在主线程上发布 UI 更新,如下所示:

    userListQuery?.findObjectsInBackgroundWithBlock({ (objects, error) -> Void in
        if error == nil && objects != nil{
                for object in objects! {
    
                    if let user = object as? PFUser {
                        if user.objectId != PFUser.currentUser()?.objectId {
    
                            self.userListData.append(user.objectId!)
                            self.userListUserNames.append(user.username!)
    
                                    dispatch_async(dispatch_get_main_queue(), { () -> Void in
                                 self.userCollectionView.reloadData()
                           })
    
                        }
                    }
                }
        }
    })
    

    如果有帮助,请告诉我。干杯!

    【讨论】:

    • 感谢您抽出宝贵时间回答,它确实有帮助!我在 if let 语句中更改了 PFObject,就像这样 override func prepareForSegue(segue: UIStoryboardSegue, sender: AnyObject?) { var currentObject : String?如果让当前=发件人为?字符串 { currentObject = 发件人为? String } var secVS: OtherUserViewController = segue.destinationViewController as! OtherUserViewController secVS.currentOtherUser = (currentObject)!现在一切正常。您的建议更好,我会将所有对象存储在一个数组中,并在需要时调用每个用户。
    猜你喜欢
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多