Flutter 中的 ScaffoldMessenger 和 MediaQuery 是什么?

Flutter 中的 ScaffoldMessenger 是什么?

ScaffoldMessenger 是 Flutter 2.0 版本中引入的一个类,用于在 Scaffold 小部件中管理和显示瞬态消息,也称为 snackbar 或 toast 通知。

在 Flutter 2.0 之前,您可以使用 Scaffold.of(context) 来显示 SnackBar。但是,这种方法在很多情况下都存在问题,例如,当您需要从一个不是 Scaffold 的直接后代(例如,Scaffold 的深嵌套子代)的部件中显示一个 SnackBar 时。

随着 ScaffoldMessenger 的引入,这个问题得到了解决,ScaffoldMessenger 提供了比以前更可靠和易用的方法。

下面是一个使用 ScaffoldMessenger 来显示 SnackBar 的基本示例:

dart 复制代码
import 'package:flutter/material.dart';

void main() {
  runApp(MaterialApp(
    home: MyHomePage(),
  ));
}
class MyHomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text('ScaffoldMessenger Example'),
      ),
      body: Center(
        child: ElevatedButton(
          onPressed: () {
            // Show a Snackbar using ScaffoldMessenger
            ScaffoldMessenger.of(context).showSnackBar(
              SnackBar(
                content: Text('Hello, Snackbar!'),
              ),
            );
          },
          child: Text('Show Snackbar'),
        ),
      ),
    );
  }
}

在这张截图中,我们展示了一个 Snackbar ScaffoldMessenger。

在这个例子中,我们使用 ScaffoldMessenger.of(context) 来获取当前 BuildContext 的 ScaffoldMessenger 实例,然后在 ScaffoldMessenger 上调用 showSnackBar 来显示 SnackBar。

需要注意的是,ScaffoldMessenger 必须在 Scaffold 上下文中使用,如果尝试在 Scaffold 之外使用它,将会遇到错误,另外,在显示 snackbars 时,最好使用 ScaffoldMessenger 而不是 Scaffold.of(context),以避免任何潜在的运行时问题。

因此,ScaffoldMessenger 提供了一种更可靠、更值得推荐的方式来在 Flutter 应用程序的 Scaffold 中显示瞬态消息。

Flutter 中的 MediaQuery 是什么?

在 Flutter 中,MediaQuery 是一个类,它提供访问当前设备屏幕或显示器最重要的信息的接口,它允许你获取屏幕尺寸、方向等信息。

MediaQuery 类通常用于创建响应式 Flutter 应用程序,以适应各种屏幕大小和方向。

要访问 Flutter 小部件中的 MediaQuery 实例,可以使用 MediaQuery.of(context) 方法,该方法检索小部件树中最近的 MediaQuery 祖先,并返回包含设备屏幕信息的 MediaQueryData 对象。

下面是一个使用 MediaQuery 的基本示例:

dart 复制代码
import 'package:flutter/material.dart';

void main() {
  runApp(MyApp());
}
class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      home: MyHomePage(),
    );
  }
}
class MyHomePage extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    MediaQueryData mediaQueryData = MediaQuery.of(context);
    double screenWidth = mediaQueryData.size.width;
    double screenHeight = mediaQueryData.size.height;
    double pixelDensity = mediaQueryData.devicePixelRatio;
    Orientation orientation = mediaQueryData.orientation;
    return Scaffold(
      appBar: AppBar(
        title: Text('MediaQuery Example'),
      ),
      body: Center(
        child: Column(
          mainAxisAlignment: MainAxisAlignment.center,
          crossAxisAlignment: CrossAxisAlignment.center,
          children: [
            Text('Screen Width: $screenWidth'),
            Text('Screen Height: $screenHeight'),
            Text('Pixel Density: $pixelDensity'),
            Text('Orientation: ${orientation == Orientation.portrait ? 'Portrait' : 'Landscape'}'),
          ],
        ),
      ),
    );
  }
}

这是MediaQuery的屏幕截图

  • 在这个例子中,我们使用 MediaQuery.of(context) 来访问 MediaQueryData 对象,然后提取和显示有关屏幕宽度、屏幕高度、像素密度和设备在应用程序 UI 中的方向的信息。
  • MediaQuery 是创建适应不同设备的响应式 Flutter 布局的关键工具,通过使用 MediaQueryData 中的设备属性,你可以创建在各种屏幕尺寸和方向上看起来很棒的 UI。
相关推荐
LinXunFeng4 小时前
Obsidian - 使用 Share Note 分享笔记并自部署
前端·笔记·github
乘风gg8 小时前
为什么AI 时代来临,大部分人吃不到红利
前端·ai编程·claude
恋猫de小郭8 小时前
Android 限制侧载新进展,谷歌联合国内厂商推验证计划
android·前端·flutter
IT_陈寒8 小时前
Redis内存爆了,原来我漏掉了这个致命配置
前端·人工智能·后端
恋猫de小郭8 小时前
解读 Android 17 全新内存限制,有没有“豁免”后门?
android·前端·flutter
Hyyy10 小时前
理解LLM的基本工作原理:预训练、微调、推理的区别
前端
Gatlin10 小时前
前端逆向与反逆向:一场猫鼠游戏的底层逻辑与实战
前端
Pedantic10 小时前
本地通知(Local Notifications)学习笔记
前端
森蓝情丶11 小时前
我给 AI 搭了个法庭:一个前端仔的 LangGraph 实战全记录
前端·后端
爱勇宝11 小时前
干了近 8 年,一夜之间被裁:AI 时代,程序员最该害怕的不是 AI
前端·后端·程序员