错误:在此UpdateSupervisor小部件

时间:2020-10-17 16:01:18

标签: flutter provider

如何在onPressed函数中包装流提供程序?这是我的课程。

UpdateSupervisor类

import 'package:finalyearproject/model/NewUser.dart';
import 'package:finalyearproject/service/database.dart';
import 'package:finalyearproject/shared/Loading.dart';
import 'package:flutter/cupertino.dart';
import 'package:flutter/material.dart';
import 'package:provider/provider.dart';



class UpdateSupervisor extends StatefulWidget {


  @override
  _UpdateSupervisorState createState() => _UpdateSupervisorState();
}

class _UpdateSupervisorState extends State<UpdateSupervisor> {

  // form values
   String name;
   String email;
   String uniqueID;
   String phone;
   String id;
   
  final GlobalKey<FormState> _formKey = GlobalKey();

  @override
  Widget build(BuildContext context) {
    final user = Provider.of<NewUser>(context);
    return Scaffold(
      appBar: AppBar(
        title: Text('Edit Supervisor'),
        backgroundColor: Colors.redAccent,
      ),
      body: StreamBuilder(
        stream: DatabaseService(uid: user.id).userData,
        builder: (context, snapshot){
          if(!snapshot.hasData){
            return Loading();
          }
          NewUser userData = snapshot.data;
          return Form(
            key: _formKey,
            child: SingleChildScrollView(
              padding: const EdgeInsets.all(16.0),
              child: Column(
                crossAxisAlignment: CrossAxisAlignment.end,
                children: <Widget>[
                  SizedBox(height: 25.0),
                  TextFormField(
                    decoration: InputDecoration(
                        hintText: 'Name',
                        border: OutlineInputBorder(borderRadius: BorderRadius.circular(5))),
                    keyboardType: TextInputType.text,
                    initialValue: userData.name,
                    validator: (value) => value.isEmpty ? 'Name cannot be empty!': null,
                    onChanged: (value) {
                      setState(() => name = value);
                    },
                  ),
                  SizedBox(height: 10.0),
                  TextFormField(
                    decoration: InputDecoration(
                        hintText: 'Email',
                        border: OutlineInputBorder(borderRadius: BorderRadius.circular(5))),
                    keyboardType: TextInputType.emailAddress,
                    validator: (value) => value.isEmpty ? 'Email cannot be empty!': null,
                    onChanged: (value) {
                      setState(() => email = value);
                    },
                  ),
                  SizedBox(height: 10.0),
                  TextFormField(
                    decoration: InputDecoration(
                        hintText: 'Number Phone',
                        border: OutlineInputBorder(borderRadius: BorderRadius.circular(5))),
                    keyboardType: TextInputType.number,
                    validator: (value) => value.isEmpty ? 'Number Phone cannot be empty!': null,
                    onChanged: (value) {
                      setState(() => phone = value);
                    },
                  ),
                  SizedBox(height: 10.0),
                  TextFormField(
                    decoration: InputDecoration(
                        hintText: 'Unique ID ',
                        border: OutlineInputBorder(borderRadius: BorderRadius.circular(5))),
                    keyboardType: TextInputType.number,
                    validator: (value) => value.isEmpty ? 'Ic number cannot be empty!': null,
                    onChanged: (value) {
                      setState(() => uniqueID = value);
                    },
                  ),
                  const SizedBox(height: 20.0),
                  RaisedButton(
                      color: Colors.redAccent,
                      textColor: Colors.black,
                      child: Text("Update"),
                      onPressed: () async {
                        if(_formKey.currentState.validate()){

                          _formKey.currentState.save();
                        } else {
                          print("Validator are correct!");
                        }
                      }
                  ),
                ],
              ),
            ),
          );
        }
      )
    );

  }
}

HomeSupervisor类

import 'package:flutter/material.dart';
import 'package:finalyearproject/model/NewUser.dart';
import 'package:finalyearproject/screen/crud/UpdateSupervisor.dart';
import 'package:finalyearproject/screen/crud/AddSupervisor.dart';
import 'package:finalyearproject/service/database.dart';
import 'package:finalyearproject/sidebar/AdminDrawer.dart';


class HomeSupervisor extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        backgroundColor: Colors.redAccent,
        title: Text('Supervisor'),
        actions: <Widget>[
          IconButton(
              icon: Icon(
                Icons.add,
                color: Colors.white,
              ),
              onPressed: () {
                Navigator.push(context,
                    MaterialPageRoute(builder: (context) => AddSupervisor()));
              })
        ],
      ),
      drawer: AdminDrawer(),
      body: ListSupervisor(),
    );
  }

}

