iOS Swift-自定义UITableViewCell不使用选项卡栏

iOS Swift-自定义UITableViewCell不使用选项卡栏,ios,uitableview,swift,uitabbar,Ios,Uitableview,Swift,Uitabbar,我正在尝试使用Swift创建带有自定义单元格的表视图。同样的代码也适用于单页应用程序,但在基于选项卡的应用程序中,它在表视图内容上添加了一个灰色层 这是我的自定义单元格类: class CardCell:UITableViewCell { @IBOutlet var backImg: UIImageView! @IBOutlet var testButton: UIButton! func loadItem(var title:String) { bac

我正在尝试使用Swift创建带有自定义单元格的表视图。同样的代码也适用于单页应用程序,但在基于选项卡的应用程序中,它在表视图内容上添加了一个灰色层

这是我的自定义单元格类:

class CardCell:UITableViewCell {
    @IBOutlet var backImg: UIImageView!
    @IBOutlet var testButton: UIButton!

    func loadItem(var title:String) {
        backImg.image = UIImage(named: title)
    }
}
以下是viewController:

class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource {

    var items = ["swift 1.jpeg", "swift 2.jpeg"]

    @IBOutlet var tableView:UITableView!

    override func viewDidLoad() {
        super.viewDidLoad()
        var nib = UINib(nibName: "CardCell", bundle: nil)
        tableView.registerNib(nib, forCellReuseIdentifier: "CardCell")
    }

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

    func tableView(tableView: UITableView!, cellForRowAtIndexPath indexPath: NSIndexPath!) -> UITableViewCell! {
        var cell:CardCell = tableView.dequeueReusableCellWithIdentifier("CardCell") as CardCell
        var (title) = items[indexPath.row]
        cell.loadItem(title)
        return cell
    }
}

您必须使用UiTableViewController类,这样更好。 如果必须使用UiView控制器,则:

import UIKit
import QuartzCore

class OthersViewController: UIViewController, UITableViewDelegate, UITableViewDataSource, MFMailComposeViewControllerDelegate {

    /*init(nibName nibNameOrNil: String?, bundle nibBundleOrNil: NSBundle?) {
        super.init(nibName: nibNameOrNil, bundle: nibBundleOrNil)
        // Custom initialization
    }*/

    let arrData = ["Row 1","Row 2","Row 3","Row 4","Row 5"];
    let dict = NSMutableDictionary()
    let arrImage = ["image 1","image 2","image 3","image 4","image 5","image 6"];
    let kLCellIdentifier = "CellIdentifier"
    var tblVc = UITableView();

    override func viewDidLoad() {
        dict.setObject(arrData, forKey: "dsd")

        super.viewDidLoad()
        self.title = "Others"
        self.view.backgroundColor = UIColor.clearColor()
        tblVc.frame = CGRectMake(0, 0, self.view.frame.size.width, self.view.frame.size.height)
        tblVc.delegate = self;
        tblVc.dataSource = self;
        tblVc.tableFooterView = UIView(frame: CGRectMake(0, 0, self.view.frame.size.width, 0))
        tblVc.backgroundColor = UIColor.clearColor();
        tblVc.separatorColor = UIColor.redColor();
        self.view.addSubview(tblVc);

        // Do any additional setup after loading the view.
    }

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

    func tableView(tableView: UITableView!, cellForRowAtIndexPath indexPath: NSIndexPath!) -> UITableViewCell!{
        var cell = tableView.dequeueReusableCellWithIdentifier(kLCellIdentifier) as UITableViewCell!
        if !cell {
            cell = UITableViewCell(style:.Default, reuseIdentifier: kLCellIdentifier)
        }

        cell.backgroundColor = UIColor.clearColor()
        cell.textLabel.text = arrData[indexPath.row]
        cell.image = UIImage(named: "\(arrImage[indexPath.row])");

        cell.accessoryType  = UITableViewCellAccessoryType.DisclosureIndicator;
        cell.selectionStyle = UITableViewCellSelectionStyle.None;

        return cell;
    }
    func tableView(tableView: UITableView!, heightForRowAtIndexPath indexPath: NSIndexPath!) -> CGFloat
    {
        return 60;
    }
    func tableView(tableView: UITableView!, didSelectRowAtIndexPath indexPath: NSIndexPath!) {
        switch (indexPath.row) {
        case 0:
        break;
        case 1:

            break;
        case 2:
            break;
        case 3:
            break;
        case 4:
        case 5:
            break;
        default:
            break;
        }
    }

试试这个:
self.tableView.registerClass(UITableViewCell.self,forCellReuseIdentifier:“CardCell”)
我有一个类似的问题,只需在情节提要中调整原型单元的大小就可以解决。这似乎是一个错误。不确定这是否是您遇到的问题,但值得一试。