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

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

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

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

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Dart

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

Q&A

解決済

1回答

1191閲覧

Riverpod(flutter_hooks)+StateNotiferを用いた状態管理ができない

Kaisei123

総合スコア0

Flutter

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

ファイル

ファイルとは、文字列に基づいた名前又はパスからアクセスすることができる、任意の情報のブロック又は情報を格納するためのリソースです。

関数

関数(ファンクション・メソッド・サブルーチンとも呼ばれる)は、はプログラムのコードの一部であり、ある特定のタスクを処理するように設計されたものです。

Dart

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

0グッド

0クリップ

投稿2021/10/04 07:16

前提・実現したいこと

FlutterでRiverpod(flutter_hooks)+StateNotifierを用いてbottomNavigationBarの状態を管理しようとしています。ファイル構成は【widget、state、controller】の3つに分けています。

発生している問題・エラーメッセージ

bottomNavigationbarのボタンを押しても初期設定された画面から変更されません。

コントローラー部分の関数内では渡されたindex値がindexStateに代入されているが、関数処理後にuseProviderを用いて呼び出した変数の値に反映されない状況です。

該当のソースコード

dart

11.bottomNavigaitonBar Widget部分 2 3import 'package:hooks_riverpod/hooks_riverpod.dart'; 4import 'package:flutter_hooks/flutter_hooks.dart'; 5 6class ScreenBottomNavigationBar extends HookWidget { 7 const ScreenBottomNavigationBar({Key? key}) : super(key: key); 8 9 Widget build(BuildContext context) { 10 final indexStateNav = useProvider(bottomNavigationController).indexState; 11 return BottomNavigationBar( 12 onTap: (int index) { 13 context.read(bottomNavigationController.notifier).getCurrentIndex(index); 14 print(indexStateNav); 15 }, 16 currentIndex: indexStateNav, 17 items: [ 18 BottomNavigationBarItem( 19 icon: Icon(Icons.rate_review), 20 label: '入力', 21 ), 22 BottomNavigationBarItem( 23 icon: Icon(Icons.analytics), 24 label: '分析', 25 ), 26 BottomNavigationBarItem( 27 icon: Icon(Icons.settings), 28 label: '設定', 29 ), 30 ], 31 ); 32 } 33}

dart

12.state部分 2 3class ScreenBottomNavigationBarState { 4 int indexState; 5 ScreenBottomNavigationBarState({required this.indexState}); 6}

dart

13.controller部分 2 3import 'package:hooks_riverpod/hooks_riverpod.dart'; 4import 'package:state_notifier/state_notifier.dart'; 5 6final bottomNavigationController = StateNotifierProvider<BottomNavigationController, ScreenBottomNavigationBarState>( 7 (ref) => BottomNavigationController(), 8); 9 10class BottomNavigationController extends StateNotifier<ScreenBottomNavigationBarState> { 11 BottomNavigationController() : super(ScreenBottomNavigationBarState(indexState: 0)); 12 void getCurrentIndex(int index) { 13 state..indexState = index; 14 } 15}

補足情報(FW/ツールのバージョンなど)

flutter_hooks: ^0.17.0
hooks_riverpod: ^0.14.0+4
state_notifier: ^0.7.1

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

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

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

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

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

guest

回答1

0

自己解決

controller部分で、引数にindex(onTap時のcurrentIndex)を当てた ScreenBottomNavigationBarStateの型をstateに代入することで解決

dart

1 void getCurrentIndex(int index) { 2 state = ScreenBottomNavigationBarState(indexState: index); 3 } 4}

投稿2021/10/04 08:06

Kaisei123

総合スコア0

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

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

あなたの回答

tips

太字

斜体

打ち消し線

見出し

引用テキストの挿入

コードの挿入

リンクの挿入

リストの挿入

番号リストの挿入

表の挿入

水平線の挿入

プレビュー

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

ただいまの回答率
85.35%

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

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

質問する

関連した質問