Swift iOS:通过UISearchBar查找解析用户,并在表视图中显示结果

Swift iOS:通过UISearchBar查找解析用户,并在表视图中显示结果,ios,swift,parse-platform,uisearchbar,Ios,Swift,Parse Platform,Uisearchbar,我尝试通过UISearchBar查找解析用户,并在表视图中显示结果。 当我热搜索时,什么也没发生。。。 我的想法是使用searchText.text作为对用户的查询 我是否应该尝试将搜索栏与搜索显示控制器一起使用? 有什么想法吗 import UIKit class AllFriendsTableViewController: UITableViewController, UISearchBarDelegate, UISearchDisplayDelegate { @IBOut

我尝试通过UISearchBar查找解析用户,并在表视图中显示结果。 当我热搜索时,什么也没发生。。。 我的想法是使用searchText.text作为对用户的查询

我是否应该尝试将搜索栏与搜索显示控制器一起使用? 有什么想法吗

import UIKit


  class AllFriendsTableViewController: UITableViewController, UISearchBarDelegate,      UISearchDisplayDelegate {
@IBOutlet var SearchDisplay: UISearchDisplayController!



var userList:NSMutableArray = NSMutableArray()


 func searchBarShouldBeginEditing(searchBar: UISearchBar!) -> Bool {
    return true
}

func searchBarShouldEndEditing(searchBar: UISearchBar!) -> Bool {
    return true

}

func searchBar(searchBar: UISearchBar!, textDidChange searchText: String!) {
    loadUser()
}



@IBOutlet var searchText: UISearchBar!



func loadUser () {

    userList.removeAllObjects()
    var findUser:PFQuery = PFUser.query()
    findUser.whereKey("username", equalTo: searchText.text)


    findUser.findObjectsInBackgroundWithBlock { (objects:[AnyObject]!, error:NSError!) -> Void in
        if !(error != nil) {
            // The find succeeded.
            println("succesfull load Users")
            // Do something with the found objects
            for object  in objects  {
                self.userList.addObject(object)
                println("users added to userlist")
            }
            self.tableView.reloadData()
        } else {
            // Log details of the failure
            println("error loadind user ")
            println("error")
        }

    }
}


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

override func tableView(tableView: UITableView!, numberOfRowsInSection section: Int) -> Int {
    if tableView == searchDisplayController.searchResultsTableView {
        return userList.count
    }
    else {
        return 0
    }
}



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



    let cell: AllFirendsTableViewCell = self.tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath)as AllFirendsTableViewCell


    let users:PFObject = self.userList.objectAtIndex(indexPath!.row) as PFObject


    var findUserName:PFQuery = PFUser.query()
    findUserName.whereKey("username", containsString: searchText.text)



    findUserName.findObjectsInBackgroundWithBlock{
        (objects:[AnyObject]!, error:NSError!) -> Void in

        if !(error != nil) {

            if let user:PFUser = users as? PFUser {
                cell.userNameTextField.text = user.username
                println("user exist")
                // define avatar poster

                if let avatarImage:PFFile = user["profileImage"] as? PFFile {
                    avatarImage.getDataInBackgroundWithBlock{(imageData:NSData!, error:NSError!)-> Void in

                        if !(error != nil) {

                            let image:UIImage = UIImage(data: imageData)


                            cell.avatarImage.image = image as UIImage
                            cell.avatarImage.layer.cornerRadius = 24
                            cell.avatarImage.clipsToBounds = true

                        }

                    }

                }
                else {
                    cell.avatarImage.image = UIImage(named: "Avatar-1")
                    cell.avatarImage.layer.cornerRadius = 24
                    cell.avatarImage.clipsToBounds = true
                }
            }

        }


    }

  return cell

}



override func viewWillAppear(animated: Bool) {
    super.viewWillAppear(true)
    navigationController.navigationBar.hidden = false
    loadUser()

}


override func viewDidAppear(animated: Bool) {

}

override func viewDidLoad() {


    // Do any additional setup after loading the view, typically from a nib.
}

}

我怀疑这可能是由于您试图从发生网络请求的后台线程重新加载tableview。UI更新应该从主线程进行

loadUser()
函数中,尝试从主线程重新加载tableview,如下所示:

NSOperationQueue.mainQueue().addOperationWithBlock({
    self.tableView.reloadData()
})

这可能会解决您的问题。

您应该在点击搜索按钮时搜索用户,但目前您使用cellForRow方法进行搜索。这是错误的。raywenderlich.com上有一篇关于搜索栏的文章,请阅读。谢谢,但我已经准备好阅读这首图图了。如果我像raywenderlich.com那样做,我必须下载所有解析用户,然后过滤结果。我希望只下载与searchText.text匹配的用户。对不起,我错了。我检查了你的代码,看起来还可以。可以,但在表视图中看不到任何结果。出现了一些问题。那些带有block:parse的方法在主线程上运行块。