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

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

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

TableView(UITableView)とは、リスト形式で表示するコントロールで、ほとんどのアプリに使用されています。画面を「行」に分けて管理し、一般的には各行をタップした際に詳細画面に移動します。

iOS

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

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Xcode

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

Swift

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

Q&A

解決済

1回答

5450閲覧

tableView複数のセルを扱いたい

退会済みユーザー

退会済みユーザー

総合スコア0

TableView

TableView(UITableView)とは、リスト形式で表示するコントロールで、ほとんどのアプリに使用されています。画面を「行」に分けて管理し、一般的には各行をタップした際に詳細画面に移動します。

iOS

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

MacOS(OSX)

MacOSとは、Appleの開発していたGUI(グラフィカルユーザーインターフェース)を採用したオペレーションシステム(OS)です。Macintoshと共に、市場に出てGUIの普及に大きく貢献しました。

Xcode

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

Swift

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

0グッド

0クリップ

投稿2018/08/03 10:19

編集2018/08/03 12:54
func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let cellTop = tableView.dequeueReusableCell(withIdentifier: "ArticleTopTableViewCell", for:indexPath) as! ArticleTopTableViewCell let cell = tableView.dequeueReusableCell(withIdentifier: "ArticleTableViewCell", for:indexPath) as! ArticleTableViewCell let article = articles[indexPath.row] if indexPath.row == 0 { cellTop.configure(article: article) } else { cell.configure(article: article) } return cell or cellTopを返したい }

一つのセクションで二つのカスタムセルを使いたく、イメージとしては上記のようなことを実装したいのですが、やり方がわかりません。
どなたかアドバイスいただけないでしょうか?
以下のコードでは'Attempted to dequeue multiple cells for the same index path, which is not allowed. If you really need to dequeue more cells than the table view is requestingと言われてしまいました。

func tableView(_ tableView: UITableView, cellForRowAt indexPath: IndexPath) -> UITableViewCell { let article = articles[indexPath.row] let cell = tableView.dequeueReusableCell(withIdentifier: "ArticleTableViewCell", for:indexPath) as! ArticleTableViewCell if finishedLoading { if indexPath.row == 0 { let cellTop = tableView.dequeueReusableCell(withIdentifier: "ArticleTopTableViewCell", for:indexPath) as! ArticleTopTableViewCell cellTop.configure(article: article) return cellTop } cell.configure(article: article) } return cell }

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

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

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

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

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

guest

回答1

0

ベストアンサー

indexPath.row == 0 のときだけ ArticleTopTableViewCell を作って設定してreturn、
そうでないときはArticleTableViewCellを作れば良いです。

投稿2018/08/03 10:26

daisuke7

総合スコア1563

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

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

退会済みユーザー

退会済みユーザー

2018/08/03 12:55

情報を追加したので、もう一度確認していただけますでしょうか?
daisuke7

2018/08/03 12:59

indexPath.row == 0 のときも ArticleTableViewCell を dequeue しちゃっていますね。
退会済みユーザー

退会済みユーザー

2018/08/03 13:06

どのように書くか、具体的に擬似コードで構いませんので、教えていただけますでしょうか?
daisuke7

2018/08/03 13:12

単にこうするだけのイメージですが… if indexPath.row == 0 { let cellTop = tableView.dequeueReusableCell(withIdentifier: "ArticleTopTableViewCell", for:indexPath) as! ArticleTopTableViewCell cellTop.configure(article: article) return cellTop } let cell = tableView.dequeueReusableCell(withIdentifier: "ArticleTableViewCell", for:indexPath) as! ArticleTableViewCell cell.configure(article: article) return cell finishedLoadingってのはわからないので省略してます。
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.50%

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

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

質問する

関連した質問