Flutter 3 基础05: 切换导航页面

创建应用导航一文中,我们为应用增加了一个底部导航栏,点击导航图标,也可以正常切换。但是,美中不足的是,不论你点击哪个导航图标,屏幕中间的内容区域都是一片空白。现在我们就来解决这个问题。

启动 Android Studio,打开 hello_world 项目,运行模拟器,这样就可以实时看到编码产生的效果。当然,现在只能看到空白的导航页面。

为什么显示空白

我们先来搞清楚页面一直显示空白的原因。

找到并打开 main.dart 文件,在 _HomePageState 类的 build 方法中,找到下面的代码:

dart 复制代码
body: SafeArea(  
  child: Container(),  
),

我们先来简单解释一下这段代码。

  • body: body 属性是用来设置屏幕要显示什么内容。
  • SafeArea: 调用 SafeArea 方法是确保我们的内容显示在"安全区域",不会被手机操作系统固有的界面内容所影响或遮挡。
  • child: child 属性是实际我们配置要显示的内容的地方。

可以看到,child 属性的值是 Container() 方法返回的一个空容器,里面没有放置任何东西,这也是我们看到空白屏幕的原因。而且,这个属性的值是固定的,不会因为我们点击了导航图标而改变,这也是为什么我们点击导航图标,也一直白屏的原因。

创建导航页面

为了能给切换不同的页面,我们首先需要创建这些页面。

继续在 main.dart 文件中,找到下列这行代码:

dart 复制代码
int _selectedIndex = 0;

在这行代码的下面,添加以下代码:

dart 复制代码
// 创建一组彩色的容器  
static List<Widget> pages = <Widget>[  
  Container(color: Colors.red),  
  Container(color: Colors.green),  
  Container(color: Colors.blue)  
];

这是一个静态方法,创建了一组简单的彩色容器:红,绿,蓝。在这里,我们依然让每个页面显示一个 Container 容器,通过 color 属性,为每个容器配置了不同的背景色(虽然不美,但可以让我们区分每个页面,你可以设置你喜欢的颜色)。

切换导航页面

现在,我们可以让用户点击不同的导航图标时,显示不同颜色的页面。

继续在 main.dart 文件中,找到下列这三行代码:

dart 复制代码
body: SafeArea(  
  child: Container(),  
),

把其中第二行代码 child: Container(), , 替换为下面的代码:

dart 复制代码
child: pages[_selectedIndex],

保存文件。如果你已经打开虚拟机,保持程序运行,你就会发现白色的页面已经变成了红色页面。

验证效果

点击部件导航图标,可以看到绿色的页面:

点击设置导航图标,可以看到蓝色的页面:

虽然页面现在显示的内容比较简单,只是展示了不同的背景颜色,但是,随着我们不断的学习和探索,会让页面呈现更丰富的内容。

提交代码

我们已经实现了应用底部导航页面的切换,又到达了一个小小的里程碑,应该对代码进行提交,保持良好编程习惯。

shell 复制代码
git add .
git commit -m '实现应用导航页面的切换。'
相关推荐
程序员老刘4 小时前
跑分第一的编程大模型,我为啥不用?
flutter·ai编程·vibecoding
橙子家4 小时前
浏览器缓存之【身份与会话管理】:Cookies 和 Private state tokens
前端
最新资讯动态5 小时前
HDC 2026 | 对话鲸鸿动能:存量时代,品牌如何夺回营销“主动权”?
前端
最新资讯动态5 小时前
游戏出海,从产品走向体系
前端
最新资讯动态5 小时前
20人团队跑出百万DAU、大厂也来抢量:谁在鸿蒙生态跑出加速度
前端
最新资讯动态6 小时前
千万开发者背后,鸿蒙商业化的B面
前端
爱勇宝7 小时前
AI 时代:智商决定起点,情商决定走多远
前端·ai编程
kyriewen8 小时前
用了半年 Claude Code 后,我尝试关掉它写了一周代码——结果比想象中严重
前端·javascript·ai编程
IT_陈寒8 小时前
Vite的静态资源打包让我熬夜到三点,这坑千万别跳
前端·人工智能·后端
徐小夕9 小时前
万字拆解 JitWord:企业级实时协同文档底层架构 + 大模型 AI 融合完整实践
前端·vue.js·github