错误:参数类型“对象?”不能分配给参数类型“字符串”

时间:2021-06-18 14:45:12

标签: flutter dart

问题很明显我只是不知道如何解决它...

这是整个页面:

import 'package:flutter/material.dart';
import 'package:provider/provider.dart';
import 'package:provider_practice_part2/controller/user_notifier.dart';
import 'package:provider_practice_part2/models/user.dart';
import 'package:provider_practice_part2/screens/user_list_screen.dart';
import 'package:provider_practice_part2/widgets/cheetah_button.dart';
import 'package:provider_practice_part2/widgets/cheetah_input.dart';
import 'package:provider_practice_part2/widgets/user_list.dart';

class Home extends StatefulWidget {
  @override
  HomeState createState() => HomeState();
}

class HomeState extends State<Home> {
  String? _name;
  String? _city;

  final GlobalKey<FormState> _formKey = GlobalKey<FormState>();

  @override
  Widget build(BuildContext context) {
    UserNotifier userNotifier = Provider.of<UserNotifier>(context);
    return Scaffold(
      backgroundColor: Theme.of(context).backgroundColor,
      appBar: AppBar(
        title: Consumer(
          builder: (context, title, child) {
            return Text(
              title,
              style: TextStyle(color: Colors.white),
            );
          },
        ),
      ),
      body: SingleChildScrollView(
        padding: EdgeInsets.all(32),
        child: Form(
          key: _formKey,
          child: Column(
            mainAxisAlignment: MainAxisAlignment.center,
            children: <Widget>[
              CheetahInput(
                labelText: 'Name',
                onSaved: (String? value) {
                  _name = value;
                },
              ),
              SizedBox(height: 16),
              CheetahInput(
                labelText: 'City',
                onSaved: (String? value) {
                  _city = value;
                },
              ),
              SizedBox(height: 20),
              Row(
                mainAxisAlignment: MainAxisAlignment.spaceBetween,
                children: [
                  CheetahButton(
                    text: 'Add',
                    onPressed: () {
                      if (!_formKey.currentState!.validate()) return;

                      _formKey.currentState!.save();
                      context
                          .read<UserNotifier>()
                          .addUser(User(_name!, _city!));
                    },
                  ),
                  SizedBox(width: 8),
                  CheetahButton(
                    text: 'List',
                    onPressed: () {
                      Navigator.push(
                        context,
                        MaterialPageRoute(
                          builder: (context) => UserListScreen(),
                        ),
                      );
                    },
                  ),
                ],
              ),
              SizedBox(height: 20),
              UserList(),
            ],
          ),
        ),
      ),
    );
  }
}

问题出在这里:

Consumer(
          builder: (context, title, child) {
            return Text(
              title,
              style: TextStyle(color: Colors.white),
            );
          },
        ),

正如您从标题中看到的那样,当我尝试将数据从使用者传递到文本小部件时出现错误,我已经尝试过 Null_aware 运算符和可空运算符,但它不起作用..... 毕竟我已经通过删除整个消费者并用以下代码替换它来解决问题:

Text(
          context.watch<String>(),
          style: TextStyle(color: Colors.white),
        ),

我只是想知道这个问题是否有任何解决方案,如果看到这个问题对我和其他未来的程序员有用。

注意:我正在使用提供程序 5 注意:此调用是一些人工数据的未来,只是为了测试 futureprovider 的工作方式..

2 个答案:

答案 0 :(得分:1)

你只需要使用

Consumer<String>(
...
)

答案 1 :(得分:0)

当您使用 Consumer 时,您需要传递一个泛型类型参数,让类知道您正在尝试使用什么,就像您使用 context.watch<String>() 所做的一样。由于 Dart 中泛型的工作方式,如果您不指定类型,Dart 将尝试使用类型推断来自动选择类型。但是由于没有任何东西可以从 Consumer 的主体中推断出来,Dart 将默认为最基本的类型,恰好是 Object?

这不仅对于让代码知道 title 将是什么类型很重要,而且还因为 Consumer 需要知道在它必须筛选的所有父提供程序中查找什么类型知道最终该听哪一个。

Consumer<String>(
  builder: (context, title, child) {
    return Text(
      title,
      style: TextStyle(color: Colors.white),
    );
  },
),