5 WPF中的Page页面的使用

         以下是一个简单的WPF示例,演示如何在三个Page之间进行导航切换,使用Frame控件作为导航容器,并包含基本的导航按钮(前进/后退/主页)

        Page类更简单,比Window更精简。

        代码见下文以及资源文件:

 https://download.csdn.net/download/qq_34047402/90919296

5WPF中的Page页面的使用资源-CSDN文库

 本例介绍如下界面实现:

一、Page的显示

Page可以放到Frame中。

1), Frame的  NavigationUIVisibility ="Visible" 可以显示导航的小图标。

 <Frame x:Name="MainFrame" Grid.Column="1" NavigationUIVisibility="Visible"/>

2).使用Frame的Navigate方法可以导航到某个页面,如下文

  MainFrame.Navigate(new Page1()); 

3)页面之间跳转可以使用超级链接或者NavigationService.Navigate实现,

a). NavigationService

        NavigationService.Navigate(new Page3());

        其中NavigationService:获得了页的宿

b). 使用Frame的GoBack,GoForward函数

 if (MainFrame.CanGoBack)
     MainFrame.GoBack();

if (MainFrame.CanGoForward)
    MainFrame.GoForward();

c). 超级链接

 <TextBlock Margin="10">
     click <Hyperlink NavigateUri="Page3.xaml" > 这儿</Hyperlink> 到页面3
 </TextBlock>

如果想对URi做验证,可以添加事件RequestNavigate 来处理具体的导航请求。

 <TextBlock Margin="10">
     click <Hyperlink NavigateUri="Page3.xaml"  RequestNavigate="Hyperlink_RequestNavigate"> 这儿</Hyperlink> 到页面3
 </TextBlock>

 private void Hyperlink_RequestNavigate(object sender, RequestNavigateEventArgs e)
 {
     if (e.Uri != null)
     {
         // 获取当前NavigationService并导航
         var navService = NavigationService.GetNavigationService((DependencyObject)sender);
         navService?.Navigate(new Uri(e.Uri.ToString(), UriKind.RelativeOrAbsolute));
         e.Handled = true;   //设置为 true 表示事件已处理
     }

 }

关于参数 RequestNavigateEventArgs:

