Flutter Navigator路由傳參的實現(xiàn)
Flutter中的默認導(dǎo)航分成兩種,一種是命名的路由,一種是構(gòu)建路由。
一、命名路由傳參
應(yīng)用入口處定義路由表
class MyApp extends StatelessWidget {
const MyApp({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return MaterialApp(
debugShowCheckedModeBanner: false, // 隱藏預(yù)覽中的debug
title: 'Flutter Demo',
routes: {
'/': (context) => const HomePage(),
"menu": (context) => const MenuPage()
},
);
}
}// 定義HomePage
class HomePage extends StatelessWidget {
const HomePage({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("登錄"),
),
body: ElevatedButton(
onPressed: () async {
// 實現(xiàn)路由跳轉(zhuǎn)
var result = await Navigator.pushNamed(context, 'menu',
arguments: {'name': 'title'});
print(result);
},
child: const Text('登錄'),
),
);
}
}// 定義MenuPage
class MenuPage extends StatelessWidget {
const MenuPage({Key? key}) : super(key: key);
@override
// 接收傳參
Widget build(BuildContext context) {
dynamic argumentsData = ModalRoute.of(context)?.settings.arguments;
return Scaffold(
appBar: AppBar(
title: Text('菜單' + argumentsData.toString()),
),
body: ElevatedButton(
onPressed: () {
Navigator.pop(context, {'name': "Navigator.pop傳參"});
},
child: const Text("返回"),
),
);
}
}二、構(gòu)建路由傳參
從HomePage頁面跳轉(zhuǎn)MenuPage頁面時,攜帶參數(shù)
第一種方式:
// 定義HomePage
class HomePage extends StatelessWidget {
const HomePage ({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("登錄"),
),
body: ElevatedButton(
onPressed: () {
// 實現(xiàn)路由跳轉(zhuǎn)
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => const MenuPage(
title: '菜單123',
), // 需要跳轉(zhuǎn)的頁面
), // 修改路由的名稱、信息等
);
},
child: const Text('登錄'),
),
);
}
}// 定義MenuPage
class MenuPage extends StatelessWidget {
// 定義接收的字段
final String title;
const MenuPage({Key? key, required this.title}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: Text(title),
),
body: ElevatedButton(
onPressed: () {
Navigator.pop(context);
},
child: const Text("返回"),
),
);
}
}第二種方式:
// 定義HomePage
class HomePage extends StatelessWidget {
const HomePage({Key? key}) : super(key: key);
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("登錄"),
),
body: ElevatedButton(
onPressed: () {
// 實現(xiàn)路由跳轉(zhuǎn)
Navigator.push(
context,
MaterialPageRoute(
builder: (context) => const MenuPage(),
// 修改路由的名稱、信息等
settings: const RouteSettings(
name: '菜單', arguments: {"name": '123'}) // 需要跳轉(zhuǎn)的頁面
),
);
},
child: const Text('登錄'),
),
);
}
}// 定義MenuPage
class MenuPage extends StatelessWidget {
const MenuPage({Key? key}) : super(key: key);
@override
// 接收傳參
Widget build(BuildContext context) {
dynamic argumentsData = ModalRoute.of(context)?.settings.arguments;
return Scaffold(
appBar: AppBar(
title: Text('菜單' + argumentsData.toString()),
),
body: ElevatedButton(
onPressed: () {
Navigator.pop(context);
},
child: const Text("返回"),
),
);
}
}從MenuPage頁面返回HomePage頁面時,攜帶參數(shù)
// 定義HomePage
class HomePage extends StatelessWidget {
const HomePage ({Key? key}) : super(key: key);;
@override
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text("登錄"),
),
body: ElevatedButton(
onPressed: () async {
// 實現(xiàn)路由跳轉(zhuǎn)
var result = await Navigator.push(
context,
MaterialPageRoute(
builder: (context) => const MenuPage(),
),
);
print(result);
},
child: const Text('登錄'),
),
);
}
}// 定義MenuPage
class MenuPage extends StatelessWidget {
const MenuPage({Key? key}) : super(key: key);
@override
// 接收傳參
Widget build(BuildContext context) {
return Scaffold(
appBar: AppBar(
title: const Text('菜單'),
),
body: ElevatedButton(
onPressed: () {
Navigator.pop(context, {'name': "Navigator.pop傳參"});
},
child: const Text("返回"),
),
);
}
}
到此這篇關(guān)于Flutter Navigator路由傳參的實現(xiàn)的文章就介紹到這了,更多相關(guān)Flutter Navigator路由傳參內(nèi)容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關(guān)文章希望大家以后多多支持腳本之家!
相關(guān)文章
android開發(fā)教程之文本框加滾動條scrollview
EditText與TextView加上滾動條其實很簡單,只需要在文本輸入框或者文本顯示框上面加上滾動條控件即可2014-02-02
Android仿微信錄音功能(錄音后的raw文件轉(zhuǎn)mp3文件)
這篇文章主要介紹了Android中仿微信錄音功能錄音后的raw文件轉(zhuǎn)mp3文件,本文通過實例代碼給大家講解的非常詳細,需要的朋友可以參考下2019-11-11
使用 Swift 語言編寫 Android 應(yīng)用入門
為了能順利使用這份向?qū)?,你需要? 1. 可以編譯Swift源碼的Linux環(huán)境。stdlib目前只能在Linux環(huán)境下編譯成安卓可用版本。在嘗試為安卓構(gòu)建之前,確保你能夠參考Swift項目的README為Linux做編譯。2016-04-04

