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。
相关推荐
We་ct14 分钟前
LeetCode 918. 环形子数组的最大和:两种解法详解
前端·数据结构·算法·leetcode·typescript·动态规划·取反
wefly20171 小时前
m3u8live.cn 在线M3U8播放器,免安装高效验流排错
前端·后端·python·音视频·前端开发工具
C澒1 小时前
微前端容器标准化 —— 公共能力篇:通用打印
前端·架构
德育处主任Pro1 小时前
前端元素转图片,dom-to-image-more入门教程
前端·javascript·vue.js
木斯佳2 小时前
前端八股文面经大全:小红书前端一二面OC(下)·(2026-03-17)·面经深度解析
前端·vue3·proxy·八股·响应式
陈天伟教授2 小时前
人工智能应用- 预测新冠病毒传染性:04. 中国:强力措施遏制疫情
前端·人工智能·安全·xss·csrf
zayzy2 小时前
前端八股总结
开发语言·前端·javascript
今天减肥吗2 小时前
前端面试题
开发语言·前端·javascript
Rabbit_QL3 小时前
【前端UI行话】前端 UI 术语速查表
前端·ui·状态模式
小码哥_常3 小时前
一文带你吃透Android BLE蓝牙开发全流程
前端