DEV Community

Cover image for Adding a snackbar in Flutter
Chris Bongers
Chris Bongers

Posted on • Originally published at daily-dev-tips.com

Adding a snackbar in Flutter

I don't mean the Dutch word snackbar (see image below), but a toast-like message that we can use to feedback to the user.

Adding a snackbar in Flutter

Using snackbars in mobile apps is very common as they are a perfect way to provide valuable feedback.

For today's article, I will be using my Flutter hello world app as the starting point.

Requirements for a Flutter snackbar

The cool part is that the only requirement for using a snackbar in Flutter is wrapping our application in a scaffold.
Something we do most of the time anyway.

We can then use something called the ScaffoldMessenger to send a message on specific actions.

Snackbars themselves can have options in return which we'll also have a look at.

Invoking a snackbar in Flutter

Let's add a button to our application so we can use that to invoke our snackbar.

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Center(
      child: ElevatedButton(
        onPressed: () {},
        child: const Text('Open the snackbar'),
      ),
    );
  }
}
Enter fullscreen mode Exit fullscreen mode

This code will give us an empty button.

Button on Flutter application

Inside this button, we have the onPressed method, which we'll use to bind our action sheet.

onPressed: () {
  final snackbar = SnackBar(
    content: const Text('Hello world, Snackbar here!'),
  );
  ScaffoldMessenger.of(context).showSnackBar(snackbar);
},
Enter fullscreen mode Exit fullscreen mode

Now, when we click our button, the snackbar will show at the bottom of our screen.

Flutter snackbar in action

Adding an action to the Flutter snackbar

We can also use the snackbar to give the user action.
This might be to undo something they just did.

For instance: User changes a row, the snackbar will show: Successfully modified row x. Then we can have an undo button to revert this change again.

That code will look like this:

onPressed: () {
  final snackbar = SnackBar(
    content: const Text('Successfully modified row x'),
    action: SnackBarAction(
      label: 'Undo',
      onPressed: () {
        // Add your undo code here
      },
    ),
  );
  ScaffoldMessenger.of(context).showSnackBar(snackbar);
},
Enter fullscreen mode Exit fullscreen mode

You need to implement the code that will undo the action you just did in the onPressed callback.

Note: A snackbar is designed only to have one action. For multiple actions, we should use a dialog.

Flutter snackbar actions

If you want to see the source code, you can find that on GitHub.

Thank you for reading, and let's connect!

Thank you for reading my blog. Feel free to subscribe to my email newsletter and connect on Facebook or Twitter

Top comments (0)