WPF页面导航的核心是Frame容器配合Page类,支持前进/后退、URI导航、历史记录与生命周期管理;Frame作为导航宿主需声明于XAML或代码中,Page须继承Page类并实现OnNavigatedTo/From方法,常用导航方式包括实例导航、相对URI导航及带参URI导航。

WPF 中实现页面导航,核心是使用 Frame 容器配合 Page 类型页面,这是官方推荐的、轻量且符合 MVVM 风格的导航方案。它不依赖窗口跳转,支持前进/后退、URI 导航、历史记录和生命周期管理。
Frame 控件是导航容器
Frame 是一个可导航的内容宿主,类似浏览器中的 iframe。它默认支持导航历史(前进/后退按钮)、URI 路由、缓存策略等。需在 XAML 中声明并设置 NavigationUIVisibility="Visible" 显示系统导航栏(可选):
也可用代码初始化并嵌入到 Window 或 UserControl 中,比如放在 Grid 或 DockPanel 里作为主内容区。
Page 页面需继承自 Page 类
每个导航目标必须是继承自 Page 的类(不能是 Window 或 UserControl)。新建项时选择 “Page (WPF)” 模板即可。Page 支持 XAML 设计、资源字典、命令绑定,也支持 OnNavigatedTo/OnNavigatedFrom 等生命周期方法:
- 重写
OnNavigatedTo(NavigationEventArgs e):页面被导航到时触发,适合刷新数据或恢复状态 - 重写
OnNavigatedFrom(NavigationEventArgs e):页面即将离开时触发,适合保存临时状态 -
e.ExtraData可传递简单对象(如字符串、ID),避免强耦合
三种常用导航方式
导航本质是 Frame 加载 Page 实例或 URI。常用方式有:
-
直接实例导航:
MainFrame.Navigate(new HomePage());—— 最常用,类型安全,适合参数少或通过构造函数/属性传参 -
URI 导航(基于 Pack URI):
MainFrame.Navigate(new Uri("Pages/HomePage.xaml", UriKind.Relative));—— 支持 XAML 文件路径,适合松耦合或动态加载 -
带参数的 URI 导航:
MainFrame.Navigate(new Uri("Pages/DetailPage.xaml?id=123", UriKind.Relative));,再在 Page 中解析NavigationContext.QueryString["id"](需自行解析或用第三方库如 Prism)
注意事项与实用技巧
Frame 默认启用页面缓存(KeepAlive="True" 在 Page 中设置),避免重复创建;若需每次刷新,可在 Page 中设 KeepAlive="False" 或在导航前清除缓存。另外:
- Frame 必须处于已加载状态(Loaded 事件之后)才能导航,否则可能静默失败
- Page 不支持无参数构造函数以外的构造方式 —— 若需注入服务,建议用依赖注入容器 + 服务定位器,或在 OnNavigatedTo 中获取
- 想禁用系统导航栏但保留历史,设
NavigationUIVisibility="Hidden",仍可用GoBack()/GoForward()手动控制
基本上就这些。不需要引入复杂框架也能快速搭出多页应用,关键在于理解 Frame 是“导航引擎”,Page 是“可寻址页面单元”。










