У меня есть класс, расширяющий StatelessWidget. При попытке вызвать SnackBars в Scaffold, например:
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
actions: <Widget>[
IconButton(
splashRadius: 18,
icon: const Icon(Icons.thumb_up),
tooltip: 'Like the app',
onPressed: () {
final SnackBar snackBar = SnackBar(
duration: const Duration(seconds: 1),
content: const Text('Registered as you like the application.'),
action: SnackBarAction(
label: 'Undo',
onPressed: () {},
),
);
ScaffoldMessenger.of(context).showSnackBar(snackBar);
},
),
],
title: const Text('My Application'),),
body: const Center(
child: Text("Hello World!"),)
);
}
}
при запуске приложение показывает ошибку, например:
Произошло исключение. FlutterError (виджет ScaffoldMessenger не найден. Для виджетов MyApp требуется предок виджета ScaffoldMessenger. Конкретный виджет, который не смог найти предка ScaffoldMessenger, был: Мое приложение Предками этого виджета были: [корень] Как правило, виджет ScaffoldMessenger представлен приложением MaterialApp в верхней части дерева виджетов вашего приложения.)
Оберните свое приложение MaterialApp
, например
void main() => runApp(MaterialApp(home: MyApp()));
@anasrokbi, поэтому я написал это вне класса. Он должен быть снаружи, потому что иначе вы передадите неправильный context
к ScaffoldMessenger.of(context)
Наконец-то я понял, использую класс Builder и решаю его.. спасибо..
используйте этот код
class MyApp extends StatefulWidget {
const MyApp({super.key});
@override
State<MyApp> createState() => _MyAppState();
}
class _MyAppState extends State<MyApp> {
GlobalKey<ScaffoldMessengerState> key = GlobalKey<ScaffoldMessengerState>();
@override
Widget build(BuildContext context) {
return MaterialApp(
home: ScaffoldMessenger(
key: key,
child: Scaffold(
appBar: AppBar(
actions: <Widget>[
IconButton(
splashRadius: 18,
icon: const Icon(Icons.thumb_up),
tooltip: 'Like the app',
onPressed: () {
final snackBar = SnackBar(
content: Text(
"message",
// style: Theme.of(context).textTheme.regularWhite14,
),
duration: const Duration(seconds: 5),
action: SnackBarAction(
label: 'OK',
textColor: CustomColorScheme.whiteColor,
onPressed: () {},
),
);
key.currentState!.showSnackBar(snackBar);
},
),
],
title: const Text('My Application'),
),
body: const Center(
child: Text("Hello World!"),
)),
),
);
}
}
Оно работает. но в StatefulWidget.. Можем ли мы сделать то же самое в StatelessWidget?? как?
Как сейчас написано, ваш ответ неясен. Пожалуйста, отредактируйте , чтобы добавить дополнительные сведения, которые помогут другим понять, как это отвечает на заданный вопрос. Вы можете найти больше информации о том, как писать хорошие ответы в справочном центре.
Я нашел ответ из видео на YouTube следующим образом:
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
final _scaffoldkey = GlobalKey<ScaffoldMessengerState>();
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
scaffoldMessengerKey: _scaffoldkey,
home: Scaffold(
appBar: AppBar(
actions: <Widget>[
IconButton(
splashRadius: 18,
icon: const Icon(Icons.thumb_up),
tooltip: 'Like the app',
onPressed: () {
final SnackBar snackBar = SnackBar(
duration: const Duration(seconds: 1),
content:
const Text('Registered as you like the application.'),
action: SnackBarAction(
label: 'Undo',
onPressed: () {},
),
);
ScaffoldMessengerState? scaffold = _scaffoldkey.currentState;
scaffold!.showSnackBar(snackBar);
},
),
],
title: const Text('My Application'),
),
body: const Center(
child: Text("Hello World!"),
),
),
);
}
}
Я нашел решение проблемы, но сначала: почему произошла ошибка? Это не удается, потому что ScaffoldMessenger.of(context) не находит ничего выше контекста этого виджета. решение использовать класс Builder следующим образом:
import 'package:flutter/material.dart';
void main() => runApp(MyApp());
class MyApp extends StatelessWidget {
const MyApp({super.key});
@override
Widget build(BuildContext context) {
return MaterialApp(
home: Scaffold(
appBar: AppBar(
actions: <Widget>[
Builder(
builder: (BuildContext context) {
return IconButton(
splashRadius: 18,
icon: const Icon(Icons.thumb_up),
tooltip: 'Like the app',
onPressed: () {
final SnackBar snackBar = SnackBar(
duration: const Duration(seconds: 1),
content: const Text(
'Registered as you like the application.'),
action: SnackBarAction(
label: 'Undo',
onPressed: () {},
),
);
ScaffoldMessenger.of(context).showSnackBar(snackBar);
},
);
},
),
],
title: const Text('My Application'),
),
body: const Center(
child: Text("Hello World!"),
)),
);
}
}
Но: когда Wrap scaffold с MaterialApp в классе MyApp, я получаю ту же ошибку.