class ListSupervisor extends StatefulWidget {
  @override
  _ListSupervisorState createState() => _ListSupervisorState();
}

class _ListSupervisorState extends State<ListSupervisor> {
  NewUser user;

  @override
  Widget build(BuildContext context) {
    return Container(
      child: FutureBuilder(
          future: DatabaseService().getPost(),
          builder: (_, snapshot) {
            if (snapshot.connectionState == ConnectionState.waiting) {
              return Center(
                child: Text("Loading..."),
              );
            } else {
              return ListView.builder(
                  itemCount: snapshot.data.length,
                  itemBuilder: (_, index) {
                    return Card(
                      child: ListTile(
                          title: Container(
                            alignment: Alignment.centerLeft,
                            child: Column(
                              children: <Widget>[
                                SizedBox(height: 5.0),
                                Container(alignment: Alignment.centerLeft,
                                  child: Text(
                                      snapshot.data[index].data["name"]),
                                ),

                                SizedBox(height: 5.0),
                                Container(alignment: Alignment.centerLeft,
                                  child: Text(
                                      snapshot.data[index].data["email"]),
                                ),
                                SizedBox(height: 5.0),
                                Container(alignment: Alignment.centerLeft,
                                  child: Text(
                                      snapshot.data[index].data["uniqueID"]),
                                ),
                              ],
                            ),
                          ),
                          trailing: Row(
                            mainAxisSize: MainAxisSize.min,
                            children: <Widget>[
                              IconButton(
                                  icon: Icon(Icons.delete),
                                  color: Colors.red,
                                  onPressed: (){

                                  }
                              ),
                              IconButton(
                                  icon: Icon(Icons.edit),
                                  color: Colors.black,
                                  onPressed: () {
                                    Navigator.push(context, MaterialPageRoute(builder: (context) => UpdateSupervisor()));  //here the line error show//
                                  }
                              ),
                              IconButton(
                                  icon: Icon(Icons.share),
                                  onPressed: () {

                                  }
                              ),
                            ],
                          )
                      ),
                    );
                  });
            }
          }),
    );
  }
}

然后erorr显示,在96:101行中,我将nagivator.push的Iconbutton推送到UpdateSupervisor。 所以我的问题是如何在onPressed()中包装流提供程序?

错误:在此UpdateSupervisor小部件上方找不到正确的提供程序

要解决,请:

  • 确保提供者是此UpdateSupervisor小部件的祖先
  • 向提供者提供类型
  • 为消费者提供类型
  • 将类型提供给Provider.of()
  • 始终使用包导入。例如:`import'package:my_app / my_code.dart';
  • 确保使用正确的context

如果这些解决方案均无效,请在以下位置提交错误: https://github.com/rrousselGit/provider/issues 相关的引起错误的小部件是: UpdateSupervisor文件:/// D:/Android_project/finalyearproject/lib/screen/home/HomeSupervisor.dart:96:101

1 个答案:

答案 0 :(得分:0)

使用这样的提供程序包装MaterialApp。

ChangeNotifierProvider<NewUser>(create: (context) => NewUser(),
      child: MaterialApp(
        title: 'Flutter Demo',
        home:Home(),
      ),
    );

另外: 我正在使用 ChangeNotifierProvider ,因为我假设您的提供商正在扩展 ChangeNotifier

如果您不扩展 ChangeNotifier ,则可以使用以下提供程序的基本形式:

Provider<NewUser>(
  create: (context) => NewUser(),
  child: child: MaterialApp(
        title: 'Flutter Demo',
        home:Home(),
      ),
)

这将使您可以将 NewUser 对象用作对所有Provider后代类的依赖项注入,如下所示:

class HomeWidget extends StatelessWidget {
  @override
  Widget buid(BuildContext context){
    final provider = Provider.of<NewUser>(contextm, listen:false); /// you can to not set listen on false it does not matter in this case cause this type of provider is just an injection
    return Text(provider.someText);

   }
}

还有 StreamProvider ,您可以在流中收听并更新 Widget ,当出现此问题时,该注入该提供程序流将接收数据,也将其检出。

还有一个 MultiProvider ,可让您将MaterialApp与多个提供程序包装在一起。

还要检查此url

来自flutter.dev

MultiProvider

示例

void main() {
  runApp(
    MultiProvider(
      providers: [
        ChangeNotifierProvider(create: (context) => CartModel()),
        Provider(create: (context) => SomeOtherClass()),
      ],
      child: MyApp(),
    ),
  );
}