← Back to list

flutter-navigator-v1-imperative
by HoangNguyen0403
A collection of Agent Skills Standard and Best Practice for Programming Languages, Frameworks that help our AI Agent follow best practies on frameworks and programming laguages
⭐ 111🍴 40📅 Jan 23, 2026
SKILL.md
name: Flutter Navigator v1 (Imperative) description: Standard Flutter navigation using Navigator 1.0 (push/pop). metadata: labels: [navigation, navigator, flutter-core] triggers: files: ['**/app.dart'] keywords: [Navigator, push, pop, MaterialPageRoute, onGenerateRoute]
Navigator v1 Navigation
Priority: P0 (CRITICAL)
Standard imperative navigation system built into Flutter using Navigator and MaterialPageRoute.
Implementation Guidelines
- Standard Push: Use
Navigator.of(context).push(MaterialPageRoute(builder: (_) => Screen())). - Named Routes: Define
routesmap inMaterialAppor useonGenerateRoutefor dynamic routing. - Passing Arguments:
- For named routes: Use
Navigator.pushNamed(context, '/path', arguments: data). - For
onGenerateRoute: Extract arguments usingsettings.arguments.
- For named routes: Use
- Returning Data:
final result = await Navigator.push(...)andNavigator.pop(context, data). - Replacing Screens: Use
pushReplacementorpushAndRemoveUntilfor auth/splash flows.
Code Example
// Basic Push
Navigator.push(
context,
MaterialPageRoute(builder: (context) => const DetailScreen()),
);
// Named Routes Configuration
MaterialApp(
initialRoute: '/',
onGenerateRoute: (settings) {
if (settings.name == '/details') {
final args = settings.arguments as Map;
return MaterialPageRoute(
builder: (context) => DetailScreen(id: args['id']),
);
}
return null;
},
);
// Navigation with Arguments
Navigator.pushNamed(
context,
'/details',
arguments: {'id': 123},
);
Anti-Patterns
- Deep Nesting: Avoid anonymous routes for complex apps; use
onGenerateRoute. - Manual String Paths: Always use constants for route names.
- Context Leaks: Ensure
BuildContextis valid when callingNavigator.of(context). UseScaffoldMessengeror global keys if navigation is needed outsidebuild.
Reference & Examples
For centralized onGenerateRoute implementation:
See references/on-generate-route.md.
Related Topics
idiomatic-flutter | widgets
Score
Total Score
85/100
Based on repository quality metrics
✓SKILL.md
SKILL.mdファイルが含まれている
+20
✓LICENSE
ライセンスが設定されている
+10
✓説明文
100文字以上の説明がある
+10
✓人気
GitHub Stars 100以上
+5
✓最近の活動
1ヶ月以内に更新
+10
✓フォーク
10回以上フォークされている
+5
✓Issue管理
オープンIssueが50未満
+5
✓言語
プログラミング言語が設定されている
+5
✓タグ
1つ以上のタグが設定されている
+5
Reviews
💬
Reviews coming soon

