c/c++语言开发共享flutter 路由跳转的实现示例

路由做android/ios原生开发的时候,要打开一个新的页面,你得知道你的目标页面对象,然后初始化一个intent或者viewcontroller,再通过startactivity或者pushvie

路由

做android/ios原生开发的时候,要打开一个新的页面,你得知道你的目标页面对象,然后初始化一个intent或者viewcontroller,再通过startactivity或者pushviewcontroller来推出一个新的页面,不能跟web一样,直接丢一个链接地址就跳转到新的页面。当然,可以自己去加一个中间层来实现这些功能。
flutter里面是原生支持路由的。flutter的framework提供了路由跳转的实现。我们可以直接使用这些功能。

flutter路由介绍

flutter里面有路由支持所有的路由场景,push、pop页面,页面间的参数传递等等。flutter里面的路由可以分成两种,一种是直接注册,不能传递参数。另一种要自己构造实例,可以传递参数。我们暂时把它们规为静态路由和动态路由。

单页面路由跳转时注意不要有两个materialapp,因为导航是依赖于这个的,有两个,就会有两个导航

一、两种路由传参方法: detailscreen跳转的路由组件

1.直接向路由子组件构造函数传参

  navigator.push(    context,    materialpageroute(       builder: (context) => detailscreen(todo: todos[index]),     ),   );  1.通过routesettings传递参数  navigator.push(     context,     materialpageroute(        builder: (context) => detailscreen(),        settings: routesettings(          arguments: todos[index],         ),      ),   );  

二、定义路由:

1、在 materialapp 中添加属性:

   initialroute 和 routes 来定义我们的路由  new materialapp(     initialroute: '/',     routes: {      '/': (context) => todosscreen(todos: todos),      '/detail': (context) => detailscreen(),     },     title: 'ssss',  );    

但要注意的是:当使用 initialroute 时,需要确保你没有同时定义 home 属性。

2、 给特定的 route 传参:

1) 定义需要传递的参数

  class screenarguments {   final string title;   final string message;   screenarguments(this.title, this.message);  }  

2) 创建组件来获取参数

  class extractargumentsscreen extends statelesswidget {   static const routename = '/extractarguments';   @override   widget build(buildcontext context) {    final screenarguments args = modalroute.of(context).settings.arguments;    return scaffold(    );   }  }  

3) 把组件注册到路由表中

  materialapp(   routes: {    extractargumentsscreen.routename: (context) => extractargumentsscreen(),   },  );  

4) 导航到组件

  raisedbutton(   onpressed: () {    navigator.pushnamed(     context,     extractargumentsscreen.routename,     arguments: screenarguments(      'extract arguments screen',      'this message is extracted in the build method.',     ),    );   },  ),  

5) ongenerateroute 提取参数

  materialapp(   ongenerateroute: (settings) {    if (settings.name == passargumentsscreen.routename) {     final screenarguments args = settings.arguments;     return materialpageroute(      builder: (context) {       return passargumentsscreen(        title: args.title,        message: args.message,       );      },     );    }   },  );  

到此这篇关于flutter 路由跳转的实现示例的文章就介绍到这了,更多相关flutter 路由跳转内容请搜索<计算机技术网(www.ctvol.com)!!>以前的文章或继续浏览下面的相关文章希望大家以后多多支持<计算机技术网(www.ctvol.com)!!>!

本文来自网络收集,不代表计算机技术网立场,如涉及侵权请联系管理员删除。

ctvol管理联系方式QQ:251552304

本文章地址:https://www.ctvol.com/c-cdevelopment/597708.html

(0)
上一篇 2021年5月8日
下一篇 2021年5月8日

精彩推荐