flutter3默认空白页
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | import 'package:flutter/material.dart' ; void main() { runApp( const MyApp()); } class MyApp extends StatelessWidget { const MyApp({super.key}); @ override Widget build(BuildContext context) { return MaterialApp( title: '程序名称' , theme: ThemeData( colorScheme: ColorScheme.fromSeed(seedColor: Colors.deepPurple), useMaterial3: true , ), home: const MyHomePage(title: '顶部标题' ), ); } } class MyHomePage extends StatefulWidget { const MyHomePage({super.key, required this .title}); final String title; @ override State<MyHomePage> createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { @ override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( backgroundColor: Theme.of(context).colorScheme.inversePrimary, title: Text(widget.title), ), body: SafeArea( child: Container(), ), ); } } |
删除了
1 2 3 4 5 6 7 8 9 10 11 12 13 | int _counter = 0; void _incrementCounter() { setState(() { _counter++; }); } floatingActionButton: FloatingActionButton( onPressed: _incrementCounter, tooltip: 'Increment' , child: const Icon(Icons.add), ), |
删除了
1 2 3 4 5 6 7 8 9 10 11 12 13 14 | body: Center( child: Column( mainAxisAlignment: MainAxisAlignment.center, children: <Widget>[ const Text( 'You have pushed the button this many times:' , ), Text( '$_counter' , style: Theme.of(context).textTheme.headlineMedium, ), ], ), ), |
替换为
1 2 3 | body: SafeArea( child: Container(), ), |
记录最终例子
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 | import 'package:flutter/material.dart' ; void main() { runApp( const GoWaterMyApp()); } class GoWaterMyApp extends StatelessWidget { const GoWaterMyApp({super.key}); @ override Widget build(BuildContext context) { return MaterialApp( title: '程序名称' , theme: ThemeData( colorScheme: ColorScheme.fromSeed(seedColor: Colors.lightBlue), useMaterial3: true , ), home: const MyHomePage(title: '顶部标题' ), ); } } class MyHomePage extends StatefulWidget { const MyHomePage({super.key, required this .title}); final String title; @ override State<MyHomePage> createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { @ override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( backgroundColor: Theme.of(context).colorScheme.inversePrimary, title: Text(widget.title), ), body: SafeArea( child: Container(), ), ); } } |
【推荐】国内首个AI IDE,深度理解中文开发场景,立即下载体验Trae
【推荐】编程新体验,更懂你的AI,立即体验豆包MarsCode编程助手
【推荐】抖音旗下AI助手豆包,你的智能百科全书,全免费不限次数
【推荐】轻量又高性能的 SSH 工具 IShell:AI 加持,快人一步
· 终于写完轮子一部分:tcp代理 了,记录一下
· 震惊!C++程序真的从main开始吗?99%的程序员都答错了
· 别再用vector<bool>了!Google高级工程师:这可能是STL最大的设计失误
· 单元测试从入门到精通
· 【硬核科普】Trae如何「偷看」你的代码?零基础破解AI编程运行原理