flutter中bottomNavigationBar切換組件保存狀態(tài)方案

原文鏈接 https://www.aiprose.com/blog/107

我們在開發(fā)的時候用底部導(dǎo)航欄是很常見的仁卷,flutter給我們默認(rèn)帶了bottomNavigationBar襟己,但是發(fā)現(xiàn)你直接這樣寫的時候,點擊導(dǎo)航欄切換組建的時候型宙,每次都會刷新狀態(tài),這用戶體驗是很不好的伦吠,今天給大家一種效率超高的解決方案妆兑,就是用PageView+AutomaticKeepAliveClientMixin組合實現(xiàn)狀態(tài)保存,切換組件的時候不刷新毛仪。

image

1.首先在有bottomNavigationBar的組件中加入pageview

/*
   * 存儲的四個頁面搁嗓,和android 中的 Fragment一樣
   */
  var _pages;
  void initData() {
    _pages = [
      new WebPage(),
      new DiscoverPage(),
      new UserPage(),
    ];
  }
PageView.builder(
 //要點1
 physics: NeverScrollableScrollPhysics(),
 //禁止頁面左右滑動切換
 controller: _pageController,
 onPageChanged: _pageChanged,
 //回調(diào)函數(shù)
 itemCount: _pages.length,
 itemBuilder: (context, index) => _pages[index]),
image

全部的代碼

class MainPage extends StatefulWidget {
  @override
  _MainPageState createState() => _MainPageState();
}
class _MainPageState extends State<MainPage> {
  int _tabIndex = 0;
  var tabImages;
  var appBarTitles = ['首頁', '發(fā)現(xiàn)', '我的'];
  var _pageController = PageController();
  Text getTabTitle(int curIndex) {
    if (curIndex == _tabIndex) {
      return new Text(appBarTitles[curIndex]);
    } else {
      return new Text(appBarTitles[curIndex]);
    }
  }
  /*
   * 存儲的四個頁面,和Fragment一樣
   */
  var _pages;
  void initData() {
    _pages = [
      new WebPage(),
      new DiscoverPage(),
      new UserPage(),
    ];
  }
  @override
  Widget build(BuildContext context) {
    initData();
    return Scaffold(
      body: SafeArea(
        child: PageView.builder(
            //要點1
            physics: NeverScrollableScrollPhysics(),
            //禁止頁面左右滑動切換
            controller: _pageController,
            onPageChanged: _pageChanged,
            //回調(diào)函數(shù)
            itemCount: _pages.length,
            itemBuilder: (context, index) => _pages[index]),
      ),
      bottomNavigationBar: new BottomNavigationBar(
        items: <BottomNavigationBarItem>[
          new BottomNavigationBarItem(
              icon: Icon(IconData(0xe71a, fontFamily: "iconfont")),
              title: getTabTitle(0)),
          new BottomNavigationBarItem(
              icon: Icon(IconData(0xe746, fontFamily: "iconfont")),
              title: getTabTitle(1)),
          new BottomNavigationBarItem(
              icon: Icon(IconData(0xe636, fontFamily: "iconfont")),
              title: getTabTitle(2)),
        ],
        type: BottomNavigationBarType.fixed,
        fixedColor: Colors.green,
        currentIndex: _tabIndex,
        onTap: (index) {
          print('onTap');
          _pageController.jumpToPage(index);
        },
      ),
    );
  }
  void _pageChanged(int index) {
    print('_pageChanged');
    setState(() {
      if (_tabIndex != index) _tabIndex = index;
    });
  }
}

這個時候我們發(fā)現(xiàn)頁面可以切換了箱靴,但是狀態(tài)還是沒有保存下來腺逛,接下來我們要修改其他的組件了。

2.在組件中實現(xiàn)AutomaticKeepAliveClientMixin

讓我們的state實現(xiàn)with AutomaticKeepAliveClientMixin衡怀,必須要重寫一個方法

@override 
bool get wantKeepAlive => true;
image

這兩個必須要組合使用棍矛,才能實現(xiàn)保存狀態(tài)不刷新,每個需要保存狀態(tài)的組件都要with AutomaticKeepAliveClientMixin抛杨。

