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

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

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

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

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

Q&A

1回答

959閲覧

Nuxt.js+Firestoreでのデータの連続取得

omcrnec

総合スコア0

Firebase

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

Nuxt.js

Nuxt.jsは、ユニバーサルなSPAが開発可能なVue.jsベースのフレームワーク。UIの描画サポートに特化しており、SSRにおけるサーバーサイドとクライアントサイドのUIレンダリングなどさまざまな機能を持ちます。

Cloud Firestore

Cloud Firestore は、自動スケーリングと高性能を実現し、アプリケーション開発を簡素化するように構築された NoSQLドキュメントデータベースです。

非同期処理

非同期処理とは一部のコードを別々のスレッドで実行させる手法です。アプリケーションのパフォーマンスを向上させる目的でこの手法を用います。

0グッド

0クリップ

投稿2021/06/05 14:15

Nuxt.js+Firestoreでデータの連続取得

Nuxt.js、firestoreにてデータを取得し、さらに取得したデータを用いて新たなデータを参照したいです。
コレクション[user]には、ユーザー情報が入っており、各ユーザーIDに対応したドキュメント[userId0]にそのユーザーが参加しているチャットのchatIdが入っています。

コレクション[chat]には、chatIdごとにチャットの内容がコレクション[messages]の中のドキュメント[message0],[message1],...として入っています。

Firestoreの構造

*:collection
@:document

*user -@useIid0 -*chat -@chatId0 -@chatId1 -@userId1 -@userId2 *chat -@chatId0 -*messages -@message0 -@message1 -@chatId1

methodsに定義した関数

ユーザーに紐づいているチャットIDを取得

javascript

1getChatIdList (userId) { 2 const chatIdList = [] 3 const db = this.$fire.firestore.collection('user').doc(userId).collection('chat') 4 db.get() 5 .then((querySnapShot) => { 6 querySnapShot.forEach((doc) => { 7 chatIdList.push(doc.data()) 8 }) 9 }) 10 return chatIdList 11}

得たチャットIDから、メッセージを取得

javascript

1getChatMessages (chatId) { 2 const messages = [] 3 const db = this.$fire.firestore.collection('chat').doc(chatId).collection('messages') 4 db.get() 5 .then((querySnapShot) => { 6 querySnapShot.forEach((doc) => { 7 messages.push(doc.data()) 8 }) 9 }) 10 return messages 11}

createdの内容

上記の関数を使って、ユーザーが参加しているチャットのchatIdを取得し、処理が終わったら、chatIdを使って、そのチャットの内容をmessagesとして取得しようとしています。

javascript

1created () { 2 const self = this 3 async function get() { 4 const chatIdList = await self.getChatIdList() 5        const messagesList = [] 6 const messages = chatIdList.forEach(chatId => { 7 messagesList.push(self.getChatMessages(chatId)) 8 }) 9 } 10 get() 11}

しかし、実際にはchatIdListが空のままforEachが回ってしまいます。
どのようにすればデータの取得後、そのデータを用いて次の処理を行えるでしょうか。

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

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

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

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

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

guest

回答1

0

db.get()の処理をawaitにすることで解決できそうですがいかがでしょうか?
同様にchatMessageのほうもawaitにしたほうが良いと思います。

async getChatIdList (userId) { const chatIdList = [] const db = this.$fire.firestore.collection('user').doc(userId).collection('chat') await db.get() .then((querySnapShot) => { querySnapShot.forEach((doc) => { chatIdList.push(doc.data()) }) }) return chatIdList }

投稿2021/06/06 05:04

m2l

総合スコア318

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

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

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

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問