Ios 搜索自定义表视图单元格无效,返回nil
我有一个UIViewController,它充当TableViewController,最上面是搜索栏。搜索栏中的搜索应该过滤它正在执行的数组中的结果,尽管我有一个自定义单元格,我想使用它,但它返回nullIos 搜索自定义表视图单元格无效,返回nil,ios,swift,uitableview,swift3,uisearchbar,Ios,Swift,Uitableview,Swift3,Uisearchbar,我有一个UIViewController,它充当TableViewController,最上面是搜索栏。搜索栏中的搜索应该过滤它正在执行的数组中的结果,尽管我有一个自定义单元格,我想使用它,但它返回null import UIKit class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, UISearchResultsUpdating { @IBOutlet var tab
import UIKit
class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, UISearchResultsUpdating {
@IBOutlet var tableView: UITableView!
@IBOutlet weak var searchBar: UISearchBar!
struct Cake {
var name = String()
var type = String()
}
var cakes = [Cake(name: "avocado", type: "fruit"),
Cake(name: "blueberry", type: "fruit"),
Cake(name: "swerve", type: "sweetener")]
var isSearching = false
let searchController = UISearchController(searchResultsController: nil)
var filteredCakes = [Cake]()
//var filteredFoodIDescArray = [String]()
//var filteredFoodImgArray = [String]()
override func viewDidLoad() {
super.viewDidLoad()
filteredCakes = cakes
searchController.searchResultsUpdater = self
searchController.dimsBackgroundDuringPresentation = false
definesPresentationContext = true
tableView.tableHeaderView = searchController.searchBar
self.tableView.register(ViewControllerTableViewCell.self, forCellReuseIdentifier: "cell")
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return self.filteredCakes.count
}
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
//let cell: UITableViewCell = UITableViewCell(style: UITableViewCellStyle.subtitle, reuseIdentifier: "cell")
var cell = self.tableView!.dequeueReusableCell(withIdentifier: "cell") as! ViewControllerTableViewCell
//cell.foodItemTitle.text = self.filteredCakes[indexPath.row].name
cell.detailTextLabel?.text = self.filteredCakes[indexPath.row].name
//cell.detailTextLabel?.text = self.filteredCakes[indexPath.row].size
return cell
}
func updateSearchResults(for searchController: UISearchController) {
// If we haven't typed anything into the search bar then do not filter the results
if searchController.searchBar.text! == "" {
filteredCakes = cakes
} else {
// Filter the results
filteredCakes = cakes.filter { $0.name.lowercased().contains(searchController.searchBar.text!.lowercased()) }
}
self.tableView.reloadData()
}
}
获取一个编译错误,其中显示:UIType“UITableViewCell”的值在此行中没有成员“foodItemTitle”:cell.foodItemTitle.text=self.filteredCakes[indexPath.row]。name
class ViewControllerTableViewCell: UITableViewCell {
@IBOutlet weak var foodItemTitle: UILabel!
@IBOutlet weak var foodItemDesc: UILabel!
@IBOutlet weak var foodItemImg: UIImageView!
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
}
}
它返回致命错误:在cell.foodItemTitle.text=self.filteredCakes[indexath.row].name上展开可选值时意外发现nil
。如果我使用UITableViewCell而不是自定义单元格,它可以工作,但在其他情况下不能
我如何声明我的自定义单元格,使我能够从ViewControllerTableViewCell
实际分配文本标签?您首先需要获取ViewControllerTableViewCell的nib
let nib = UINib(nibName: "YOUR_CUSTOM_CELL_NIB_NAME", bundle: nil)
tableView.register(nib, forCellReuseIdentifier: "YOUR_CUSTOM_CELL_ID")
唯一可以强制展开的地方是这行代码cell.foodItemTitle.text
。您正在将您的foodItemTitle
声明为UILabel代码>
确保将自定义类名设置为故事板上的自定义单元格,然后像这样正确连接它们
当您使用原型单元时,无需在表格视图
中注册该单元,它将自动注册该表格视图
。因此,只需从viewDidLoad
中删除寄存器
代码,就可以开始了
删除此行:
self.tableView.register(ViewControllerTableViewCell.self, forCellReuseIdentifier: "cell")
foodItemTitle
标签是否连接到情节提要?如果连接正确,则应填写其左侧的圆圈。还应确保filteredCakes
按住任何键values@nathan是的,它在里面ViewController@fscore但是它在故事板中是连接的吗?如果连接被删除,将导致您遇到问题。仔细检查@IBOutlet
左侧的小圆圈是否已填充。@nathan是的,我刚刚检查了它在情节提要中是否已连接这在使用情节提要时是不必要的。