Navigator组件使用的频率不是很高,但在一些场景下非常适用,比如局部表单多页填写、底部导航一直存在,每个tab各自导航场景。

Navigator 是管理路由的控件,通常情况下直接使用Navigator.of(context)的方法来跳转页面,之所以可以直接使用Navigator.of(context)是因为在WidgetsApp中使用了此控件,应用程序的根控件通常是MaterialAppMaterialApp包含WidgetsApp,所以可以直接使用Navigator的相关属性。

Navigator用法非常简单,如下:

Navigator(
 initialRoute: '/',
 onGenerateRoute: (RouteSettings settings) {
 WidgetBuilder builder;
 switch (settings.name) {
  case 'home':
  builder = (context) => PageA();
  break;
  case 'user':
  builder = (context) => PageB();
  break;
 }
 return MaterialPageRoute(builder: builder, settings: settings);
 },
)

initialRoute表示初始化路由,onGenerateRoute表示根据RouteSettings生成路由。

那么在什么情况下需要使用Navigator?在需要局部页面跳转的地方使用Navigator,如下面的场景:

头条客户端举报场景

头条客户端每一个新闻下面都有一个“叉号”,点击弹出相关信息,点击其中的局部,会在当前小窗户内跳转到举报页面,效果如下:

此场景就是使用Navigator的典型场景,点击举报,并不是全屏切换页面,而是仅仅在当前弹出的页面进行切换。

首页代码如下:

@override
Widget build(BuildContext context) {
 return Center(
 child: Container(
  height: 350,
  width: 300,
  child: Navigator(
  initialRoute: '/',
  onGenerateRoute: (RouteSettings settins) {
   WidgetBuilder builder;
   switch (settins.name) {
   case '/':
    builder = (context) => PageC();
    break;
   }
   return MaterialPageRoute(builder: builder);
  },
  ),
 ),
 );
}

Navigator的初始化路由为PageC页面,PageC页面代码如下:

class PageC extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
 return Center(
  child: Card(
  child: Column(
   children: <Widget>[
   _buildItem(Icons.clear, '不感兴趣', '减少这类内容'),
   Divider(),
   _buildItem(Icons.access_alarm, '举报', '标题夸张,内容质量差 等',
    showArrow: true, onPress: () {
    Navigator.of(context).push(MaterialPageRoute(builder: (context) {
    return PageD();
    }));
   }),
   Divider(),
   _buildItem(Icons.perm_identity, '拉黑作者:新华网客户端', ''),
   Divider(),
   _buildItem(Icons.account_circle, '屏蔽', '军事视频、驾驶员等'),
   ],
  ),
  ),
 );
 }

 _buildItem(IconData iconData, String title, String content,
  {bool showArrow = false, Function onPress}) {
 return Row(
  children: <Widget>[
  Icon(iconData),
  SizedBox(
   width: 20,
  ),
  Expanded(
   child: Column(
   crossAxisAlignment: CrossAxisAlignment.start,
   children: <Widget>[
    Text(
    title,
    style: TextStyle(fontSize: 18),
    ),
    Text(
    content,
    style: TextStyle(
     color: Colors.black.withOpacity(.5), fontSize: 14),
    )
   ],
   ),
  ),
  !showArrow
   ? Container()
   : IconButton(
    icon: Icon(Icons.arrow_forward_ios),
    iconSize: 16,
    onPressed: onPress,
    ),
  ],
 );
 }
}

PageC页面跳转到PageD页面,PageD页面代码如下:

class PageD extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
 return Container(
  height: 200,
  width: 250,
  color: Colors.grey.withOpacity(.5),
  child: Column(
  children: <Widget>[
   Row(
   children: <Widget>[
    IconButton(
    icon: Icon(Icons.arrow_back_ios),
    onPressed: () {
     Navigator.of(context).pop();
    },
    ),
    Text('返回'),
    SizedBox(
    width: 30,
    ),
    Text('举报'),
   ],
   ),
  ],
  ),
 );
 }
}

