iOS:'MyViewController'不符合协议'UITableViewDataSource'

  • 我是IOS swift开发新手。 我曾经使用以前的Xcode 6 beta

  • 我已经下载的Xcode 6.0.1 ,我不能得到这个工作Xcode Version: 6.0.1

  • 当我尝试运行示例时,仍然收到“ MyViewController ”未确认协议“ UITableViewDataSource ”。

有人可以帮帮我吗? 我已经经历了这个网站上的其他问题,并添加了“ UITableViewDataSource ”所需的所有function;


 import UIKit import Foundation class MyViewController: UIViewController, UITableViewDelegate, UITableViewDataSource { var array1:[String] = ["one","two","three","four"] var array2:[String] = ["IOS","Android","java","c++","Swift"] let sectionCount = 2 var myTableView:UITableView! // init(nibName nibNameOrNil: String?, bundle nibBundleOrNil: NSBundle?) { // var rect = CGRectMake(0, 0, 220, 320) // myTableView = UITableView(frame: rect, style: UITableViewStyle.Grouped) // super.init(nibName: nil, bundle: nil) // // Custom initialization // } override func viewDidLoad() { super.viewDidLoad() var rect = CGRectMake(0, 0, 320, 600) myTableView = UITableView(frame: rect, style: UITableViewStyle.Grouped) myTableView!.delegate = self myTableView!.dataSource = self self.view.addSubview(myTableView) } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() // Dispose of any resources that can be recreated. } //dataSourrce //tableview:tableview,section: func tableView(tableView: UITableView!, numberOfRowsInSection section: Int) -> Int{ switch section{ case 0: return array1.count case 1: return array2.count default: return 1 } } func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { //func tableView(tableView: UITableView!, cellForRowAtIndexPath indexPath: NSIndexPath!) -> UITableViewCell!{ //---cellstart---- let identifier = "identifier" // var cell:UITableViewCell //cell var cell = tableView.dequeueReusableCellWithIdentifier(identifier) as? MyCell if cell == nil { // cell = UITableViewCell(style: UITableViewCellStyle.Subtitle, reuseIdentifier: identifier) cell = MyCell(style: UITableViewCellStyle.Subtitle, reuseIdentifier: identifier) } //---cellend---- switch indexPath.section{ case 0: // cell!.textLabel.text = array1[indexPath.row] cell!.myLable!.text = array1[indexPath.row] case 1: // cell!.textLabel.text = array2[indexPath.row] cell!.myLable!.text = array2[indexPath.row] default: println() } var image = UIImage(named: "images/qq.png") // cell!.imageView.image = image cell!.myImageView!.image = image // cell!.detailTextLabel.text = "\(indexPath.section)\(indexPath.row) return cell! } //dataSourrce func numberOfSectionsInTableView(tableView: UITableView!) -> Int { return sectionCount } func tableView(tableView: UITableView, titleForHeaderInSection section: Int) -> String? { var title:String? = nil switch section { case 0: title = "Num" case 1: title = "Prog" default: title = nil } return title } func tableView(tableView: UITableView, didDeselectRowAtIndexPath indexPath: NSIndexPath) { println("Test\(indexPath.section) \(indexPath.row)") } func tableView(tableView: UITableView, heightForRowAtIndexPath indexPath: NSIndexPath) -> CGFloat { return 60.0 } func numberOfComponentsInPickerView(pickerView: UIPickerView!) -> Int {} func pickerView(pickerView: UIPickerView!,numberOfRowsInComponent component: Int) -> Int{} func pageViewController(pageViewController: UIPageViewController, viewControllerBeforeViewController viewController: UIViewController) -> UIViewController?{ } func pageViewController(pageViewController: UIPageViewController, viewControllerAfterViewController viewController: UIViewController) -> UIViewController?{ } } 

*****************我的单元类****************************** *****

 import Foundation import UIKit class MyCell: UITableViewCell { let indetifier:String = "indetifier" var myLable:UILabel? var myImageView:UIImageView? override init(style: UITableViewCellStyle, reuseIdentifier: String!) { super.init(style: .Subtitle, reuseIdentifier: indetifier) var rect = CGRectMake(10, 0, 60, 30) self.myLable = UILabel() self.myLable!.frame = rect self.myLable!.textColor = UIColor.redColor() self.contentView.addSubview(self.myLable!) var imageRect = CGRectMake(160, 10, 40, 40) self.myImageView = UIImageView() self.myImageView!.frame = imageRect self.contentView.addSubview(self.myImageView!) } required init(coder aDecoder: NSCoder) { fatalError("init(coder:) has not been implemented") } } 

你需要看看整个错误信息。 此特定消息包含有关缺less哪些方法的其他信息:

 Type 'MyViewController' does not conform to protocol 'UITableViewDataSource' Protocol requires function 'tableView(_:numberOfRowsInSection:)' with type '(UITableView, numberOfRowsInSection: Int) -> Int' Candidate has non-matching type '(UITableView!, numberOfRowsInSection: Int) -> Int' 

所以…你的numberOfRowsInSection需要一个可选的UITableView,并且需要一个必需的UITableView(这是他们在6和6.1之间进行的更改,所有UITableView委托和数据源方法现在都需要tableView和indexPath值)

试试这个简单的解决

 import UIKit class HomeViewController: UIViewController, UITableViewDelegate, UITableViewDataSource { //MARK: - Life Cycle override func viewDidLoad() { super.viewDidLoad() } override func didReceiveMemoryWarning() { super.didReceiveMemoryWarning() } //MARK: - Tableview Delegate & Datasource func tableView(tableView:UITableView, numberOfRowsInSection section:Int) -> Int { return 10 } func numberOfSectionsInTableView(tableView: UITableView) -> Int { return 1 } func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell { let cell: UITableViewCell = UITableViewCell(style: UITableViewCellStyle.Subtitle, reuseIdentifier: "MyTestCell") return cell } func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { } } 
 class ROTableView: UITableView, UITableViewDelegate { func tableView(tableView:UITableView!, numberOfRowsInSection section:Int) -> Int { return 10 } func tableView(tableView:UITableView!, cellForRowAtIndexPath indexPath:NSIndexPath!) -> UITableViewCell! { let cell: UITableViewCell = UITableViewCell(style: UITableViewCellStyle.Subtitle, reuseIdentifier: "MyTestCell") // cell.text = "Row #\(indexPath.row)" // cell.detailTextLabel.text = "Subtitle #\(indexPath.row)" return cell } func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) { } } 

当你创buildUITableView的子类时,请参考上面的代码,你不会得到任何错误。

对我来说,从inheritance的类列表中删除UITableViewDataSource修复了这个问题