Flutter Snackbar 关闭监听器

15 dart flutter

我正在寻找一种方法来检查是否Snackbar已被用户或超时的东西解雇。我真的无法让任何听众知道这样做。

这是我目前得到的

Scaffold.of(context)
    .showSnackBar(SnackBar(content: Text("Title")))
    .closed
    .then((reason) {
  // snackbar is now closed
});
Run Code Online (Sandbox Code Playgroud)

这是一种方法,我正在寻找确切的听众。我不希望任何解决办法,如设置durationSnackbar,然后持续时间过后听它。

小智 6

请参阅下面的完整示例,我只是用它包装了SnackBar内容,WillPopoScope如果用户按下后退按钮,它将删除小吃店。
默认情况下,它会指定SnackBarClosedReason.remove原因

导入 'package:flutter/material.dart';

void main() => runApp(MyApp());

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: Scaffold(
        appBar: AppBar(),
        body: FirstPage(),
      ),
    );
  }
}

class FirstPage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Center(
      child: ElevatedButton(
        child: Text('go to test page'),
        onPressed: () => Navigator.of(context).push(MaterialPageRoute(builder: (context) => Test())),
      ),
    );
  }
}

class Test extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      body: Center(
        child: ElevatedButton(
          child: Text('show snack'),
          onPressed: () => _showSnack(context),
        ),
      ),
    );
  }

  void _showSnack(BuildContext context) {
    ScaffoldMessenger.of(context)
        .showSnackBar(
          SnackBar(
            content: WillPopScope(
              onWillPop: () async {
                ScaffoldMessenger.of(context).removeCurrentSnackBar();
                return true;
              },
              child: Text("Title"),
            ),
          ),
        )
        .closed
        .then((reason) {
      print('------------ $reason');
    });
  }
}
Run Code Online (Sandbox Code Playgroud)