コンテンツへスキップ

【Swift】UITableViewを使ってみる

よく使われるUITableViewの基本的な利用方法

UITableViewの基本的な使い方

Stroyboardを使わずにコードのみ、オートレイアウトもコードで行っています

class ViewController: UIViewController {

    var tableView:UITableView!
    
    let items:[String] = [
        "Cell 1",
        "Cell 2",
        "Cell 3",
        "Cell 4",
        "Cell 5",
    ]
    
    override func viewDidLoad() {
        super.viewDidLoad()

        self.tableView = UITableView()
        self.tableView.delegate = self
        self.tableView.dataSource = self
        self.tableView.translatesAutoresizingMaskIntoConstraints = false
        self.view.addSubview(tableView)
        self.tableView.topAnchor.constraint(equalTo: self.view.topAnchor).isActive = true
        self.tableView.leadingAnchor.constraint(equalTo: self.view.leadingAnchor).isActive = true
        self.tableView.trailingAnchor.constraint(equalTo: self.view.trailingAnchor).isActive = true
        self.tableView.bottomAnchor.constraint(equalTo: self.view.bottomAnchor).isActive = true
        
    }
}

extension ViewController : UITableViewDelegate , UITableViewDataSource {
    func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell {
        let cell = UITableViewCell(style: .value1, reuseIdentifier: "cell")
        cell.textLabel?.text = self.items[indexPath.row]
        cell.detailTextLabel?.text = indexPath.row.description
        return cell
    }
    
    func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int {
        return self.items.count
    }
}

これを実行すると下記のような画面が表示されます

TableViewのセルをタップして検出する

セルのタップを検出するにはDelegateに下記を追加します

    func tableView(_ tableView: UITableView, didSelectRowAt indexPath: IndexPath) {
        print("セル\(indexPath)をタップ")
    }

タップされると上記が実行されます

UITableViewの基本的な使い方は以上です