UISearchController保留问题

时间:2015-08-21 13:09:22

标签: ios swift uitableview uisearchcontroller

我正在尝试使用UISearchController但是我面临保留我无法解决的问题。 MainTableview有两个部分。

第1节

基于某些正则表达式的过滤数据

第2节

所有数据

我将UISearchController添加到我的tableview中,并将ResultsTableController作为resultsTableController附加。当用户搜索某些东西时,它工作,ResultsTableController出现,因为我将tableview委托设置为self,从我的MainTableViewController中的ResultsTableController调用didSelectRowAtIndexPath中选择项目。但是,如果用户从resultsTableController中选择了某些内容,我就会遇到分配问题。

以下针对不同场景发生

  • 用户不搜索任何内容,只需从中选择一项 MainTableview,我看到了deinit消息
  • 用户搜索内容,取消搜索,从中选择项目 MainTableview,我看到了deinit消息
  • 用户搜索内容,然后从中选择一个项目 ResultsTableController,我的viewcontrollers中没有deinit

MainTableViewController.swift

var searchController: UISearchController!

// Secondary search results table view.
var resultsTableController: ResultsTableController!
var allCompanies = ["Data1","Data2","Data3"]

override func viewDidLoad() {
    super.viewDidLoad()
     resultsTableController = ResultsTableController()
    // We want to be the delegate for our filtered table so didSelectRowAtIndexPath(_:) is called for both tables.
    resultsTableController.tableView.delegate = self
    searchController = UISearchController(searchResultsController: resultsTableController)
    searchController.searchResultsUpdater = self
    searchController.searchBar.sizeToFit()
    tableView.tableHeaderView = searchController.searchBar

    searchController.delegate = self
    searchController.dimsBackgroundDuringPresentation = false 
    searchController.searchBar.delegate = self   
    definesPresentationContext = true
    }
}



// MARK: UISearchBarDelegate

func searchBarSearchButtonClicked(searchBar: UISearchBar) {
    searchBar.resignFirstResponder()
}

// MARK: UISearchResultsUpdating
func updateSearchResultsForSearchController(searchController: UISearchController) {
    // Update the filtered array based on the search text.

    let filteredResults = allCompanies.filter({ company in
        (company.lowercaseString as NSString).containsString(searchController.searchBar.text.lowercaseString)
    })

    // Hand over the filtered results to our search results table.
    let resultsController = searchController.searchResultsController as! ResultsTableController
    resultsController.searchResult = filteredResults
    resultsController.tableView.reloadData()
}

// usual tableview methods

    override func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {

        if resultsTableController.searchResult.count > 0 {
        selectedCompany = resultsTableController.searchResult[index]
        //do something with selected company
        navigationController?.popViewControllerAnimated(true)
        return
     }
     //
     selectedCompany = allCompanies[index]
      navigationController?.popViewControllerAnimated(true)

}

deinit {
    println("MainTableView deinit")
}

ResultTableController.swift

class ResultsTableController:UITableViewController {

     var searchResult = [String]()

    override func viewDidLoad() {
        super.viewDidLoad()
        tableView.registerClass(UITableViewCell.self, forCellReuseIdentifier: "cell")
     }

    override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {

        return searchResult.count
    }

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

        let cell = tableView.dequeueReusableCellWithIdentifier("cell", forIndexPath: indexPath) as! UITableViewCell
        let index = indexPath.row
        cell.textLabel?.font = UIFont(name: "Avenir-Roman", size: 16)
        cell.textLabel?.text = searchResult[index].description
        return cell

    }

    deinit {
        println("ResultTableController deinit")
    }
}

2 个答案:

答案 0 :(得分:6)

嘿,我今天遇到了这个问题 显然我需要强制解除searchController来解决保留问题

  override func viewWillDisappear(animated: Bool) {
    super.viewWillDisappear(animated)
    searchController?.dismissViewControllerAnimated(false, completion: nil)
  }

这是我的示例项目 https://www.dropbox.com/s/zzs0m4n9maxd2u5/TestSearch.zip?dl=0

答案 1 :(得分:3)

解决方案似乎在某些时候在UISearchController上调用dismissViewControllerAnimated。大多数人可能不这样做,因为UISearchController在某种程度上是与托管UISearchController的视图控制器相关的实现细节。

我的解决方案似乎无论你如何展示你的搜索UI(标准存在或弹出窗口),都是在检查视图控制器是否不再显示之后从主机的viewDidDisappear调用searchController.dismissViewControllerAnimated()被提出。这可以捕获所有情况,尤其是用户点击弹出窗口以自动关闭UI的popover情况,或者仅仅因为您将其他内容推送到导航堆栈而导致搜索UI消失的情况。在后一种情况下,您不想关闭UISearchController。

override func viewDidDisappear(animated: Bool)
{
    super.viewDidDisappear(animated)

    if presentingViewController == nil
    {
        searchController.dismissViewControllerAnimated(false, completion: nil)
    }
}