文件结构:
内容承接:https://blog.csdn.net/u013227399/article/details/103859886
home.dart
import 'package:flutter/material.dart';
class HomePage extends StatefulWidget {
HomePage({Key key}) : super(key: key);
@override
_HomePageState createState() => _HomePageState();
}
class _HomePageState extends State<HomePage> {
@override
Widget build(BuildContext context) {
return Column(
crossAxisAlignment: CrossAxisAlignment.start,
mainAxisAlignment: MainAxisAlignment.center,
children: <Widget>[
RaisedButton(
child: Text('跳转到搜索页面'),
onPressed: () {
//路由跳转
Navigator.pushNamed(context, '/search');
},
color: Theme.of(context).accentColor,
textTheme: ButtonTextTheme.primary,
),
SizedBox(height: 20),
RaisedButton(
child: Text('跳转到表单页面并传值'),
onPressed: () {
Navigator.pushNamed(context, '/form',arguments: {
'title':'传标题'
});
},
color: Theme.of(context).accentColor,
textTheme: ButtonTextTheme.primary,
),
//以下为新增
SizedBox(height: 20),
RaisedButton(
child: Text('跳转到商品列表'),
onPressed: () {
Navigator.pushNamed(context, '/product');
},
color: Theme.of(context).accentColor,
textTheme: ButtonTextTheme.primary,
),
],
);
}
}
routes.dart
import 'package:flutter/material.dart';
import '../pages/tabs.dart';
import '../pages/From.dart';
import '../pages/Search.dart';
import '../pages/Product.dart';
import '../pages/ProductInfo.dart';
final routes = {
'/': (context) => Tabs(),
'/search': (context) => SearchPage(),
'/form': (context, {arguments}) => FormPage(arguments: arguments),
'/product': (context) => ProductPage(),
'/productinfo':(context, {arguments}) => ProductInfoPage(arguments: arguments),
};
var onGenerateRoute=(RouteSettings settings){
//统一处理
final String name = settings.name;
final Function pageContentBuilder = routes[name];
if (pageContentBuilder != null) {
if (settings.arguments != null) {
final Route route = MaterialPageRoute(
builder: (context) =>
pageContentBuilder(context, arguments: settings.arguments),
);
return route;
} else {
final Route route = MaterialPageRoute(
builder: (context) => pageContentBuilder(context),
);
return route;
}
}
};
product.dart
import 'package:flutter/material.dart';
class ProductPage extends StatefulWidget {
ProductPage({Key key}) : super(key: key);
@override
_ProductPageState createState() => _ProductPageState();
}
class _ProductPageState extends State<ProductPage> {
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('商品列表页'),
),
body: Column(
children: <Widget>[
RaisedButton(
child: Text('点击进入商品详情'),
onPressed: (){
Navigator.pushNamed(context, '/productinfo',arguments: {
'id':123
});
},
),
],
),
);
}
}
productinfo.dart
import 'package:flutter/material.dart';
class ProductInfoPage extends StatefulWidget {
Map arguments;
ProductInfoPage({Key key,this.arguments}) : super(key: key);
@override
_ProductInfoPageState createState() => _ProductInfoPageState(arguments:this.arguments);
}
class _ProductInfoPageState extends State<ProductInfoPage> {
Map arguments;
_ProductInfoPageState({this.arguments});
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text('商品详情'),
),
body: Text("id=${arguments['id']}"),
);
}
}
效果展示