#ios #swift #uisearchbar #searchbar
#iOS #swift #панель пользовательского поиска #панель поиска
Вопрос:
Я внедрил панель поиска для поиска пользователей, но при поиске чего-либо в табличном представлении ничего не отображается. Я прикрепил изображение моего контроллера просмотра ниже.
Просмотр контроллера:
Этот контроллер просмотра показывает список всех пользователей, и панель поиска должна помочь пользователю найти имя пользователя.
import UIKit
class FindFriendsViewController: UIViewController {
var users = [User]()
@IBOutlet weak var tableView: UITableView!
@IBOutlet weak var searchBar: UISearchBar!
var searchItem = [String]()
var searching = false
override func viewDidLoad() {
super.viewDidLoad()
tableView.tableFooterView = UIView()
tableView.rowHeight = 71
let tap = UITapGestureRecognizer(target: self.view, action: #selector(UIView.endEditing(_:)))
tap.cancelsTouchesInView = false
self.view.addGestureRecognizer(tap)
}
override func viewWillAppear(_ animated: Bool) {
super.viewWillAppear(animated)
UserService.usersExcludingCurrentUser { [unowned self] (users) in
self.users = users
DispatchQueue.main.async {
self.tableView.reloadData()
}
}
}
}
extension FindFriendsViewController: UITableViewDataSource {
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
if searching {
return searchItem.count
} else {
return users.count
}
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCell(withIdentifier: "FindFriendsCell") as! FindFriendsCell
// разрешить пользователю = users[indexPath.row]
var usernamesArr = [String]()
for user in users {
usernamesArr.append(user.username)
}
if searching {
cell.textLabel?.text = searchItem[indexPath.row]
} else {
cell.textLabel?.text = usernamesArr[indexPath.row]
cell.delegate = self
configure(cell: cell, atIndexPath: indexPath)
}
return cell
}
func configure(cell: FindFriendsCell, atIndexPath indexPath: IndexPath) {
let user = users[indexPath.row]
cell.usernameLabel.text = user.username
cell.followButton.isSelected = user.isFollowed
}
}
extension FindFriendsViewController: FindFriendsCellDelegate {
func didTapFollowButton(_ followButton: UIButton, on cell: FindFriendsCell) {
guard let indexPath = tableView.indexPath(for: cell) else { return }
followButton.isUserInteractionEnabled = false
let followee = users[indexPath.row]
FollowService.setIsFollowing(!followee.isFollowed, fromCurrentUserTo: followee) { (success) in
defer {
followButton.isUserInteractionEnabled = true
}
guard success else { return }
followee.isFollowed = !followee.isFollowed
self.tableView.reloadRows(at: [indexPath], with: .none)
}
}
}
extension FindFriendsViewController: UISearchBarDelegate {
func searchBar(_ searchBar: UISearchBar, textDidChange searchText: String) {
var usernamesArr = [String]()
for user in users {
usernamesArr.append(user.username)
}
searchItem = usernamesArr.filter({$0.lowercased().prefix(searchText.count) == searchText.lowercased()})
searching = true
tableView.reloadData()
}
}
Ответ №1:
Я думаю о различных проблемах, которые могут возникнуть в вашем коде. Вам необходимо настроить делегирование панели поиска и средство обновления результатов поиска:
yourSearchController.searchBar.delegate = self
yourSearchController.searchResultsUpdater = self
Если у вас нет контроллера, но непосредственно панель поиска:
yourSearchBar.delegate = self
yourSearchBar.searchResultsUpdater = self
И это в качестве вашего делегата:
extension MasterViewController: UISearchBarDelegate {
// MARK: - UISearchBar Delegate
func searchBar(_ searchBar: UISearchBar, selectedScopeButtonIndexDidChange selectedScope: Int) {
filterContentForSearchText(searchBar.text!, scope: searchBar.scopeButtonTitles![selectedScope])
}
}
extension MasterViewController: UISearchResultsUpdating {
// MARK: - UISearchResultsUpdating Delegate
func updateSearchResults(for searchController: UISearchController) {
let searchBar = searchController.searchBar
let scope = searchBar.scopeButtonTitles![searchBar.selectedScopeButtonIndex]
filterContentForSearchText(searchController.searchBar.text!, scope: scope)
}
Или, может быть, вам не хватает чего-то вроде обновления. Проверьте путь к данным, исключая проблемный, на время. Сначала вы вводите текст внутри строки поиска, после этого проверяете в коде, куда идет текст и что происходит. Вы обновляли табличное представление, когда панель поиска находится в состоянии завершения редактирования?
Если это вам не помогло, ознакомьтесь с этим замечательным руководством, которому я следовал несколько раз назад: Панель поиска iOS
Комментарии:
1. Спасибо! Я загляну в руководство и посмотрю, работает ли предоставленный вами код.
Ответ №2:
попробуйте выполнить поиск по имени пользователя, используя этот метод для фильтрации
searchItem = users.filter({ (objUser) -> Bool in
return (objUser.username?.lowercased() ?? "").starts(with: searchBar.text!.trim().lowercased())
})
Надеюсь, это вам поможет.
Комментарии:
1. Привет. В нем говорится, что «Значение типа ‘String’ не имеет элемента ‘trim'»
2. Нет, но значение не фильтрует строку по имени пользователя, поэтому.