中文字幕av专区_日韩电影在线播放_精品国产精品久久一区免费式_av在线免费观看网站

溫馨提示×

溫馨提示×

您好,登錄后才能下訂單哦!

密碼登錄×
登錄注冊×
其他方式登錄
點擊 登錄注冊 即表示同意《億速云用戶服務條款》

Flutter如何使用Navigator進行局部跳轉頁面

發布時間:2020-07-21 15:00:21 來源:億速云 閱讀:180 作者:小豬 欄目:移動開發

小編這次要給大家分享的是Flutter如何使用Navigator進行局部跳轉頁面,文章內容豐富,感興趣的小伙伴可以來了解一下,希望大家閱讀完這篇文章之后能夠有所收獲。

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,如下面的場景:

頭條客戶端舉報場景

頭條客戶端每一個新聞下面都有一個“叉號”,點擊彈出相關信息,點擊其中的局部,會在當前小窗戶內跳轉到舉報頁面,效果如下:

Flutter如何使用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
   &#63; 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('舉報'),
   ],
   ),
  ],
  ),
 );
 }
}

Flutter如何使用Navigator進行局部跳轉頁面

最終實現了局部跳轉效果,只在中間區域變化,其他區域不變。

Tab內跳轉

還有一個典型到應用場景就Tab內跳轉,效果如下:

Flutter如何使用Navigator進行局部跳轉頁面

底部導航一直存在,每個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進行局部跳轉頁面的文章,如果覺得文章內容寫得不錯的話,可以把它分享出去給更多人看到。

向AI問一下細節

免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。

AI

江油市| 察雅县| 崇义县| 岳阳县| 达日县| 西乌| 开阳县| 陵水| 前郭尔| 海口市| 南平市| 五原县| 忻城县| 安图县| 浪卡子县| 固镇县| 冕宁县| 松桃| 定兴县| 商南县| 类乌齐县| 铜梁县| 任丘市| 楚雄市| 周口市| 弥渡县| 乌什县| 汉沽区| 勃利县| 交口县| 台前县| 桐城市| 海门市| 桃园县| 资讯| 交城县| 平罗县| 中江县| 阿尔山市| 苗栗市| 奉贤区|