1

我最近在 Flutter 中遇到了一个我无法解释的奇怪行为。考虑为 WEB 平台构建的以下代码:

import 'package:flutter/material.dart';

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

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    return MaterialApp(
      title: 'Flutter Hello World',
      theme: ThemeData(
        primarySwatch: Colors.blue,
      ),
      home: const MyHomePage(title: 'Flutter Demo Home Page'),
    );
  }
}

class MyHomePage extends StatelessWidget {
  final String title;

  const MyHomePage({this.title = "Home Page"});

  @override
  Widget build(BuildContext context) {
    return Scaffold(
      appBar: AppBar(
        title: Text(title),
      ),
      body: const Center(
        child: Text(
          'Hello, World!',
        ),
      ),
      floatingActionButton: FloatingActionButton(
        onPressed: () => showModalBottomSheet(
          context: context,
          isScrollControlled: true,
          builder: (_) => DraggableScrollableSheet(
            expand: false,
            builder: (_, ScrollController scrollController) {
              return ListView(
                controller: scrollController,
                children: [for (var i = 0; i < 250; i++) Text("Item: $i")],
              );
            },
          ),
          shape: const RoundedRectangleBorder(
              borderRadius: BorderRadius.vertical(top: Radius.circular(20))),
        ),
        tooltip: "Open Sheet!",
        child: const Icon(Icons.add),
      ),
    );
  }
}

从移动设备打开时,它工作得非常好并且符合预期:DraggableScrollableSheet被打开,占用屏幕高度的 50%,然后它的ListView内部可能会随着工作表本身滚动,所以它将占用屏幕高度的 0% 到 100%屏幕。
但是,如果在桌面浏览器中打开,则只会拒绝与鼠标滚轮旋转DraggableScrollableSheet一起滚动。ListView它只是坚持50%,只能关闭,永远不能扩大​​!
我错过了什么?它是一个颤振错误吗?如何使其按预期在桌面浏览器中工作?

PS 这里是我的应用程序中行为的一个稍微复杂的示例,托管在 GitHub 页面上;要ModalBottomSheet打开,您应该触摸圣彼得堡中心的 Flutter 图标。

4

0 回答 0