Warning: file_get_contents(/data/phpspider/zhask/data//catemap/9/ios/116.json): failed to open stream: No such file or directory in /data/phpspider/zhask/libs/function.php on line 167

Warning: Invalid argument supplied for foreach() in /data/phpspider/zhask/libs/tag.function.php on line 1116

Notice: Undefined index: in /data/phpspider/zhask/libs/function.php on line 180

Warning: array_chunk() expects parameter 1 to be array, null given in /data/phpspider/zhask/libs/function.php on line 181
Ios 搜索自定义表视图单元格无效,返回nil_Ios_Swift_Uitableview_Swift3_Uisearchbar - Fatal编程技术网

Ios 搜索自定义表视图单元格无效,返回nil

Ios 搜索自定义表视图单元格无效,返回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

我有一个UIViewController,它充当TableViewController,最上面是搜索栏。搜索栏中的搜索应该过滤它正在执行的数组中的结果,尽管我有一个自定义单元格,我想使用它,但它返回null

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是的,我刚刚检查了它在情节提要中是否已连接这在使用情节提要时是不必要的。