3

我有一个关于切换小部件的简单示例,我希望在单击按钮后显示圆形进度指示器,然后在 3 秒后显示文本。对于我的示例,我使用riverpod_hooksflutter_hooks

加载提供者

class IsLoading extends StateNotifier<bool> {
  IsLoading() : super(false);
  void toggleLoading(bool value) => state = value;
}

final isLoadingProvider = StateNotifierProvider((ref) => IsLoading());

主要.dart

class TestingApp extends HookWidget {
  @override
  Widget build(BuildContext context) {
    final IsLoading isLoading = useProvider(isLoadingProvider);
    return Scaffold(
      body: Container(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          children: <Widget>[
            Center(
              child: isLoading.state ? CircularProgressIndicator() : Text('This Is Your Data'),
            ),
            Padding(
              padding: const EdgeInsets.all(8.0),
              child: FlatButton(
                  onPressed: () => showLoading(isLoading), child: Text('Toggle Loading')),
            ),
          ],
        ),
      ),
    );
  }

  void showLoading(IsLoading isLoading) async {
    isLoading.toggleLoading(true);
    print("Proses");
    await Future.delayed(const Duration(seconds: 3));
    print("Done");
    isLoading.toggleLoading(false);
  }
}

但是当我按下按钮时,它不显示 progressIndicator 并且仍然显示文本并且我收到了这个警告:
The member 'state' can only be used within instance members of subclasses of 'package:state_notifier/state_notifier.dart'.

我错过了什么?

我的源代码遵循这样的文档:

在此处输入图像描述

4

2 回答 2

1

它在那里说,当您像这样调用增量时,它不会触发重建方法。

所以不是用 read 方法调用 isLoading.toggleLoading(true) ,所以它可以像 isLoading.read(context).toggleLoading(true) 那样重建状态

于 2020-07-16T13:48:08.213 回答
1

为你的 提供两种类型,StateNotifierProvider你返回的类的类型和类的状态。

class IsLoading extends StateNotifier<bool> {
  IsLoading() : super(false);
  void toggleLoading(bool value) => state = value;
}

final isLoadingProvider =
    StateNotifierProvider<IsLoading, bool>((ref) => IsLoading());

在您的build方法中 (of a ConsumerStateWidget) 使用:

final isLoading = ref.watch(isLoadingProvider);
return Scaffold(body: Center(child:
isLoading ? CircularProgressIndicator() : Text('This Is Your Data'),))
于 2022-01-09T16:22:30.290 回答