カスタムクラスから呼び出されていない私は、私は基本的にUITable
を構築するカスタムクラスを作成しようとしているのXcode 7.0、スウィフト2cellForRowAtIndexPathは
を使用しています、そしてViewController
に私はの新しいオブジェクトを作りますテーブルを読み込み、それをself.viewにロードします。
問題は、カスタムクラス内から関数func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell
がまったく呼び出されていないことです。私は今3日間のソリューションを探していましたが、私はアプリケーションとコードを何度も再構築しようとしました。
ViewController.swiftファイルで同じコード(テーブルの作成に必要なものすべて、init関数などを除く)を使用しても問題ありません。
cellForRowAtIndexPath
関数で問題があることはわかっています。実行時にそのブロックに設定した文が表示されないためです。他のすべての関数が呼び出されますが、なんらかの理由で呼び出されていません。私はここで何か見落としているかどうかは分かりません。どんな助けもありがとう。前もって感謝します。
class sideTest: NSObject, UITableViewDelegate, UITableViewDataSource {
let tesTable: UITableView = UITableView()
var items: [String]?
var mView: UIView = UIView()
func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
print("The number of rows is: \(self.items!.count)")
return self.items!.count
}
func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
print("\nLets create some cells.")
let sCell: UITableViewCell = tableView.dequeueReusableCellWithIdentifier("cell") as UITableViewCell!
sCell.textLabel?.text = self.items![indexPath.row]
sCell.textLabel?.textColor = UIColor.darkTextColor()
return sCell
}
func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
print("You selected cell #\(indexPath.row)!")
}
func tblSetup() {
self.tesTable.frame = CGRectMake(0, 0, 320, mView.bounds.height)
self.tesTable.delegate = self
self.tesTable.dataSource = self
self.tesTable.backgroundColor = UIColor.cyanColor()
// load cells
self.tesTable.registerClass(UITableViewCell.self, forCellReuseIdentifier: "Cell")
self.tesTable.reloadData()
print("Currenlty in tblSetup.\nCurrent rows is: \(self.items!.count)")
}
//Init
override init() {
super.init()
self.items = nil
self.tblSetup()
}
init(sourceView: UIView , itemListAsArrayString: [String]) {
super.init()
self.items = itemListAsArrayString
self.mView = sourceView
self.tblSetup()
}
}
ここにはViewController.swiftのコードがあります。私は手動で行うことにより、セルの情報を入力した場合でも、テーブルが構築されることを注意しないが、細胞が移入しないでください:sCell.textLabel?.text = "test cell"
class ViewController: UIViewController {
override func viewDidLoad() {
super.viewDidLoad()
// Do any additional setup after loading the view, typically from a nib.
let myTable: sideTest = sideTest(sourceView: self.view, itemListAsArrayString: ["Cell 1", "Cell 2", "Cell 3"])
self.view.addSubview(myTable.tesTable)
}
override func didReceiveMemoryWarning() {
super.didReceiveMemoryWarning()
// Dispose of any resources that can be recreated.
}
}
ここでも、任意のヘルプは大歓迎です。ありがとう。
'init(フレームフレーム:CGRect、スタイルスタイル:UITableViewStyle)'である 'UITableView'の指定された初期化子を使うべきですが、これが違いを生み出すかどうかは分かりません。 – Sulthan
クラスはテーブルビューのデータソースとして設定されていますか? – quellish