美文网首页Flutter
Flutter fluro 实现路由配置简介

Flutter fluro 实现路由配置简介

作者: StevenHu_Sir | 来源:发表于2019-08-26 17:42 被阅读0次
dependencies:
 fluro: "^1.4.0"

或者

dependencies:
 fluro:
   git: git://github.com/theyakka/fluro.git

配置步骤

  • 创建router_handler
import 'package:flutter/material.dart';
import 'package:fluro/fluro.dart';
import '../pages/details_page.dart';

// 跳转商品详情页
Handler detailsHanderl = Handler(
    handlerFunc: (BuildContext context, Map<String, List<String>> params) {
  String goodsId = params['id'].first;
  print('index>details goodsID is ${goodsId}');
  return DetailsPage(goodsId);
});
  • 创建全局Routes配置
import 'package:flutter/material.dart';
import 'package:fluro/fluro.dart';
import './router_handler.dart';
class Routes{
  static String root='/';
  static String detailsPage = '/detail';
  static void configureRoutes(Router router){
    router.notFoundHandler= new Handler(
        handlerFunc: (BuildContext context,Map<String,List<String>> params){
          print('ERROR====>ROUTE WAS NOT FONUND!!!');
        }
    );
    router.define(detailsPage,handler:detailsHanderl);
  }
}
  • 静态化
import 'package:fluro/fluro.dart';

class Application{
  static Router router;
}

路由_fluro的全局注入和使用

import './routers/routes.dart';
import './routers/application.dart';

class MyApp extends StatelessWidget {
  @override
  Widget build(BuildContext context) {
    //-------------------主要代码start
    final router = Router();
    Routes.configureRoutes(router);
    Application.router=router;
    //-------------------主要代码end
    
    return Container(
      child: MaterialApp(
        title:'百姓生活+',
        debugShowCheckedModeBanner: false,
        //----------------主要代码start
        onGenerateRoute: Application.router.generator,
        //----------------主要代码end
        theme: ThemeData(
          primaryColor:Colors.pink,
        ),
        home:IndexPage()
      ),
    );
  }
}

首页使用

Application.router.navigateTo(context,"/detail?id=${val['goodsId']}");

相关文章

网友评论

    本文标题:Flutter fluro 实现路由配置简介

    本文链接:https://www.haomeiwen.com/subject/ykmdectx.html