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

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

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

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Xcode

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

Swift

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

Q&A

1回答

1359閲覧

SwiftUI tabviewで初期home画面のデータが表示できない

swiftybird2

総合スコア4

Firebase

Firebaseは、Googleが提供するBasSサービスの一つ。リアルタイム通知可能、並びにアクセス制御ができるオブジェクトデータベース機能を備えます。さらに認証機能、アプリケーションのログ解析機能などの利用も可能です。

Xcode

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

Swift

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

0グッド

1クリップ

投稿2020/10/09 23:19

編集2020/10/11 00:40

現状態・前提・実現したいこと

SwiftUI:tabviewで初期tab1(home)画面のデータが表示できない理由と対応方法が知りたいです。
タブ(下部)切り替えできる下記のソースtab1にこちらのページ
を使いスクロールしてスマートニュースのように上部のタブと画面が切り替わるようにしています。

TabView { tab1() //タブ表示 .tabItem { Image("home") Text("ホーム") } tab2() .tabItem { Image("position") Text("hoge") } //以下省略

発生している問題

tab1画面に表示するデータはfirebaseから引っ張ってきたデータをForeachで回し表示しようとしています。
しかしアプリを立ち上げたり下部のタブをtab1(home)に切り替えるとデータは表示されません。

tab1の中のページで
2ページめに移動しようとタップして横にスクロールしようとしたり(ちょびっと画面を動かす)、スクロールして画面に戻ると表示されます。

2ページ以降のデータは表示されてます。。。。

==============================
「初期画面、tab1選択時にデータが表示されない画像」
イメージ説明
==============================
「上部タブ内のページを切り替えようと指を動かしたら表示された時の画像」
果物が一列に横並びになっている部分が1ページ目表示されていなかった部分です。
イメージ説明

表示画面のビューとデーター取得のソースは以下になります。

struct ProductListView: View { @ObservedObject var productVM = ProductViewModel() var body: some View { let chunkedProducts = self.productVM.products.chunked(into: 3) ScrollView { VStack { ForEach(0..<chunkedProducts.count) { index in HStack { ForEach(chunkedProducts[index]) { product in ProductCell(product: product) } } } } } } } ーーーー import Foundation import Firebase class ProductViewModel:ObservableObject{ @Published var products:[Product] = [] init() { self.fetchProducts() } func fetchProducts() { PRODUCTS_REF.observeSingleEvent(of: .value) { (snapshot) in guard let allObjects = snapshot.children.allObjects as? [DataSnapshot] else { return } allObjects.forEach { (snapshot) in let productId = snapshot.key Database.fetchProduct(with: productId) { (product) in self.products.append(product) } } } } }

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

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

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

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

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

guest

回答1

0

chunkedProducts 部分だと思います。
非同期で取得するのでしたら定数宣言時はデータが空の可能性あります。
直接 self.productVM.products.chunked(into: 3) を使うようにすれば表示されると思います。

投稿2020/10/14 19:57

TakuyaAso

総合スコア1361

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

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

swiftybird2

2020/10/15 13:16

直接使うとは下記のようにってことでしょうか? VStack { ForEach(0..<self.productVM.products.chunked(into: 3).count) { index in HStack { ForEach(self.productVM.products.chunked(into: 3)[index]) { product in ProductCell(product: product) } }
swiftybird2

2020/10/16 10:46

self.productVM.products.chunked(into: 3)をViewmodel内で行い下記のようにしましたが表示できませんでした。 VStack { ForEach(0..<productVM.productsData.count) { index in HStack { ForEach(self.productVM.productsData[index]) { product in ProductCell(product: product) } } } }
guest

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

まだベストアンサーが選ばれていません

会員登録して回答してみよう

アカウントをお持ちの方は

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問