未调用 DidSelectRow 方法

DidSelectRow method not called

大家好,我试了几天都没有找到答案。在提出这个问题之前,我已经实现了 UITableViewDelegateUITableViewDataSource 我的 didSelectRowAtdidDeselectRowAt,这两种方法都不起作用。

class SearchClass: UIViewController, UITableViewDataSource,UITableViewDelegate, UISearchBarDelegate {

@IBOutlet weak var myTableView: UITableView!
@IBOutlet weak var mySearchBar: UISearchBar!

var objects:PFObject!

var searchResults = [String]()

override func viewDidAppear(_ animated: Bool) {
    super.viewDidAppear(animated)
    self.navigationController?.navigationBar.topItem?.title = "Search"
    self.navigationController?.navigationBar.barTintColor = UIColor.white
    self.navigationController?.navigationBar.backgroundColor = UIColor.black
    self.navigationController?.navigationBar.tintColor = UIColor.black
    self.searchResults.removeAll()

}


override func viewDidLoad() {
    super.viewDidLoad()
    // Do any additional setup after loading the view, typically from a nib.

    self.myTableView.dataSource = self
    self.mySearchBar.delegate = self
    self.myTableView.delegate = self


    self.navigationController?.extendedLayoutIncludesOpaqueBars = true

    //self.myTableView.reloadData()
}

override func didReceiveMemoryWarning() {
    super.didReceiveMemoryWarning()
    // Dispose of any resources that can be recreated.
}

func searchBarSearchButtonClicked(_ searchBar: UISearchBar)
{
    searchBar.resignFirstResponder()
   // self.navigationController?.navigationBar.isHidden = false
    self.mySearchBar.endEditing(true)
    print("Search word = \(searchBar.text)")

    let query = PFQuery(className:"myClass")
    //let newText = searchBar.autocapitalization
    searchBar.autocapitalizationType = .none
    searchBar.text = searchBar.text?.localizedLowercase
    query.whereKey("collegeNickName", contains: searchBar.text)

    query.findObjectsInBackground { (results, error) in
        if error == nil {

            if let objects = results {

                self.searchResults.removeAll(keepingCapacity: true)

                for object in objects {
                    let firstName = object.object(forKey: "myName") as! String
                    let image = object.object(forKey: "myImage") as! PFFile
                    //   let lastName = object.object(forKey: "myPlace") as! String
                    //   let fullName = firstName + " " + lastName
                    self.searchResults.append(firstName)

                    print(self.searchResults[0])
                    DispatchQueue.main.async {
                        self.myTableView.reloadData()
                        self.mySearchBar.resignFirstResponder()
                    }
                }
            }

        } else {

            let myAlert = UIAlertController(title:"Alert", message:error?.localizedDescription, preferredStyle:UIAlertControllerStyle.alert)

            let okAction = UIAlertAction(title: "Ok", style: UIAlertActionStyle.default, handler: nil)

            myAlert.addAction(okAction)

            self.present(myAlert, animated: true, completion: nil)
            return


                }
            }
        }

func searchBarTextDidBeginEditing(_ searchBar: UISearchBar) {
    //self.navigationController?.navigationBar.isHidden = true
}


func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int
{
    return searchResults.count
}

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell
{
    myTableView.register(UITableViewCell.self, forCellReuseIdentifier: "myCell")

    let myCell = myTableView.dequeueReusableCell(withIdentifier: "myCell")

    myCell?.textLabel?.text = searchResults[indexPath.row]
    print(searchResults[indexPath.row])
    return myCell!
}


func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
    print("Hi")
}

func tableView(_ tableView: UITableView, didDeselectRowAt indexPath: IndexPath) {

}

func searchBarCancelButtonClicked(_ searchBar: UISearchBar)
{
    mySearchBar.resignFirstResponder()
    mySearchBar.text = ""
    myTableView.reloadData()
}

func searchBarTextDidEndEditing(_ searchBar: UISearchBar) {
    //self.mySearchBar.resignFirstResponder()
    //self.mySearchBar.endEditing(true)
    self.definesPresentationContext = true
}

@IBAction func refreshButtonTapped(sender: AnyObject) {
    mySearchBar.resignFirstResponder()
    mySearchBar.text = ""
    self.searchResults.removeAll(keepingCapacity: false)
    self.myTableView.reloadData()
  }
}

它还实现了一个 searchView 我得到了我想要搜索的内容,但无法在我的 class.

中使用 select 和 deselect 方法
self.myTableView.dataSource = self
self.myTableView.delegate = self

<--- 添加这个。

注意到您在情节提要中将委托设置为 view 而不是 UIViewController see Discover - that's mine UViewController

在界面生成器中

  • dataSource delegate My Table View 连接到 SearchClass

然后可以删除SearchClass

中多余的self.myTableView.dataSource = self

考虑到 Interface Builder 中的连接比代码中的连接更有效。

单元格声明错误。你已经完成了下面的代码

 let myCell = myTableView.dequeueReusableCell(withIdentifier: "myCell")

正确的格式

 let myCell = tableView.dequeueReusableCell(withIdentifier: "myCell")

原因: 当你使用 dequeue 属性 时,然后 UITableView 通过它从方法

获得的参数将它的 cell 出列

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell

看到有一个参数 tableView 但你在 UITableView 的出口出队。