gpt4 book ai didi

uitableview - iOS Swift - 使用搜索栏和搜索显示过滤具有自定义单元格的 UITableView 的内容

转载 作者:搜寻专家 更新时间:2023-10-31 19:31:30 25 4
gpt4 key购买 nike

我在 iPhone 的 Swift 项目中遇到搜索栏和搜索显示的问题。我向 View 添加了一个带有自定义单元格的 UITableView。 Cell 的 Indetifier 设置为“QuestionCell”,Class 设置为“QuestionCellTableViewCell”。我向该单元格添加了两个标签,并将标签的导出添加到单元格类。我的目标是过滤 UITableView 的内容。

这是我的 View Controller :DomandeViewController.swift

import UIKit

class DomandeViewController: UIViewController, UITableViewDataSource, UITableViewDelegate, UISearchDisplayDelegate, UISearchBarDelegate {

var arrayDomande = [Domanda]()
var areaDomande: Area = Area()
var argomentoDomande: Argomento = Argomento()
var domandeFiltrate = [Domanda]()

@IBOutlet weak var questionTableView: UITableView!

override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
arrayDomande = ModelManager.instance.getQuestionsWithArguments(inAreaId: areaDomande.id, aboutId: argomentoDomande.id)
self.searchDisplayController!.searchResultsTableView.registerClass(QuestionCellTableViewCell.classForCoder(), forCellReuseIdentifier: "QuestionCell")
}

func numberOfSectionsInTableView(tableView: UITableView) -> Int {
if(tableView == self.searchDisplayController!.searchResultsTableView){
return 1
}else{
return 1
}
}

func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
if tableView == self.searchDisplayController!.searchResultsTableView {
return domandeFiltrate.count
} else {
return arrayDomande.count
}
}

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

var cell = tableView.dequeueReusableCellWithIdentifier("QuestionCell") as QuestionCellTableViewCell

var domanda = Domanda()

if tableView == searchDisplayController!.searchResultsTableView {
domanda = domandeFiltrate[indexPath.row]
} else {
domanda = arrayDomande[indexPath.row]
}

cell.testoLabel.text = domanda.testo
cell.numeroLabel.text = String(domanda.numero)

return cell
}

func filterContentForSearchText(searchText: String) {
// Filter the array using the filter method
filteredDomande = arrayDomande.filter({( domanda: Domanda) -> Bool in
let stringMatch = domanda.testo.rangeOfString(searchText)
return stringMatch != nil
})
}

func searchDisplayController(controller: UISearchDisplayController, shouldReloadTableForSearchString searchString: String!) -> Bool {
self.filterContentForSearchText(searchString)
return true
}
}

这是我的QuestionCellTableViewCell.swift

import UIKit

class QuestionCellTableViewCell: UITableViewCell {

@IBOutlet weak var testoLabel: UILabel!
@IBOutlet weak var numeroLabel: UILabel!


override func awakeFromNib() {
super.awakeFromNib()
// Initialization code
}

override func setSelected(selected: Bool, animated: Bool) {
super.setSelected(selected, animated: animated)

// Configure the view for the selected state
}

}

这是我的 Domanda.swift

import UIKit

class Domanda: NSObject {
var numero: Int = Int()
var testo: String = String()
var preferita: Bool = Bool()
var visualizzato: Int = Int()
var area: Int = Int()
var argomento: Int = Int()
}

一切正常,直到我在搜索栏中搜索字符串:应用程序崩溃并且控制台返回:

"fatal error: unexpectedly found nil while unwrapping an Optional value"

通过调试,我看到“cell”存在,但它的 socket (testoLabel 和 numeroLabel)为零,因此应用程序崩溃了

cell.testoLabel.text = domanda.testo

如果我在 viewDidLoad() 中移除

self.searchDisplayController!.searchResultsTableView.registerClass(QuestionCellTableViewCell.classForCoder(), forCellReuseIdentifier: "QuestionCell")

当在搜索栏中输入一些文本时应用程序崩溃,执行时出现相同的错误

var cell = tableView.dequeueReusableCellWithIdentifier("QuestionCell") as QuestionCellTableViewCell

如果我在 viewDidLoad() 中添加

self.questionTableView.registerClass(QuestionCellTableViewCell.classForCoder(), forCellReuseIdentifier: "QuestionCell")

应用程序在 cell.testoLabel.text 处不断崩溃,但这次是在启动时。

对我有什么建议?非常感谢,感谢您的帮助!

安德里亚

编辑:

今天我做了其他测试,结果如下:如果我将 searchResultsTableView 的单元格用作基本单元格,一切正常,但如果我尝试使用自定义单元格的导出,应用程序就会崩溃。这是工作代码:

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

var cell = tableView.dequeueReusableCellWithIdentifier("QuestionCell") as QuestionCellTableViewCell
var domanda = Domanda()

if tableView == self.searchDisplayController!.searchResultsTableView {
domanda = filteredDomande[indexPath.row]

cell.textLabel.text = domanda.testo
} else {
domanda = arrayDomande[indexPath.row]

cell.testoLabel.text = domanda.testo
cell.numeroLabel.text = String(domanda.numero)
}

return cell
}

最后我似乎无法将我的自定义单元格与 searchResultsTableView 一起使用。我的错误在哪里?再次感谢您!

最佳答案

终于找到解决办法了。我在我的项目中添加了一个新的用户界面空文件,然后我在这个新的 nib 文件中创建了一个单元格,并将我的自定义单元格类分配给它。在 Interface Builder 中,我将 questionTableView 的 Prototype Cells 设置为 0,然后我在 viewDidLoad() 中为 questionTableView 和 searchResultsTableView 注册了 Nib forCellReuseIdentifier。这是我的代码:

var cellIdentifier = "questionCell"

@IBOutlet weak var questionTableView: UITableView!

override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
arrayDomande = ModelManager.instance.getQuestionsWithArguments(inAreaId: areaDomande.id, aboutId: argomentoDomande.id)

var nib = UINib(nibName: "QuestionCellTableViewCell", bundle: nil)
self.searchDisplayController!.searchResultsTableView.registerNib(nib, forCellReuseIdentifier: cellIdentifier)
self.questionTableView.registerNib(nib, forCellReuseIdentifier: cellIdentifier)
}

func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
var cell: QuestionCellTableViewCell = tableView.dequeueReusableCellWithIdentifier(cellIdentifier) as QuestionCellTableViewCell
var domanda = Domanda()

if tableView == self.searchDisplayController!.searchResultsTableView {
domanda = filteredDomande[indexPath.row]
} else {
domanda = arrayDomande[indexPath.row]
}
cell.testoLabel.text = domanda.testo
cell.numeroLabel.text = String(domanda.numero)

return cell
}

关于uitableview - iOS Swift - 使用搜索栏和搜索显示过滤具有自定义单元格的 UITableView 的内容,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/27195396/

25 4 0
Copyright 2021 - 2024 cfsdn All Rights Reserved 蜀ICP备2022000587号
广告合作:1813099741@qq.com 6ren.com