Rumah > Soal Jawab > teks badan
以下是我定义的自己的ViewController,继承了UITableViewController,教程指出我需要override重写tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int 和 tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell 两个方法,一个是定义行数,一个是获取可重用的cell。
import UIKit
class listViewController: UITableViewController {
override func viewDidLoad() {
super.viewDidLoad()
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
}
override func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
return 0;
}
override func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
let cell = tableView.dequeueReusableCellWithIdentifier("listItem", forIndexPath: indexPath)
return cell
}
}
我在Xcode中command点击进入继承的 UITableViewController 看了下:
@available(iOS 2.0, *)
public class UITableViewController : UIViewController, UITableViewDelegate, UITableViewDataSource {
public init(style: UITableViewStyle)
public init(nibName nibNameOrNil: String?, bundle nibBundleOrNil: NSBundle?)
public init?(coder aDecoder: NSCoder)
public var tableView: UITableView!
@available(iOS 3.2, *)
public var clearsSelectionOnViewWillAppear: Bool // defaults to YES. If YES, any selection is cleared in viewWillAppear:
@available(iOS 6.0, *)
public var refreshControl: UIRefreshControl?
}
没有看到有tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int 和 tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell 两个方法,我知道这两个方式是UITableViewDataSource协议中定义的,看下面,我又点击进入UITableViewDataSource协议中看了下:
public protocol UITableViewDataSource : NSObjectProtocol {
@available(iOS 2.0, *)
public func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int
// Row display. Implementers should *always* try to reuse cells by setting each cell's reuseIdentifier and querying for available reusable cells with dequeueReusableCellWithIdentifier:
// Cell gets various attributes set automatically based on table (separators) and data source (accessory views, editing controls)
@available(iOS 2.0, *)
public func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell
@available(iOS 2.0, *)
optional public func numberOfSectionsInTableView(tableView: UITableView) -> Int // Default is 1 if not implemented
...以下省略...
我看到了这两个方法的定义,我不能理解的是:
教程要我用override重写tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int 和 tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell 两个方法。既然是用override那么就应该是重写了父类的存在方法,但是在UITableViewController中我没有看到这2个方法的定义?
在UITableViewDataSource中有定义,但是UITableViewDataSource是个协议,那么就是说这2个方法是必须要实现类来实现的,所以我想问这2个方式是在哪里实现的呢?
天蓬老师2017-04-17 17:37:03
Soalan pertama, mari lihat definisi UITableViewController
public class UITableViewController : UIViewController, UITableViewDelegate, UITableViewDataSource
Kelas ini telah diperlukan untuk melaksanakan protokol UITableViewDataSource, jadi mewarisi UITableViewController mesti mengatasi kedua-dua kaedah ini
Kedua, semua yang anda boleh lihat ialah antara muka UITableViewController, bukan keseluruhan kandungannya
伊谢尔伦2017-04-17 17:37:03
UITableViewController dan kawalan sistem lain yang anda gunakan telah dirangkumkan Apa yang anda lihat hanyalah fail .h, dan pelaksanaan khusus kaedah adalah dalam .m, jadi kedua-dua kaedah ini berada dalam
dilaksanakan dalam UITableView. m天蓬老师2017-04-17 17:37:03
Sekarang Swift adalah sumber terbuka, bolehkah fail UITableView.m dilihat? ? ? Memang, tetapi sekali lagi, subkelas juga boleh mengatasi kaedah protokol dalam kelas induk! Betul ke?