属性/方法说明
e.Uri获取Hyperlink中指定的目标URI(如 NavigateUri="Page2.xaml"
e.Handled设置为 true 表示事件已处理,阻止默认行为(必须设置!)
e.Source事件源(即Hyperlink控件本身)

二、代码如下

<Window x:Class="WpfApp1.MainWindow"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:d="http://schemas.microsoft.com/expression/blend/2008"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"xmlns:local="clr-namespace:WpfApp1"mc:Ignorable="d"Title="Page导航示例" Height="450" Width="800"><Grid><Grid.ColumnDefinitions><ColumnDefinition Width="Auto"/><ColumnDefinition Width="*"/></Grid.ColumnDefinitions><!-- 导航按钮 --><StackPanel Grid.Row="0" Orientation="Vertical" Background="LightGray"><Button Content="首页" Margin="5" Padding="10,2" Click="GoToHome_Click"/><Button Content="上一页" Margin="5" Padding="10,2" Click="GoBack_Click"/><Button Content="下一页" Margin="5" Padding="10,2" Click="GoForward_Click"/><Button Content="用Command跳转到页面2" Margin="5" Padding="10,2" Command="{Binding NavigationToPageCommand}" CommandParameter="/Pages/Page2.xaml"                    /><Button Content="用Command跳转到页面3" Margin="5" Padding="10,2" Command="{Binding NavigationToPageCommand}" CommandParameter="/Pages/Page3.xaml"        /><TextBlock Margin="10" VerticalAlignment="Center" Text="{Binding ElementName=MainFrame, Path=Content.Title}"/></StackPanel><!-- 导航容器 --><Frame x:Name="MainFrame" Grid.Column="1" NavigationUIVisibility="Hidden"/></Grid>
</Window>

<Page x:Class="WpfApp1.Pages.Page1"xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006" xmlns:d="http://schemas.microsoft.com/expression/blend/2008" xmlns:local="clr-namespace:WpfApp1.Pages"mc:Ignorable="d" d:DesignHeight="450" d:DesignWidth="800"Title="页面1欢迎"><StackPanel VerticalAlignment="Center" HorizontalAlignment="Center"><TextBlock Text="这是页面1" FontSize="24" Margin="10"/><Button Content="前往页面2" Click="NavigateToPage2" Width="100" Margin="10"/></StackPanel>
</Page>
  public partial class Page1 : Page{public Page1(){InitializeComponent();}private void NavigateToPage2(object sender, RoutedEventArgs e){NavigationService.Navigate(new Page2());}}
public partial class Page2 : Page
{public Page2(){InitializeComponent();}private void NavigateToPage3(object sender, RoutedEventArgs e){NavigationService.Navigate(new Page3());}private void GoBackToPage1(object sender, RoutedEventArgs e){NavigationService.GoBack();}
}public partial class Page3 : Page{public Page3(){InitializeComponent();}private void GoToHome(object sender, RoutedEventArgs e){// 直接导航到Page1(清空导航历史)NavigationService.Navigate(new Page1());}}public partial class MainWindow : Window{public MainWindow(){InitializeComponent();this.DataContext = new MainViewModel(this.MainFrame);}private void GoToHome_Click(object sender, RoutedEventArgs e){MainFrame.Navigate(new Page1());}private void GoBack_Click(object sender, RoutedEventArgs e){if (MainFrame.CanGoBack)MainFrame.GoBack();}private void GoForward_Click(object sender, RoutedEventArgs e){if (MainFrame.CanGoForward)MainFrame.GoForward();}}public class MainViewModel{private Frame _frame;public MainViewModel(Frame frame){_frame = frame;}private ICommand _navigationToPageCommand;public ICommand NavigationToPageCommand {get{return _navigationToPageCommand ?? new RelayCommand<object>( NavigationToPage, (s) => true);}set{_navigationToPageCommand = value;}}private void NavigationToPage(object page){try{string pageUrl = page as string;if(pageUrl!=null){_frame.Navigate(new Uri(pageUrl, UriKind.Relative));}}catch(Exception ex){}}}

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.pswp.cn/news/907159.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

基于51单片机的音乐盒点阵屏proteus仿真

地址&#xff1a; https://pan.baidu.com/s/1hYzg2icjHV8jWJdltJkKxw 提取码&#xff1a;1234 仿真图&#xff1a; 芯片/模块的特点&#xff1a; AT89C52/AT89C51简介&#xff1a; AT89C51 是一款常用的 8 位单片机&#xff0c;由 Atmel 公司&#xff08;现已被 Microchip 收…

图论:floyed算法

Floyd 算法是一种用于寻找加权图中所有顶点对之间最短路径的经典算法&#xff0c;它能够处理负权边&#xff0c;但不能处理负权环。即如果边权有负数&#xff0c;切负权边与其他边构成了环就不能用该算法。该算法的时间复杂度为 \(O(V^3)\)&#xff0c;其中 V 是图中顶点的数量…

STM32之看门狗(IWDG)

一、看门狗外设的原理与应用 背景说明 随着单片机的发展&#xff0c;单片机在家用电器、工业自动化、生产过程控制、智能仪器仪表等领域的应用越来越广泛。然而处于同一电力系统中的各种电气设备通过电或磁的联系彼此紧密相连&#xff0c;相互影响&#xff0c;由于运行方式的…

#RabbitMQ# 消息队列进阶

目录 消息可靠性 一 生产者的可靠性 1 生产者的重连 2 生产者的确认 (1 Confirm* (2 Return 二 MQ的可靠性 1 数据持久化 2 Lazy Queue* 三 消费者的可靠性 1 消费者确认机制 2 消费失败处理 3 业务幂等性 四 延迟消息 消息可靠性 在消息队列中&#xff0c;可靠性…

《计算机组成原理》第 10 章 - 控制单元的设计

目录 10.1 组合逻辑设计 10.1.1 组合逻辑控制单元框图 10.1.2 微操作的节拍安排 10.1.3 组合逻辑设计步骤 10.2 微程序设计 10.2.1 微程序设计思想的产生 10.2.2 微程序控制单元框图及工作原理 10.2.3 微指令的编码方式 1. 直接编码&#xff08;水平型&#xff09; 2.…

AstroNex空间任务智能控制研究与训练数据集

数据集概述 AstroNex空间任务智能控制研究与训练数据集是朗迪锋科技基于Multiverse平台精心打造的首个全面覆盖航天器智能控制全周期的综合数据集产品。该数据集汇集了轨道动力学、姿态控制、机器视觉、环境感知等多维度数据&#xff0c;为航天器智能算法研发提供丰富的训练与…

​​3D 几何建模工具库​Open CASCADE(OCCT)简单介绍。

​​Open CASCADE&#xff08;OCCT&#xff09;​​ 的新手&#xff0c;我会用最简单的方式帮你理解它是什么、能做什么&#xff0c;以及如何快速上手。 ​​1. OCCT 是什么&#xff1f;​​ ​​一句话定义​​&#xff1a;OCCT 是一个开源的 ​​3D 几何建模工具库​​&…

[7-1] ADC模数转换器 江协科技学习笔记(14个知识点)

1 2 3 4 5 6 7 8 9 10 11 12 13 14 DMA&#xff08;Direct Memory Access&#xff0c;直接内存访问&#xff09;是一种硬件特性&#xff0c;它允许某些硬件子系统直接访问系统的内存&#xff0c;而无需CPU的介入。这样&#xff0c;CPU就可以处理其他任务&#xff0c;从而提高系…

篇章三 基础——不可变类

目录 1.是什么 2.为什么 3.怎么做 4.构造详细的不可变类示例: 5.补充 5.1 Java标准库中的不可变类 5.2 构造不可变类进阶 1.对象包含嵌套的引用类型字段 2. 大型对象采用不可变类时,需考虑性能影响。 2.1 内存占用问题 2.2 垃圾回收压力 2.3 复制开销 2.4 优化策…

cuda ncu section 含义解释

NVIDIA Nsight Compute (NCU) 是用于分析 CUDA 程序性能的工具&#xff0c;通过 Sections 组织性能指标。用户提供的 24 个 Sections 涵盖了计算、内存、调度、互连和可视化等方面。本报告详细解释每个 Section 的含义、用途及相关分析场景。 Sections 详细解析 C2CLink 含义&…

NGINX HTTP/2 全面指南开启、调优与实战

一、为什么要用 HTTP/2&#xff1f; 多路复用&#xff08;Multiplexing&#xff09; 单连接上可并发交错发送多路请求&#xff0c;避免了 HTTP/1.x 中的队头阻塞&#xff08;Head-Of-Line Blocking&#xff09;。头部压缩&#xff08;HPACK&#xff09; 对 HTTP 头部字段进行高…

手写简单的tomcat

首先&#xff0c;Tomcat是一个软件&#xff0c;所有的项目都能在Tomcat上加载运行&#xff0c;Tomcat最核心的就是Servlet集合&#xff0c;本身就是HashMap。Tomcat需要支持Servlet&#xff0c;所以有servlet底层的资源&#xff1a;HttpServlet抽象类、HttpRequest和HttpRespon…

智能体赋能效率,企业知识库沉淀价值:UMI企业智脑的双轮驱动!

智能体企业知识库&#xff1a;UMI企业智脑的核心功能与价值 在人工智能技术飞速发展的今天&#xff0c;企业智能化转型已经成为不可逆转的趋势。作为企业级AI智能体开发平台的佼佼者&#xff0c;优秘智能推出的UMI企业智脑&#xff0c;以其强大的智能体开发能力和全面的企业知…

与 PyCharm 官方沟通解决开发环境问题记录(进展:官方已推出2个新的修复版本)

​​​​​​主题&#xff1a;有关 PyCharm 中终端和环境激活问题的反馈&#xff1a;PY-81233 前言 目前进展&#xff1a; 官方已有2个修复版本推出测试。 更新方法&#xff1a; 使用JetBrains Toolbox App&#xff0c;如下图所示&#xff0c;从“其他版本”进入查看更新。…

LINUX安装运行jeelowcode后端项目(命令行)

环境准备 运行环境&#xff1a;JDK1.8开发工具&#xff1a; Idea、Maven默认已启动中间件&#xff1a;&#xff08;推荐使用宝塔&#xff09;Mysql8.0、Redis、Minio第一步&#xff1a;下载JeelowCode项目并导入IDEA中 第二步&#xff1a;导入数据库文件到mysql中&#xff0c;…

Android开机向导定制(2)开机向导配置

先贴lineage_wizard_script_user.xml的代码&#xff1a; <WizardScript xmlns:wizard"http://schemas.android.com/apk/res/com.google.android.setupwizard"wizard:firstAction"welcome"><WizardAction wizard:uri"intent:#Intent;actiono…

守护电动“心脏”!仿真APP在汽车电池包随机振动分析中的应用

汽车电动化、智能化、绿色化发展已成为全球各国应对气候变化、实现低碳发展的共同选择。在此背景下&#xff0c;新能源汽车持续高速发展。电池包作为新能源汽车的“心脏”&#xff0c;是其主要动力来源&#xff0c;直接影响车辆的续航里程与行驶安全。电池包结构的安全可靠性对…

实习面经(JAVA)

目录 锁升级 notify和notifyAll区别 Sleep和Wait的区别 ArrayList和ListedList区别 HashMap扩容原理 ConcurrentHashMap StringBuffer 和 StringBuilder 事务等级 索引结构 三次握手四次挥手&#xff0c;为什么是三次和四次 Java中重写和重载的区别和应用场景 ArrayLis…

计算机网络-WebSocket/DNS/Cookie/Session/Token/Jwt/Nginx

文章目录 WebSocketDNS什么是dns域名解析底层协议 cookie/sessionToken/JWTNginx WebSocket 一种网络通信协议&#xff0c;允许在单个 TCP&#xff08;半双工&#xff09; 连接上进行全双工通信&#xff08;客户端和服务器可同时双向传输数据&#xff09;。 HTTP是基于请求-响…

单片机如何快速实现查看实时数据

在用 Keil 做调试的时候&#xff0c;最让人头秃的是什么&#xff1f; 不是写代码的BUG&#xff0c;而是&#xff1a;这个条件变量是什么情况&#xff1f;为什么没进入这个判断&#xff1f;我代码跑到哪里了&#xff1f; 其实本质上都是通过变量判断代码的执行顺序有没有问题 …