最终实现了局部跳转效果,只在中间区域变化,其他区域不变。

Tab内跳转

还有一个典型到应用场景就Tab内跳转,效果如下:

底部导航一直存在,每个tab都有自己的导航器。

首页代码如下:

class TabMain extends StatefulWidget {
 @override
 State<StatefulWidget> createState() => _TabMainState();
}

class _TabMainState extends State<TabMain> {
 int _currentIndex = 0;

 @override
 Widget build(BuildContext context) {
 return Scaffold(
  body: IndexedStack(
  index: _currentIndex,
  children: <Widget>[
   TabNavigator(0),
   TabNavigator(1),
   TabNavigator(2),
  ],
  ),
  bottomNavigationBar: BottomNavigationBar(
  onTap: (int index) {
   setState(() {
   _currentIndex = index;
   });
  },
  currentIndex: _currentIndex,
  items: <BottomNavigationBarItem>[
   BottomNavigationBarItem(title: Text('首页'), icon: Icon(Icons.home)),
   BottomNavigationBarItem(title: Text('书籍'), icon: Icon(Icons.book)),
   BottomNavigationBarItem(
    title: Text('我的'), icon: Icon(Icons.perm_identity)),
  ],
  ),
 );
 }
}

首页定义了3个tab及切换效果。

定义TabNavigator:

class TabNavigator extends StatelessWidget {
 TabNavigator(this.index);

 final int index;

 @override
 Widget build(BuildContext context) {
 return Navigator(
  initialRoute: '/',
  onGenerateRoute: (RouteSettings settins) {
  WidgetBuilder builder;
  switch (settins.name) {
   case '/':
   builder = (context) => ListPage(index);
   break;
  }
  return MaterialPageRoute(builder: builder);
  },
 );
 }
}

列表页面,此页面一般为List页面,点击其中一个跳转到相关详情页面,这里为了简便,只放了一个跳转按钮:

class ListPage extends StatelessWidget {
 ListPage(this.index);

 final int index;

 @override
 Widget build(BuildContext context) {
 return Scaffold(
  appBar: AppBar(),
  body: Center(
  child: RaisedButton(
   child: Text('$index'),
   onPressed: () {
   Navigator.of(context).push(MaterialPageRoute(builder: (context) {
    return DetailPage();
   }));
   },
  ),
  ),
 );
 }
}

详情页面

class DetailPage extends StatelessWidget {
 @override
 Widget build(BuildContext context) {
 return Scaffold(
  appBar: AppBar(),
  body: Center(
  child: Text('DetailPage'),
  ),
 );
 }
}

虽然Navigator控件不是特别常用,但在一些场景下非常适用。

总结

到此这篇关于Flutter 使用Navigator进行局部跳转页面的文章就介绍到这了,更多相关Flutter 使用Navigator进行局部跳转页面内容请搜索Devmax以前的文章或继续浏览下面的相关文章希望大家以后多多支持Devmax!

