为什么在flutter中显示模式底部表单需要2个小部件



为什么需要2个无状态小部件来创建flutter中的模式底部表单?为什么我们不能用一个???为什么我们必须有一个带有scaffold的主小部件,然后在其中输入另一个小部件?当我用一个无状态小部件类尝试它时,它不起作用。为什么?

import 'package:flutter/material.dart';
void main() => runApp(const MyApp());
class MyApp extends StatelessWidget {
  const MyApp({Key? key}) : super(key: key);
  static const String _title = 'Flutter Code Sample';
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: _title,
      home: Scaffold(
        appBar: AppBar(title: const Text(_title)),
        body: const MyStatelessWidget(),
      ),
    );
  }
}
class MyStatelessWidget extends StatelessWidget {
  const MyStatelessWidget({Key? key}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    return Center(
      child: ElevatedButton(
        child: const Text('showModalBottomSheet'),
        onPressed: () {
          showModalBottomSheet<void>(
            context: context,
            builder: (BuildContext context) {
              return Container(
                height: 200,
                color: Colors.amber,
                child: Center(
                  child: Column(
                    mainAxisAlignment: MainAxisAlignment.center,
                    mainAxisSize: MainAxisSize.min,
                    children: <Widget>[
                      const Text('Modal BottomSheet'),
                      ElevatedButton(
                        child: const Text('Close BottomSheet'),
                        onPressed: () => Navigator.pop(context),
                      )
                    ],
                  ),
                ),
              );
            },
          );
        },
      ),
    );
  }
}

这一切都与构建方法的BuildContext属性有关。MaterialApp和Scaffold将Material小部件引入到小部件树中,这是显示ModalBottomSheet方法正常工作所必需的。因此,如果您将showModalBottomSheet与MaterialApp和Scaffold一起声明在同一个StatelessWidget中,则上下文是相同的,并且此上下文中没有MaterialApp和Scaffold组件,当构建方法完成时,它们将被引入小部件树中。

相反,如果你在一个单独的小部件中声明你的组件,那么你的新小部件的构建方法的BuildContext上下文属性确实有关于之前创建的材料小部件的数据,所以这就是它按预期工作的原因。

您必须使用showModalBottomSheet而不是showBottomSheet-

最新更新