最后編輯于
?著作權(quán)歸作者所有,轉(zhuǎn)載或內(nèi)容合作請聯(lián)系作者
  • 序言:七十年代末够委,一起剝皮案震驚了整個濱河市,隨后出現(xiàn)的幾起案子蝶桶,更是在濱河造成了極大的恐慌慨绳,老刑警劉巖,帶你破解...
    沈念sama閱讀 217,084評論 6 503
  • 序言:濱河連續(xù)發(fā)生了三起死亡事件真竖,死亡現(xiàn)場離奇詭異脐雪,居然都是意外死亡,警方通過查閱死者的電腦和手機(jī)恢共,發(fā)現(xiàn)死者居然都...
    沈念sama閱讀 92,623評論 3 392
  • 文/潘曉璐 我一進(jìn)店門战秋,熙熙樓的掌柜王于貴愁眉苦臉地迎上來,“玉大人讨韭,你說我怎么就攤上這事脂信。” “怎么了透硝?”我有些...
    開封第一講書人閱讀 163,450評論 0 353
  • 文/不壞的土叔 我叫張陵狰闪,是天一觀的道長。 經(jīng)常有香客問我濒生,道長埋泵,這世上最難降的妖魔是什么? 我笑而不...
    開封第一講書人閱讀 58,322評論 1 293
  • 正文 為了忘掉前任,我火速辦了婚禮丽声,結(jié)果婚禮上礁蔗,老公的妹妹穿的比我還像新娘。我一直安慰自己雁社,他們只是感情好浴井,可當(dāng)我...
    茶點故事閱讀 67,370評論 6 390
  • 文/花漫 我一把揭開白布。 她就那樣靜靜地躺著霉撵,像睡著了一般磺浙。 火紅的嫁衣襯著肌膚如雪。 梳的紋絲不亂的頭發(fā)上喊巍,一...
    開封第一講書人閱讀 51,274評論 1 300
  • 那天屠缭,我揣著相機(jī)與錄音箍鼓,去河邊找鬼崭参。 笑死,一個胖子當(dāng)著我的面吹牛款咖,可吹牛的內(nèi)容都是我干的何暮。 我是一名探鬼主播,決...
    沈念sama閱讀 40,126評論 3 418
  • 文/蒼蘭香墨 我猛地睜開眼铐殃,長吁一口氣:“原來是場噩夢啊……” “哼海洼!你這毒婦竟也來了?” 一聲冷哼從身側(cè)響起富腊,我...
    開封第一講書人閱讀 38,980評論 0 275
  • 序言:老撾萬榮一對情侶失蹤坏逢,失蹤者是張志新(化名)和其女友劉穎,沒想到半個月后赘被,有當(dāng)?shù)厝嗽跇淞掷锇l(fā)現(xiàn)了一具尸體是整,經(jīng)...
    沈念sama閱讀 45,414評論 1 313
  • 正文 獨居荒郊野嶺守林人離奇死亡,尸身上長有42處帶血的膿包…… 初始之章·張勛 以下內(nèi)容為張勛視角 年9月15日...
    茶點故事閱讀 37,599評論 3 334
  • 正文 我和宋清朗相戀三年民假,在試婚紗的時候發(fā)現(xiàn)自己被綠了浮入。 大學(xué)時的朋友給我發(fā)了我未婚夫和他白月光在一起吃飯的照片。...
    茶點故事閱讀 39,773評論 1 348
  • 序言:一個原本活蹦亂跳的男人離奇死亡羊异,死狀恐怖事秀,靈堂內(nèi)的尸體忽然破棺而出,到底是詐尸還是另有隱情野舶,我是刑警寧澤易迹,帶...
    沈念sama閱讀 35,470評論 5 344
  • 正文 年R本政府宣布,位于F島的核電站平道,受9級特大地震影響睹欲,放射性物質(zhì)發(fā)生泄漏。R本人自食惡果不足惜巢掺,卻給世界環(huán)境...
    茶點故事閱讀 41,080評論 3 327
  • 文/蒙蒙 一句伶、第九天 我趴在偏房一處隱蔽的房頂上張望劲蜻。 院中可真熱鬧,春花似錦考余、人聲如沸先嬉。這莊子的主人今日做“春日...
    開封第一講書人閱讀 31,713評論 0 22
  • 文/蒼蘭香墨 我抬頭看了看天上的太陽疫蔓。三九已至,卻和暖如春身冬,著一層夾襖步出監(jiān)牢的瞬間衅胀,已是汗流浹背。 一陣腳步聲響...
    開封第一講書人閱讀 32,852評論 1 269
  • 我被黑心中介騙來泰國打工酥筝, 沒想到剛下飛機(jī)就差點兒被人妖公主榨干…… 1. 我叫王不留滚躯,地道東北人。 一個月前我還...
    沈念sama閱讀 47,865評論 2 370
  • 正文 我出身青樓嘿歌,卻偏偏與公主長得像掸掏,于是被迫代替她去往敵國和親。 傳聞我的和親對象是個殘疾皇子宙帝,可洞房花燭夜當(dāng)晚...
    茶點故事閱讀 44,689評論 2 354