Панель поиска не работает в приложении Swift 4 IOS - PullRequest
0 голосов
/ 31 марта 2019

Я реализовал панель поиска для поиска пользователей, но ничего не отображается в табличном представлении, когда я что-то ищу. Я приложил изображение моего контроллера вида ниже.

Контроллер представления:

View Controller

Этот контроллер представления отображает список всех пользователей, и предполагается, что строка поиска помогает пользователю найти имя пользователя.

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

// let user = 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()
}

}

Ответы [ 2 ]

0 голосов
/ 01 апреля 2019

попробуйте найти имя пользователя, используя этот метод для фильтрации

searchItem = users.filter({ (objUser) -> Bool in
                return (objUser.username?.lowercased() ?? "").starts(with: searchBar.text!.trim().lowercased())
            })

Надеюсь, это поможет вам.

0 голосов
/ 01 апреля 2019

Я думаю о различных проблемах, которые могут возникнуть в вашем коде.Вам необходимо установить делегат панели поиска и средство обновления результатов поиска:

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

...