提供者main.dart的init方法

时间:2019-08-08 04:29:53

标签: flutter flutter-provider

我可以在main.dart文件的init方法中使用provider吗?

我尝试使用SchedulerBinding.instance.addPostFrameCallback方法作为回调,但出现异常。

import 'package:flutter/material.dart';
import 'package:flutter/scheduler.dart';
import 'package:flutterdev/pages/product_list.dart';
import 'package:flutterdev/state/user.dart';
import 'package:provider/provider.dart';
// import 'package:flutter/rendering.dart';

import './pages/auth.dart';
import './pages/products_admin.dart';
import './pages/products.dart';
import './pages/product.dart';
import './state/products.dart';
import './state/user.dart';
import './models/product.dart';

void main() {
  // debugPaintSizeEnabled = true;
  // debugPaintBaselinesEnabled = true;
  // debugPaintPointersEnabled = true;
  runApp(MyApp());
}

class MyApp extends StatefulWidget {
  @override
  State<StatefulWidget> createState() {
    return _MyAppState();
  }
}

class _MyAppState extends State<MyApp> {
  @override
  void initState() {
    // TODO: implement initState
    super.initState();

    SchedulerBinding.instance.addPostFrameCallback((_) {

      UserProvider userProvider = Provider.of<UserProvider>(context);
      userProvider.autoAuthenticate();

    });

    // () async {
    //  await Future.delayed(Duration.zero);

    //}();
  }

  @override
  Widget build(BuildContext context) {
    return MultiProvider(
      providers: [
        ChangeNotifierProvider(builder: (_) => ProductsProvider()),
        ChangeNotifierProvider(builder: (_) => UserProvider()),
      ],
      child: MaterialApp(
        // debugShowMaterialGrid: true,
        theme: ThemeData(
            brightness: Brightness.light,
            primarySwatch: Colors.deepOrange,
            accentColor: Colors.deepPurple,
            buttonColor: Colors.deepPurple),

        // home: AuthPage(),
        routes: {
          '/': (BuildContext context) =>
              Consumer<UserProvider>(builder: (context, userProvider, _) {
                final ProductsProvider productsProvider =
                    Provider.of<ProductsProvider>(context);
                String token = "";

                if (userProvider.authenticatedUser != null) {
                  token = userProvider.authenticatedUser.token;
                }

                return userProvider.authenticatedUser == null
                    ? AuthPage()
                    : ProductListPage(productsProvider, token);
              }),

        },
      ),
    );
  }
}

我要例外了。我不知道如何将多供应商提升到小部件上方以使其工作。我试图将其移动到createstate和main方法。我不明白该怎么做。


flutter: ══╡ EXCEPTION CAUGHT BY SCHEDULER LIBRARY ╞═════════════════════════════════════════════════════════
flutter: The following ProviderNotFoundError was thrown during a scheduler callback:
flutter: Error: Could not find the correct Provider<UserProvider> above this MyApp Widget
flutter:
flutter: To fix, please:
flutter:
flutter:   * Ensure the Provider<UserProvider> is an ancestor to this MyApp Widget
flutter:   * Provide types to Provider<UserProvider>
flutter:   * Provide types to Consumer<UserProvider>
flutter:   * Provide types to Provider.of<UserProvider>()
flutter:   * Always use package imports. Ex: `import 'package:my_app/my_code.dart';
flutter:   * Ensure the correct `context` is being used.
flutter:
flutter: If none of these solutions work, please file a bug at:


1 个答案:

答案 0 :(得分:0)

以下代码有效。我将提供程序设置移至runApp,并在MyApp中将userprovider作为参数接收。

null