質問をすることでしか得られない、回答やアドバイスがある。

15分調べてもわからないことは、質問しよう!

新規登録して質問してみよう
ただいま回答率
85.35%
iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

Q&A

解決済

1回答

1599閲覧

カスタムセル内のボタンをタップするとボタンのタイトルが変わる

vlb

総合スコア109

iOS

iOSとは、Apple製のスマートフォンであるiPhoneやタブレット端末のiPadに搭載しているオペレーションシステム(OS)です。その他にもiPod touch・Apple TVにも搭載されています。

Xcode

Xcodeはソフトウェア開発のための、Appleの統合開発環境です。Mac OSXに付随するかたちで配布されています。

Swift

Swiftは、アップルのiOSおよびOS Xのためのプログラミング言語で、Objective-CやObjective-C++と共存することが意図されています

0グッド

0クリップ

投稿2020/03/24 14:26

やりたいこと

下の写真のようにカスタムセルにボタンを配置し,そのボタンをタップするとタップしたボタンのタイトルを変更したい.

イメージ説明

現在のコード

CustomTableViewCell.swift

Swift

1import UIKit 2 3class CustomTableViewCell: UITableViewCell { 4 5 //"A面"or"B面" 6 @IBOutlet weak var button: UIButton! 7 8 override func awakeFromNib() { 9 super.awakeFromNib() 10 } 11 12 override func setSelected(_ selected: Bool, animated: Bool) { 13 super.setSelected(selected, animated: animated) 14 } 15}

ViewController.swift

Swift

1import UIKit 2 3class ViewController: UIViewController, UITableViewDelegate, UITableViewDataSource { 4 5 //tableViewのインスタンス 6 @IBOutlet weak var tableView: UITableView! 7 //"A面"か"B面"か判断するためのフラグ 8 var array: [String] = [] 9 10 override func viewDidLoad() { 11 super.viewDidLoad() 12 self.tableView.delegate = self 13 self.tableView.dataSource = self 14 //初期値は全てのセルが"A面" 15 self.array = Array(repeating: "A面", count: 50) 16 } 17 18 19 func tableView(_ tableView: UITableView, numberOfRowsInSection section: Int) -> Int { 20 return self.array.count 21 } 22 23 24 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 25 guard let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as? CustomTableViewCell else { 26 return UITableViewCell() 27 } 28 return cell 29 } 30 31 32 @IBAction func tapButton(_ sender: UIButton) { 33 //タップされたボタンのあるセルを取得 34 let cell = sender.superview?.superview as! CustomTableViewCell 35 //タップされたボタンのあるセルの位置を取得 36 guard let row = self.tableView.indexPath(for: cell)?.row else { 37 print("Error") 38 return 39 } 40 switch self.array[row] { 41 case "A面": 42 //タップされたボタンが"A面"であればフラグを"B面"にする 43 self.array[row] = "B面" 44 DispatchQueue.main.async { 45 //タイトルの変更 46 cell.button.setTitle("B面", for: .normal) 47 } 48 default: 49 //タップされたボタンが"B面"であればフラグを"A面"にする 50 self.array[row] = "A面" 51 DispatchQueue.main.async { 52 //タイトルの変更 53 cell.button.setTitle("A面", for: .normal) 54 } 55 } 56 } 57}

問題点

上記のコードでは選択したボタン以外のボタンのタイトルも変更されてしまいます.
多分セルの再利用の観点から問題が生じているのかと思いますが,解決策がわかりません.
具体的にコードで修正していただける方,よろしくお願いいたします.

環境

xcode : ver11.3.1
swift : ver5.1.3
ios : 13.2

気になる質問をクリップする

クリップした質問は、後からいつでもMYページで確認できます。

またクリップした質問に回答があった際、通知やメールを受け取ることができます。

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

guest

回答1

0

ベストアンサー

セルにタイトルをつける処理を追加すれば、期待通りに動くのではないでしょうか。

swift

1 func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 2 guard let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as? CustomTableViewCell else { 3 return UITableViewCell() 4 } 5 // ここ 6 cell.button.setTitle(array[indexPath.row], for: []) 7 return cell 8 }

ちなみに、ボタンにタグをつけて、それで押されたセルを特定する方がすっきりとした書き方になりそうですが、いかがでしょうか。

swift

1func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { 2 guard let cell = tableView.dequeueReusableCell(withIdentifier: "Cell", for: indexPath) as? CustomTableViewCell else { 3 return UITableViewCell() 4 } 5 // ボタンにタグをつける 6 cell.button.tag = indexPath.row 7 cell.button.setTitle(array[indexPath.row], for: []) 8 return cell 9 } 10 11 @IBAction func tapButton(_ sender: UIButton) { 12 // ボタンにつけたタグを得る 13 let row = sender.tag 14 15 switch self.array[row] { 16 case "A面": 17 //タップされたボタンが"A面"であればフラグを"B面"にする 18 self.array[row] = "B面" 19 DispatchQueue.main.async { 20 //タイトルの変更 21 sender.setTitle("B面", for: .normal) 22 } 23 default: 24 //タップされたボタンが"B面"であればフラグを"A面"にする 25 self.array[row] = "A面" 26 DispatchQueue.main.async { 27 //タイトルの変更 28 sender.setTitle("A面", for: .normal) 29 } 30 } 31 }

投稿2020/03/24 15:29

TsukubaDepot

総合スコア5086

バッドをするには、ログインかつ

こちらの条件を満たす必要があります。

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

15分調べてもわからないことは
teratailで質問しよう!

ただいまの回答率
85.35%

質問をまとめることで
思考を整理して素早く解決

テンプレート機能で
簡単に質問をまとめる

質問する

関連した質問