欧美bbbwbbbw肥妇,免费乱码人妻系列日韩,一级黄片

Flutter?GetPageRoute實(shí)現(xiàn)嵌套導(dǎo)航學(xué)習(xí)

 更新時(shí)間:2022年08月11日 15:22:46   作者:潛水的魚兒  
這篇文章主要為大家介紹了Flutter?GetPageRoute實(shí)現(xiàn)嵌套導(dǎo)航的示例學(xué)習(xí),有需要的朋友可以借鑒參考下,希望能夠有所幫助,祝大家多多進(jìn)步,早日升職加薪

1. 嵌套導(dǎo)航-GetPageRoute

本文主要介紹在Getx下快速實(shí)現(xiàn)一個(gè)嵌套導(dǎo)航

嵌套導(dǎo)航顧名思義,我們導(dǎo)航頁面中嵌套一個(gè)獨(dú)立的路由,效果如下

點(diǎn)擊跳轉(zhuǎn)

代碼如下,也是比較簡單

return Scaffold(
  appBar: AppBar(title: const Text('嵌套導(dǎo)航'),),
  body: Navigator(
      key: Get.nestedKey(1), // create a key by index
      initialRoute: '/',
      onGenerateRoute: (settings) {
        if (settings.name == '/') {
          return GetPageRoute(
            page: () => Scaffold(
              appBar: AppBar(
                title: const Text("首頁"), backgroundColor: Colors.blue
              ),
              body: Center(
                child: ElevatedButton(
                  onPressed: () {
                    Get.toNamed('/second', id:1); // navigate by your nested route by index
                  },
                  child: const Text("跳轉(zhuǎn)下一頁"),
                ),
              ),
            ),
          );
        } else if (settings.name == '/second') {
          return GetPageRoute(
            page: () => Center(
              child: Scaffold(
                appBar: AppBar(
                  title: const Text("第二頁"),backgroundColor: Colors.blue
                ),
                body: const Center(
                    child:  Text("第二頁")
                ),
              ),
            ),
          );
        }
      }
  ),
);

通過Navigator這個(gè)widget把我們的路由放入新的導(dǎo)航中,通過onGenerateRoute來區(qū)分頁面的路由跳轉(zhuǎn),key使用的是Get.nestedKey(1)來區(qū)分具體頁面。GetPageRoute創(chuàng)建路由頁面

2. 自定義拓展

我們也可以添加占位圖,用于存放一些廣告頁

 Column(
  children: [
    Container(
      color: Colors.amberAccent,
      height: 100,
      child: const Center(child: Text('我是輪播圖')),
    ),
    Expanded(
      child: Navigator())]

這里使用Column進(jìn)行包裹,Expanded撐開下部分。

3. 使用bottomNavigationBar

class NestedNavigatePage extends StatelessWidget {
  const NestedNavigatePage({Key? key}) : super(key: key);
  @override
  Widget build(BuildContext context) {
    final logic = Get.find<NestedNavigateLogic>();
    final state = Get.find<NestedNavigateLogic>().state;
    return Scaffold(
      appBar: AppBar(title: const Text('嵌套導(dǎo)航'),),
      body: Column(
        children: [
          Container(
            color: Colors.amberAccent,
            height: 100,
            child: const Center(child: Text('我是輪播圖')),
          ),
          Expanded(
            child: Navigator(
                key: Get.nestedKey(1), // create a key by index
                initialRoute: '/home',
                onGenerateRoute: logic.onGenerateRoute,
            ),
          ),
        ],
      ),
      bottomNavigationBar:Obx(() => BottomNavigationBar(
        items: const [
          BottomNavigationBarItem(icon: Icon(Icons.home),label: '首頁'),
          BottomNavigationBarItem(icon: Icon(Icons.list),label: '列表'),
          BottomNavigationBarItem(icon: Icon(Icons.people),label:'我的'),
        ],
        currentIndex: state.selectIndex.value,
        onTap: logic.selectTabBarIndex,
        selectedItemColor: Colors.red,
      )),
    );
  }
}
  • state 中定義數(shù)據(jù)
class NestedNavigateState {
 var selectIndex = 0.obs;
 List<String> pages = ['/home','/list','/mine'];
  NestedNavigateState() {
    ///Initialize variables
  }
}
  • logic 中實(shí)現(xiàn)邏輯
import 'package:flutter/material.dart';
import 'package:get/get.dart';
import 'nested_navigate_state.dart';
class NestedNavigateLogic extends GetxController {
  final NestedNavigateState state = NestedNavigateState();
  selectTabBarIndex( int index){
    state.selectIndex.value = index;
    Get.toNamed(state.pages[index],id: 1);
  }
  Route? onGenerateRoute(RouteSettings settings) {
    return GetPageRoute(
      settings: settings,
      page: () => page(settings.name!),
      transition: Transition.leftToRightWithFade,
    );
  }
  Widget page(String title) {
   return Center(
        child: Scaffold(
            // appBar: AppBar(
            //     title:  Text(title), backgroundColor: Colors.blue
            // ),
            body: Center(
                child: Text(title)
            )
        ));
  }
}

點(diǎn)擊通過obx自動(dòng)響應(yīng)

4.小結(jié)

我們通過GetPageRoute可以進(jìn)行導(dǎo)航嵌套,方便我們實(shí)現(xiàn)一些特定需求。同時(shí)我們可以配合bottomNavigationBar實(shí)現(xiàn)tabbr效果。 創(chuàng)建平行導(dǎo)航堆棧可能是危險(xiǎn)的。

理想的情況是不要使用NestedNavigators,或者盡量少用。如果你的項(xiàng)目需要它,請(qǐng)繼續(xù),但請(qǐng)記住,在內(nèi)存中保持多個(gè)導(dǎo)航堆??赡懿皇且粋€(gè)好主意。

以上就是Flutter GetPageRoute實(shí)現(xiàn)嵌套導(dǎo)航學(xué)習(xí)的詳細(xì)內(nèi)容,更多關(guān)于Flutter GetPageRoute嵌套導(dǎo)航的資料請(qǐng)關(guān)注腳本之家其它相關(guān)文章!

相關(guān)文章

最新評(píng)論