【问题标题】:iOS Swift - Custom UITableViewCell not working with tab bariOS Swift - 自定义 UITableViewCell 不适用于标签栏
【发布时间】:2014-07-04 07:53:14
【问题描述】:

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

这是我的自定义单元类:

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

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

这是视图控制器:

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
    }
}

【问题讨论】:

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

标签: ios uitableview swift uitabbar


【解决方案1】:

你必须使用 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;
        }
    }

【讨论】:

    猜你喜欢
    • 1970-01-01
    • 2015-10-16
    • 1970-01-01
    • 2012-05-07
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    • 1970-01-01
    相关资源
    最近更新 更多