[XCode]SwiftでTableView動作サンプル
2019年7月4日 2019年7月9日
・動作環境
XCode 10 Swift 5
・手順
- プロジェクトを新規作成する。
- Main.Storyboardにオブジェクトを配置する。
- ViewControllerをコーディングする。
- 起動テストする。
1.プロジェクトを新規作成する。
data:image/s3,"s3://crabby-images/c517a/c517abc1fec541c63bd807959aae95c5e01c5685" alt=""
「Command+Shift+N」でプロジェクトを作成する。 テンプレートは「Single View Page」を選択してNext。
data:image/s3,"s3://crabby-images/23220/23220df8cce7a9ac4143146f72209354619ba875" alt=""
「Product Name」 ... にプロジェクト名を自由に入力する。今回は[sample_tableview] 「Team」 ... 設定済であれば任意で選択、未設定でも可。 「Organization Name」 ... 空白でも可。 「Organization Identifier」 ... 識別情報を入力する。一般的にドメイン名が入力される。
data:image/s3,"s3://crabby-images/8b43f/8b43fe8a987243763607575f3baaf792b5c7f843" alt=""
プロジェクトが作成される。この時赤いビックリマークのアイコンはプロジェクト作成時に「Team」を 設定していないためだが今回は気にせずに進める。
2.Main.Storyboardにオブジェクトを配置する。
data:image/s3,"s3://crabby-images/0d6ef/0d6ef18bd4430a0ad5d1870f59236582ac8394a3" alt=""
左側のファイル一覧から「Main.Storyboard」をクリックする。 Iphoneのレイアウト画面が表示される。
data:image/s3,"s3://crabby-images/67041/67041fd61e54eb3f814b63737f43b42e042e2525" alt=""
「Command+Shift+L」または画像の①をクリックするとパーツの一覧が表示される。 検索窓から配置したいオブジェクト名を入力すると絞られる。
data:image/s3,"s3://crabby-images/1f437/1f437f306e859e0faa8c2397adb7bbe8cd7a30b0" alt=""
「Table View」をIphoneの画面に向けてドラッグ&ドロップするとオブジェクトが配置される。 配置されたTableViewを画面いっぱいに広げる。
data:image/s3,"s3://crabby-images/5590a/5590a24af413064e747a91dc7025f4890d824d49" alt=""
配置したTableViewにOutletを設定する。 TableViewを選択した状態で右側メニューの右矢印のアイコンを選択する。画像①参照 Outletの「dataSource」と「delegate」を画像のようにViewControllerにドラッグ&ドロップで設定する。
data:image/s3,"s3://crabby-images/f0ec3/f0ec3d3d8ca11c5e9b1565f9a348555fe443ce20" alt=""
続いてテーブルにセルの値を設定するための「Table View Cell」を追加したTable Viewに向かってドラッグ&ドロップする。
data:image/s3,"s3://crabby-images/0f120/0f12025815c315f2022fad9c579df1037ab3e848" alt=""
配置したセルに「identifier」を設定する。今回は[cell]と入力している。 入力箇所が出ない、わからない場合は画像の順番にクリックすると一番右に入力フォームが表示される。
3.ViewControllerをコーディングする。
TableViewのOutletで設定したdataSourceとdelegateをソース上で利用する宣言をする。
// 変更前 class ViewController: UIViewController { } // 変更後 class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate { }
テーブルに表示させたい項目を宣言する。
class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate { // テーブルの中身を宣言 let prefs = ["東京", "大阪", "愛知", "福岡", "京都"] override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view. } }
セルの総数を返すデリゲートメソッドを実装する。これを実装しないとエラーになる。
// セルの総数を返す func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return prefs.count }
セルの中身を表示するデータソースメソッドを実装する。これも実装しないとエラーになる。
// セルの値を設定 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { // Main.storyboardのテーブルセルで設定した識別子を使う(今回は"cell") let cell: UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) // セルに表示する値を設定する cell.textLabel!.text = prefs[indexPath.row] return cell }
完成形のソースは下記になる。
import UIKit class ViewController: UIViewController, UITableViewDataSource, UITableViewDelegate { // テーブルの中身を宣言 let prefs = ["東京", "大阪", "愛知", "福岡", "京都"] override func viewDidLoad() { super.viewDidLoad() // Do any additional setup after loading the view. } // セルの総数を返す func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { return prefs.count } // セルの値を設定 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { // Main.storyboardのテーブルセルで設定した識別子を使う(今回は"cell") let cell: UITableViewCell = tableView.dequeueReusableCell(withIdentifier: "cell", for: indexPath) // セルに表示する値を設定する cell.textLabel!.text = prefs[indexPath.row] return cell } }
4.起動テストする。
「Command+B」でビルド後、エラーが出てなければ「Command+R」で実行する。
data:image/s3,"s3://crabby-images/d9aa3/d9aa34c1e47a795686fbfef99d47ba4ef0666ec6" alt=""
実行してもアプリが落ちる場合
テーブルセルで設定した識別子が間違っている或いはMain.storyboardでテーブルセルが未設定の可能がないかを確認。
以上で完了です。