0

我正在使用颤振制作移动应用程序。我正在为这个屏幕使用流生成器。我没有明白我在代码中的错误之处。你能帮我解决这个问题吗?我正在共享导致问题的特定行的代码和屏幕截图

 var timeSelected = 'Click here';

Row(
                          mainAxisAlignment: MainAxisAlignment.start,
                          children: <Widget>[
                            Text(
                              'Time Slot:',
                              style: TextStyle(color: Colors.white),
                            ),
                            Spacer(),
                            GestureDetector(
                              onTap: () {
                                _asyncInputDialog(context);
                                //_displayDialog();
                              },
                              child: StreamBuilder(stream: cartManager.getTimeSlotSelected,
                                initialData: timeSelected,
                                builder: (context, AsyncSnapshot snapshot) {
                                if (snapshot.hasData){
                                 timeShow(snapshot,);
                                }
                                else if (snapshot.hasError) {
                                  return Text(snapshot.error.toString());
                                  }
                                  return Center(
                                  child: Container(
                                  child: Text('Select time slot'),
                                  ),
                                  );
                              },)
                            ),
                          ],
                        ),

当我单击行的文本时,将显示此警报对话框:

   _asyncInputDialog(
        BuildContext context,
      ) {
        return showDialog(
            context: context,
            builder: (context) {
              return AlertDialog(
                title: Center(child: Text('Available Time Slot')),
                content: TEAlertDialogContent(),
                actions: <Widget>[
                  new FlatButton(
                    child: new Text('CANCEL'),
                    onPressed: () {
                      Navigator.of(context).pop();
                    },
                  )
                ],
              );
            });
      }

当我从 showdialog 获得值时,我会将值存储在 CartManager 中的流控制器中。

 static StreamController<Timeslot> timeSlotController = BehaviorSubject();

  timeSlotSelected(Timeslot time){
    timeSlotController.sink.add(time);
  }

  get getTimeSlotSelected{
    return timeSlotController.stream;
  }

而我们在streamcontroller的stream属性中调用上述方法并获取快照。这是我们的快照有数据时调用的方法:

  Widget timeShow(AsyncSnapshot<Timeslot> snapshot ) {
    timeSelected = '${snapshot.data.firstTimeSlot}-${snapshot.data.secondTimeSlot}';
    timeslotid = snapshot.data.id.toString();
    return Text(timeSelected);
  }

但我收到错误:“BehaviorSubject”类型不是“Stream”类型的子类型 请让我知道我哪里错了。我还分享了显示此错误的屏幕截图。错误截图

4

1 回答 1

0

正如您的错误所述,您正在尝试将类型 Timeslot 传递给期望 String 类型流的 Stream 构建器。您必须检查哪一个是正确的(字符串或时隙)并在两边使用相同的类型。显然,您的问题出在 timeSelected 变量中。它在哪里定义?如果这是一个字符串,则流构建器将推断您的流是字符串类型,这是不正确的。您必须将此变量设置为时隙,因为这是您的流类型。

此外,您的代码中有错误。如果快照有数据,您必须返回要呈现的小部件。检查下面的代码:

StreamBuilder(stream: cartManager.getTimeSlotSelected,
                            initialData: timeSelected,
                            builder: (context, AsyncSnapshot snapshot) {
                            if (snapshot.hasData){
                             return timeShow(snapshot,);
                            }
                            else if (snapshot.hasError) {
                              return Text(snapshot.error.toString());
                              }
                              return Center(
                              child: Container(
                              child: Text('Select time slot'),
                              ),
                              );
                          },)
于 2019-12-20T13:57:21.487 回答