Flutter 使用Navigator进行局部跳转页面的方法的更多相关文章

  1. Flutter中文教程-Cookbook

    Flutter中文网的Cookbook中包含了在编写Flutter应用程序时常见问题及示例。设计基础使用主题共享颜色和字体样式Images显示来自网上的图片用占位符淡入图片使用缓存图Lists创建一个基本list创建一个水平list使用长列表创建不同类型子项的List创建一个gridList处理手势处理点击添加Material触摸水波效果实现滑动关闭导航导航到新页面并返回给新页面传值从新页面返回数据给上一个页面网络从网上获取数据进行认证请求使用WebSockets

  2. android-studio – 未配置Dart SDK

    Initializinggradle…

  3. 安卓 – 从一个扑动的应用程序拨打电话

    或者有更好的选择从我的应用程序拨打电话?

  4. android – 如何在Flutter中添加Webview?

    我知道可以将WebView添加为整页,但找不到任何示例代码.我假设你可以使用PageView作为它的基础,但不知道如何调用本机androidWebView并将其添加到PageView.谁能指出我正确的方向?

  5. android – 如何将消息从Flutter传递给Native?

    如果需要与特定的API/硬件组件进行交互,您如何将Flutter的信息传递回Android/Native代码?是否有任何事件频道可以通过其他方式发送信息或类似于回调?

  6. android – 如何在Flutter App中处理onPause / onResume?

    我是否过于复杂的事情?即使我的用例似乎不需要它,我仍然想知道:如何自己处理onPause/onResume事件?

  7. android – 如何使用Flutter构建Augment Reality应用程序?

    我对Android开发有一些基础知识.最近听说过Flutter并且非常有兴趣研究它.我想知道是否有可能使用颤振构建增强现实应用程序以及要实现此目的的方法?请帮忙.解决方法截至目前,颤振不支持3D.Flutter现在专注于2D,团队长期计划为颤振提供优化的3Dapi.你读了常见问题here.

  8. Flutter 网络请求框架封装详解

    这篇文章主要介绍了Flutter 网络请求框架封装详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  9. Flutter StreamBuilder实现局部刷新实例详解

    这篇文章主要为大家介绍了Flutter StreamBuilder实现局部刷新实例详解,有需要的朋友可以借鉴参考下,希望能够有所帮助,祝大家多多进步,早日升职加薪

  10. Flutter 首页必用组件NestedScrollView的示例详解

    今天介绍的组件是NestedScrollView,大部分的App首页都会用到这个组件。对Flutter 首页必用组件NestedScrollView的相关知识感兴趣的一起看看吧

随机推荐

  1. Flutter 网络请求框架封装详解

    这篇文章主要介绍了Flutter 网络请求框架封装详解,小编觉得挺不错的,现在分享给大家,也给大家做个参考。一起跟随小编过来看看吧

  2. Android单选按钮RadioButton的使用详解

    今天小编就为大家分享一篇关于Android单选按钮RadioButton的使用详解,小编觉得内容挺不错的,现在分享给大家,具有很好的参考价值,需要的朋友一起跟随小编来看看吧

  3. 解决android studio 打包发现generate signed apk 消失不见问题

    这篇文章主要介绍了解决android studio 打包发现generate signed apk 消失不见问题,具有很好的参考价值,希望对大家有所帮助。一起跟随小编过来看看吧

  4. Android 实现自定义圆形listview功能的实例代码

    这篇文章主要介绍了Android 实现自定义圆形listview功能的实例代码,本文通过实例代码给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  5. 详解Android studio 动态fragment的用法

    这篇文章主要介绍了Android studio 动态fragment的用法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,需要的朋友可以参考下

  6. Android用RecyclerView实现图标拖拽排序以及增删管理

    这篇文章主要介绍了Android用RecyclerView实现图标拖拽排序以及增删管理的方法,帮助大家更好的理解和学习使用Android,感兴趣的朋友可以了解下

  7. Android notifyDataSetChanged() 动态更新ListView案例详解

    这篇文章主要介绍了Android notifyDataSetChanged() 动态更新ListView案例详解,本篇文章通过简要的案例,讲解了该项技术的了解与使用,以下就是详细内容,需要的朋友可以参考下

  8. Android自定义View实现弹幕效果

    这篇文章主要为大家详细介绍了Android自定义View实现弹幕效果,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  9. Android自定义View实现跟随手指移动

    这篇文章主要为大家详细介绍了Android自定义View实现跟随手指移动,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

  10. Android实现多点触摸操作

    这篇文章主要介绍了Android实现多点触摸操作,实现图片的放大、缩小和旋转等处理,文中示例代码介绍的非常详细,具有一定的参考价值,感兴趣的小伙伴们可以参考一下

返回
顶部