在不使用onPressed颤动的情况下浏览页面后如何打开bottomSheet?

在不使用onpressed的情况下导航页面后是否可以打开bottomSheet?

当前,我添加了在bottomSheet事件中打开onpressed

scaffoldKey.currentState
        .showBottomSheet((context) => Container(
              height: 100,color: Colors.red,)),
gogo2b2 回答:在不使用onPressed颤动的情况下浏览页面后如何打开bottomSheet?

我不确定您是否已经尝试过此操作,但是可以定义一个有状态的小部件并添加显示bottomSheet为其状态的函数,我添加了一个示例波纹管,

void _modalBottomSheetMenu() {
    WidgetsBinding.instance.addPostFrameCallback((_) async {
      await showModalBottomSheet(
          context: context,builder: (builder) {
            return new Container(
              height: 350.0,color:
                  Colors.transparent,//could change this to Color(0xFF737373),//so you don't have to change MaterialApp canvasColor
              child: new Container(
                  decoration: new BoxDecoration(
                      color: Colors.white,borderRadius: new BorderRadius.only(
                          topLeft: const Radius.circular(10.0),topRight: const Radius.circular(10.0))),child: new Center(
                    child: new Text("This is a modal sheet"),)),);
          });
    });
  }

在显示bottomSheet之前,它将等待绘制第一帧,因此您可以从initState调用它

@override,在初始化状态下,您将调用上述函数。

 @override
  void initState() {
    super.initState();
    _modalBottomSheetMenu();
  }
,

您无法将其添加到initState()上,因为那时您还没有上下文。

最简单的方法是在开头添加变量didOpenModalBottomSheet = false

然后在构建中添加类似这样的内容

@override
Widget build(BuildContext context) {
    if(!didOpenModalBottomSheet){
        didOpenModalBottomSheet = true;
        _modalBottomSheetMenu();
    }
    return ...

您还可以使用以下库:https://pub.dev/packages/need_resume 特别是如果您来自Android。但是我还没有尝试过。

本文链接:https://www.f2er.com/3145404.html

大家都在问