成人午夜视频全免费观看高清-秋霞福利视频一区二区三区-国产精品久久久久电影小说-亚洲不卡区三一区三区一区

Flutter實(shí)現(xiàn)頁(yè)面切換后保持原頁(yè)面狀態(tài)的3種方法-創(chuàng)新互聯(lián)

前言:

成都創(chuàng)新互聯(lián)-專(zhuān)業(yè)網(wǎng)站定制、快速模板網(wǎng)站建設(shè)、高性?xún)r(jià)比利津網(wǎng)站開(kāi)發(fā)、企業(yè)建站全套包干低至880元,成熟完善的模板庫(kù),直接使用。一站式利津網(wǎng)站制作公司更省心,省錢(qián),快速模板網(wǎng)站建設(shè)找我們,業(yè)務(wù)覆蓋利津地區(qū)。費(fèi)用合理售后完善,十年實(shí)體公司更值得信賴(lài)。

在Flutter應(yīng)用中,導(dǎo)航欄切換頁(yè)面后默認(rèn)情況下會(huì)丟失原頁(yè)面狀態(tài),即每次進(jìn)入頁(yè)面時(shí)都會(huì)重新初始化狀態(tài),如果在initState中打印日志,會(huì)發(fā)現(xiàn)每次進(jìn)入時(shí)都會(huì)輸出,顯然這樣增加了額外的開(kāi)銷(xiāo),并且?guī)?lái)了不好的用戶體驗(yàn)。
在正文之前,先看一些常見(jiàn)的App導(dǎo)航,以喜馬拉雅FM為例:

它擁有一個(gè)固定的底部導(dǎo)航以及首頁(yè)的頂部導(dǎo)航,可以看到不管是點(diǎn)擊底部導(dǎo)航切換頁(yè)面還是在首頁(yè)左右側(cè)滑切換頁(yè)面,之前的頁(yè)面狀態(tài)都是始終維持的,下面就具體介紹下如何在flutter中實(shí)現(xiàn)類(lèi)似喜馬拉雅的導(dǎo)航效果


第一步:實(shí)現(xiàn)固定的底部導(dǎo)航


在通過(guò)flutter create生成的項(xiàng)目模板中,我們先簡(jiǎn)化一下代碼,將MyHomePage提取到一個(gè)單獨(dú)的home.dart文件,并在Scaffold腳手架中添加bottomNavigationBar底部導(dǎo)航,在body中展示當(dāng)前選中的子頁(yè)面。


/// 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('首頁(yè)')),
 BottomNavigationBarItem(icon: Icon(Icons.music_video), title: Text('聽(tīng)')),
 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]
 );
 }
}

本文標(biāo)題:Flutter實(shí)現(xiàn)頁(yè)面切換后保持原頁(yè)面狀態(tài)的3種方法-創(chuàng)新互聯(lián)
文章鏈接:http://jinyejixie.com/article4/pecie.html

成都網(wǎng)站建設(shè)公司_創(chuàng)新互聯(lián),為您提供定制開(kāi)發(fā)標(biāo)簽優(yōu)化、動(dòng)態(tài)網(wǎng)站品牌網(wǎng)站制作、搜索引擎優(yōu)化網(wǎng)站建設(shè)

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權(quán)請(qǐng)盡快告知,我們將會(huì)在第一時(shí)間刪除。文章觀點(diǎn)不代表本網(wǎng)站立場(chǎng),如需處理請(qǐng)聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時(shí)需注明來(lái)源: 創(chuàng)新互聯(lián)

手機(jī)網(wǎng)站建設(shè)
平阳县| 东明县| 察隅县| 克山县| 通河县| 合水县| 山东省| 荔浦县| 洪泽县| 龙山县| 绵阳市| 潮州市| 潮州市| 肇庆市| 自治县| 自治县| 广水市| 柳江县| 汉川市| 长兴县| 灵寿县| 聂拉木县| 杭锦旗| 图木舒克市| 芷江| 罗定市| 高雄县| 平度市| 红河县| 诏安县| 台北县| 左权县| 新乡县| 白朗县| 长治县| 余干县| 云安县| 桂阳县| 理塘县| 什邡市| 恩施市|