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