前言:
在Flutter應(yīng)用中,導(dǎo)航欄切換頁面后默認情況下會丟失原頁面狀態(tài),即每次進入頁面時都會重新初始化狀態(tài),如果在initState中打印日志,會發(fā)現(xiàn)每次進入時都會輸出,顯然這樣增加了額外的開銷,并且?guī)砹瞬缓玫挠脩趔w驗。
在正文之前,先看一些常見的App導(dǎo)航,以喜馬拉雅FM為例:
它擁有一個固定的底部導(dǎo)航以及首頁的頂部導(dǎo)航,可以看到不管是點擊底部導(dǎo)航切換頁面還是在首頁左右側(cè)滑切換頁面,之前的頁面狀態(tài)都是始終維持的,下面就具體介紹下如何在flutter中實現(xiàn)類似喜馬拉雅的導(dǎo)航效果
第一步:實現(xiàn)固定的底部導(dǎo)航
在通過flutter create生成的項目模板中,我們先簡化一下代碼,將MyHomePage提取到一個單獨的home.dart文件,并在Scaffold腳手架中添加bottomNavigationBar底部導(dǎo)航,在body中展示當前選中的子頁面。
/// home.dart import 'package:flutter/material.dart'; import './pages/first_page.dart'; import './pages/second_page.dart'; import './pages/third_page.dart'; class MyHomePage extends StatefulWidget { @override _MyHomePageState createState() => _MyHomePageState(); } class _MyHomePageState extends State<MyHomePage> { final items = [ BottomNavigationBarItem(icon: Icon(Icons.home), title: Text('首頁')), BottomNavigationBarItem(icon: Icon(Icons.music_video), title: Text('聽')), BottomNavigationBarItem(icon: Icon(Icons.message), title: Text('消息')) ]; final bodyList = [FirstPage(), SecondPage(), ThirdPage()]; int currentIndex = 0; void onTap(int index) { setState(() { currentIndex = index; }); } @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text('demo'), ), bottomNavigationBar: BottomNavigationBar( items: items, currentIndex: currentIndex, onTap: onTap ), body: bodyList[currentIndex] ); } }
本文標題:Flutter實現(xiàn)頁面切換后保持原頁面狀態(tài)的3種方法-創(chuàng)新互聯(lián)
文章鏈接:http://chinadenli.net/article4/pecie.html
成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開發(fā)、標簽優(yōu)化、動態(tài)網(wǎng)站、品牌網(wǎng)站制作、搜索引擎優(yōu)化、網(wǎng)站建設(shè)
聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)
猜你還喜歡下面的內(nèi)容