21
22

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 5 years have passed since last update.

UITableViewとかUITableViewControllerの使い方メモ+UITableViewCellのxibとかstoryboardのメモ

Last updated at Posted at 2016-08-07

storyboard も使い慣れていなければ、xibでのUI作成もイマイチよくわかっていない。
何度か使用している UITableView だが、何度か調べてみても色々なやり方があって理解できていない。
これを機にちょっとまとめてみようと思ったのがこの記事のキッカケ。

  • ViewContoroller
    • UIViewController を使う場合
    • UITableViewController を使う場合
  • UITableViewCell
    • xib で UITableViewCell を作る場合
    • storyboard 上で UITableViewCell を貼り付ける場合

この辺が自分の中であまり理解できていない

storyboard(UIViewController, UITableView) + xib(UITableViewCell)

(個人的によく利用しているやり方)

完成イメージ

Projectディレクトリ の状態

storyboard の状態

ViewController の準備

  1. Storyboard を開いて UITableViewViewController に貼り付ける
  2. UITableViewViewController.swift に Outlet で紐付ける

UITableViewCell の準備

  1. TableViewCell.swift と TableViewCell.xib の作成
    1. メニューバー -> File -> New... -> iOS - Source - Cocoa Touch Class を選択
    2. Subclass of:UITableViewCell を選択
    3. Also create XIB file にチェックを入れて作成
  2. XIB を開いて適当に UILabel でも貼り付ける
  3. UILabelTableViewCell.swift に Outlet で紐付ける
  4. Identifier を設定する

20160807143025.png

ViewController.swift の実装

ViewController.swift
// UITableViewDataSource と UITableViewDelegate を実装
class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {

    @IBOutlet weak var tableView: UITableView!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.

        // XIBファイルからUINibのインスタンスを生成
        let nib = UINib(nibName: "TableViewCell", bundle: nil)
        // UITableViewにXIBファイルを登録
        tableView.registerNib(nib, forCellReuseIdentifier: "Cell")
        tableView.delegate = self
        tableView.dataSource = self
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
    
    // MARK : UITableViewDataSource
    
    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // とりあえず適当に10個のセルを用意
        return 10
    }
    
    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath) as! TableViewCell
        cell.label.text = "Cell No." + String(indexPath.row)
        return cell
    }
    
    // MARK : UITableViewDelegate
    
    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
        let cell = self.tableView(tableView, cellForRowAtIndexPath: indexPath) as! TableViewCell
        print(cell.label.text)
    }
}

storyboard(UIViewController, UITableView + UITableViewCell)

(まとめる上で理解しようと思って試してみた)

完成イメージ

Projectディレクトリ の状態

※ storyboard 上で UITableViewCell のUIを扱うので xib が不要になった

storyboard の状態

ViewController の準備

  1. Storyboard を開いて UITableViewViewController に貼り付ける
  2. UITableViewCell を UITableView に貼り付ける
  3. UITableViewViewController.swift に Outlet で紐付ける

UITableViewCell の準備

  1. Identifier を設定する

20160807143025.png

ViewController.swift の実装

ViewController.swift
// UITableViewDataSource と UITableViewDelegate を実装
class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate {

    @IBOutlet weak var tableView: UITableView!
    
    override func viewDidLoad() {
        super.viewDidLoad()
        // Do any additional setup after loading the view, typically from a nib.
        tableView.delegate = self
        tableView.dataSource = self
    }

    override func didReceiveMemoryWarning() {
        super.didReceiveMemoryWarning()
        // Dispose of any resources that can be recreated.
    }
    
    // MARK : UITableViewDataSource
    
    func tableView(tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        // とりあえず適当に10個のセルを用意
        return 10
    }
    
    func tableView(tableView: UITableView, cellForRowAtIndexPath indexPath: NSIndexPath) -> UITableViewCell {
        let cell = tableView.dequeueReusableCellWithIdentifier("Cell", forIndexPath: indexPath)
        cell.textLabel.text = "Cell No." + String(indexPath.row)
        return cell
    }
    
    // MARK : UITableViewDelegate
    
    func tableView(tableView: UITableView, didSelectRowAtIndexPath indexPath: NSIndexPath) {
        let cell = self.tableView(tableView, cellForRowAtIndexPath: indexPath)
        print(cell.textLabel.text)
    }
}

気づいたこと

  • UITableViewCellには textLabel という UILabel がデフォルトで居た・・・
  • storyboard(UIViewController, UITableView) + xib(UITableViewCell) のようにカスタムセルにしたい場合は TableViewCell.xib は不要になるが TableViewCell.swift は必要でとなって storyboard 上の UITableViewCell に紐付けてあげれば良いのか・・・

UITableViewController で作成

(個人的にイマイチ理解していなかったやり方)

上記2つの方法の後に UITableViewController を storyboard 上に貼り付けて理解した
ただの UIViewController + UITableView + UITableView で2番目の構成と同じだった

ひとつ違うのは UITableViewController 専用のメソッドが切られていること

UIKit/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?
}

まとめ

storyboard だったり xib だったり、自動で色々付いてる UITableViewController だったり、
なかなか取っ付き難い感はあるけど、Qiitaの場を借りてちゃんとまとめてみたら理解が進んだ。

21
22
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
21
22

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?