技術文章
技術問答
iT 徵才
聊天室
2026 鐵人賽
登入/註冊
文章
問答
Tag
邦友
鐵人賽
搜尋
2022 iThome 鐵人賽
DAY
11
0
Mobile Development
Android 開發 30天 初學之路筆記
系列 第
11
篇
Day11 - Android Navigation component
14th鐵人賽
android
新手上路
ian_liu
團隊
nutc imac 老扛寶
2022-09-22 19:12:20
1117 瀏覽
分享至
簡介
Navigation優點:
可視化的頁面導航圖,便於我們快速了解頁面間的關係。
通過destination和action完成頁面間的導航
方便添加頁面切換的動畫。
提供頁面之間類型安全的參數傳遞 - Safe Args。
通過NavigationUI 對菜單(menu)、底部導航(Bottom Navigation)、抽屜(側拉)導航(Navigation drawer)進行統一的管理。
支持深層鏈接DeepLink。
支持ViewModel, 可以將ViewModel的範圍限定為導航圖, 讓目標頁面之間共享數據。
其中Navigation的主要元素有:
Navigation Graph
:一種新的xml資源文件,包含應用程式所有的頁面,以及"頁面間的關係"。
NavHostFragment
:一個特殊的Fragment,可以將它看作是其他"Fragment的容器"。
NavController
:用於在程式碼中完成Navigation Graph具體的"頁面切換"工作。
它們三者之間的關係:
當你想切換Fragment時,使用NavController物件,告訴它你想要去Navigation Graph中的哪個Fragment,NavController會將你想去的Fragment展示NavHostFragment中。
留言
追蹤
檢舉
上一篇
Day10 - Android Navigation drawer 側拉導航欄
下一篇
Day12 - RecyclerView 簡單使用
系列文
Android 開發 30天 初學之路筆記
共
30
篇
目錄
RSS系列文
訂閱系列文
6
人訂閱
26
Day26 - 子母畫面PIP (Picture in Picture)
27
Day27 - 多國語言設置 | 本地化(Localization)
28
Day28 - Jetpack DataStore (上) | Preferences DataStore
29
Day29 - Jetpack DataStore (下) | Proto DataStore
30
Day30 - 在實體手機調適APP的方法ADB | 無線
完整目錄
熱門推薦
{{ item.subject }}
{{ item.channelVendor }}
|
{{ item.webinarstarted }}
|
{{ formatDate(item.duration) }}
直播中
立即報名
尚未有邦友留言
立即登入留言
iThome鐵人賽
參賽組數
902
組
團體組數
37
組
累計文章數
19836
篇
完賽人數
528
人
看影片追技術
看更多
{{ item.subject }}
{{ item.channelVendor }}
|
{{ formatDate(item.duration) }}
直播中
熱門tag
15th鐵人賽
16th鐵人賽
13th鐵人賽
14th鐵人賽
17th鐵人賽
12th鐵人賽
11th鐵人賽
鐵人賽
2019鐵人賽
javascript
2018鐵人賽
python
2017鐵人賽
windows
php
c#
linux
windows server
css
react
熱門問題
鼎新 Workflow ERP 批次採購計畫明細表問題
K8s 顧問 / 平台治理經驗廠商請益
用AI問答方式,也是可以直接網址分享過程給別人(原來要最原始的網址才可以)
熱門回答
用AI問答方式,也是可以直接網址分享過程給別人(原來要最原始的網址才可以)
熱門文章
[Frame & Reference Method-02] 別再叫 AI「總結」這次對話了 : 用起承轉合做對話回顧,價值差十倍
【案場實錄】RS485 的不歸路:為什麼 1000V DC 旁的訊號線必死無疑?(兼論 4-20mA 的老兵價值)
樹莓派串流機之路 - 0 開發背景
【資安筆記】企業遭遇勒索軟體怎麼辦?從緊急隔離到系統重建的 5 階段 AI 應變指南
o11y-bench 協助你評估 LLM 到底能不能當 SRE?
IT邦幫忙
×
標記使用者
輸入對方的帳號或暱稱
Loading
找不到結果。
標記
{{ result.label }}
{{ result.account }}