摘要:是借鑒的開發思想實現的,在子組件的插槽上,有,有。當然也有類似的,那就是,不過是以的形式實現像。的使用無非個屬性初始路由匹配路由在實現層面首先的高度為。最后執行尋找路由順序是,這個和的是類似的。
Flutter是借鑒React的開發思想實現的,在子組件的插槽上,React有this.props.children,Vue有
當然Flutter也有類似的Widget,那就是Navigator,不過是以router的形式實現(像
Navigator的使用無非3個屬性
initialRoute: 初始路由
onGenerateRoute: 匹配路由
onUnknownRoute: 404
在實現層面
首先:Navigator的高度為infinity。如果直接父級非最上級也是infinity會產生異常,例如,Scaffold -> Column -> Navigator。所以:Navigator需要附件限制高度,例如:Scaffold -> Column -> Container(height: 300) -> Navigator
然后:在onGenerateRoute屬性中,使用第一個BuildContext參數,能夠在MaterialApp未設置route的情況下使用Navigator.pushNamed(nContext, "/efg");跳到對應的子路由中。
最后:Navigator執行尋找路由順序是 initialRoute -> onGenerateRoute -> onUnknownRoute,這個和React的Route是類似的。
最后附上源碼
import "package:flutter/material.dart"; class NavigatorPage extends StatefulWidget { @override _NavigatorPageState createState() => _NavigatorPageState(); } class _NavigatorPageState extends State項目地址: https://github.com/zhongmeizhi/fultter-example-app{ @override Widget build(BuildContext context) { return Scaffold( appBar: AppBar( title: Text("Navigator"), ), body: Column( children: [ Text("Navigator的高度為infinity"), Text("如果直接父級非最上級也是infinity會產生異常"), Container( height: 333, color: Colors.amber.withAlpha(111), child: Navigator( // Navigator initialRoute: "/abc", onGenerateRoute: (val) { RoutePageBuilder builder; switch (val.name) { case "/abc": builder = (BuildContext nContext, Animation animation, Animation secondaryAnimation) => Column( // 并沒有在 MaterialApp 中設定 /efg 路由 // 因為Navigator的特性 使用nContext 可以跳轉 /efg children: [ Text("呵呵呵"), RaisedButton( child: Text("去 /efg"), onPressed: () { Navigator.pushNamed(nContext, "/efg"); }, ) ], ); break; case "/efg": builder = (BuildContext nContext, Animation animation, Animation secondaryAnimation) => Row( children: [ RaisedButton( child: Text("去 /hhh"), onPressed: () { Navigator.pushNamed(nContext, "/hhh"); }, ) ], ); break; default: builder = (BuildContext nContext, Animation animation, Animation secondaryAnimation) => Center( child: RaisedButton( child: Text("去 /abc"), onPressed: () { Navigator.pushNamed(nContext, "/abc"); }, ) ); } return PageRouteBuilder( pageBuilder: builder, // transitionDuration: const Duration(milliseconds: 0), ); }, onUnknownRoute: (val) { print(val); }, observers: [] ), ), Text("Navigator執行尋找路由順序"), Text("initialRoute"), Text("onGenerateRoute"), Text("onUnknownRoute"), ], ), ); } }
擼完代碼記得給顆星哦。
文章版權歸作者所有,未經允許請勿轉載,若此文章存在違規行為,您可以聯系管理員刪除。
轉載請注明本文地址:http://specialneedsforspecialkids.com/yun/104591.html
閱讀 1856·2023-04-25 14:28
閱讀 1892·2021-11-19 09:40
閱讀 2795·2021-11-17 09:33
閱讀 1385·2021-11-02 14:48
閱讀 1710·2019-08-29 16:36
閱讀 3333·2019-08-29 16:09
閱讀 2917·2019-08-29 14:17
閱讀 2378·2019-08-29 14:07