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

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

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

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

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Cloud Firestore

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

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

Q&A

解決済

1回答

2025閲覧

Flutter Firestoreの値を更新しても画面に反映されない

Gento

総合スコア77

Firebase

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

Flutter

Flutterは、iOSとAndroidのアプリを同じコードで開発するためのフレームワークです。オープンソースで開発言語はDart。双方のプラットフォームにおける高度な実行パフォーマンスと開発効率を提供することを目的としています。

Cloud Firestore

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

Dart

Dartは、Googleによって開発されたJavaScriptの代替となることを目的に作られた、ウェブ向けのプログラミング言語である。

0グッド

0クリップ

投稿2021/05/23 02:32

解決したいこと

https://qiita.com/kokogento/questions/d670eb857d03e66e95f5

上記ページに埋め込まれている動画のように、Firestoreの値の更新は成功していても、画面にリアルタイムで反映されません。

これをリアルタイムで反映するようにしたいです!

#環境

yaml:pubspec.yaml

1environment: 2 sdk: ">=2.7.0 <3.0.0" 3 4dependencies: 5 flutter: 6 sdk: flutter 7 provider: ^4.3.3 8 rxdart: ^0.25.0 9 firebase_core: "0.7.0" 10 firebase_auth: "^0.20.1" 11 cloud_firestore: "^0.16.0+1"

providerを使って状態管理をしています。(providerに関しては超初心者なので、あまりわかっていません。。)

該当するソースコード

##全体の構成

lib/  ├ main.dart  ├ models  ├ └ user_model.dart  ├ providers  │ └ user_provider.dart  ├ widgets  │ └ mypage_view.dart  └ screens ├ mypage_screen.dart └ mypage_edit_screen.dart

###ソースコードが長すぎて、teratailでは投稿できませんでした。。。(10000字以下でないと投稿できないようで)
https://qiita.com/kokogento/questions/d670eb857d03e66e95f5

こちらをご覧ください!

#疑問点

https://www.youtube.com/watch?v=W0oKfFgoKpM

上記の動画を参考にChangeNotifierProviderを使って実装しましたが、Streamを監視する?StreamProviderというものもあると知りました。。

一体どっちを使うのが良いのでしょうか?

リアルタイムで値が変更されていない原因は、ウィジェットのリビルド?がうまくできていないからだと思われます。
Consumerなら勝手に変わってくれるのかな?とか思っていましたが、想像していたよりもはるかに複雑で意味がわからないです。。。

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

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

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

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

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

guest

回答1

0

自己解決

根本からやり方を変えて無理やりですが実現しました

https://qiita.com/kokogento/items/f0861b820ffcdf1133c3

投稿2021/05/23 12:35

Gento

総合スコア77

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.46%

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

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

質問する

関連した質問