服务器之家:专注于VPS、云服务器配置技术及软件下载分享
分类导航

PHP教程|ASP.NET教程|Java教程|ASP教程|编程技术|正则表达式|C/C++|IOS|C#|Swift|Android|VB|R语言|JavaScript|易语言|vb.net|

服务器之家 - 编程语言 - C# - WPF实现页面的切换的示例代码

WPF实现页面的切换的示例代码

2023-03-06 14:55鲤籽鲲 C#

本文主要介绍了WPF实现页面的切换的示例代码,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友们下面随着小编来一起学习学习吧

前言

本文主要讲述如何在同一个窗体内,实现不同功能模块的页面切换。

一、准备工作

1.搭建一个简单的mvvm项目结构

WPF实现页面的切换的示例代码

首先搭建一个简单的项目框架,然后有红和绿两个页面,ViewModels中的Base 中简单实现了ICommand 和 INotifyPropertyChanged接口

二、实现

1.使用Frame控件的方式实现

利用Frame的Source 属性加载内部的控件,使用Frame的时候,用于切换的页面可以是UserControl 或者Page,如案例中使用的就是Page

实现代码如下:

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
<Window x:Class="WpfApp2.Views.MainView"
        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:WpfApp2.Views"
        xmlns:vm="clr-namespace:WpfApp2.ViewModels"
        mc:Ignorable="d"
        Title="MainView" Height="450" Width="800">
    <Window.DataContext>
        <vm:MainViewModel></vm:MainViewModel>
    </Window.DataContext>
    <DockPanel Grid.Column="0">
        <StackPanel Background="LightBlue">
            <RadioButton Command="{Binding ChangePageCommand}" CommandParameter="PageRedView.xaml" Content="红色" Margin="10"></RadioButton>
            <RadioButton Command="{Binding ChangePageCommand}" CommandParameter="PageGreenView.xaml" Content="绿色" Margin="10"></RadioButton>
        </StackPanel>
        <Frame NavigationUIVisibility="Hidden" Source="{Binding PageName}"/>
    </DockPanel>
</Window>

注意:这里的CommandParameter传入的是PageRedView.xaml文件

?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
public class MainViewModel:ViewModelBase
{
    private string _pageName;
 
    public string PageName
    {
        get { return _pageName; }
        set { _pageName = value; OnPropertyChanged(); }
    }
 
    public ICommand ChangePageCommand { get; set; }
 
    public MainViewModel()
    {
        ChangePageCommand = new CommandBase(ChangePage);
    }
 
    private void ChangePage(object obj)
    {
        PageName = obj.ToString();
    }
}

2.使用反射的方式实现

使用反射+ContentControl 的方式也可使用页面切换,不过该方式下ContentControl 的Content不可以承接Page,Page只有Frame 和Window可以承接,但是可以承接UserControl。
首先将红色和绿色两个界面修改为UserControl并命名为UserControlRed和UserControlGreen ,然后修改代码如下:

?
1
2
3
4
5
6
7
<DockPanel Grid.Column="0">
    <StackPanel Background="LightBlue">
        <RadioButton Command="{Binding ChangePageCommand}" CommandParameter="UserControlRed" Content="红色" Margin="10"></RadioButton>
        <RadioButton Command="{Binding ChangePageCommand}" CommandParameter="UserControlGreen" Content="绿色" Margin="10"></RadioButton>
    </StackPanel>
    <ContentControl Content="{Binding MainContent}"/>
</DockPanel>
?
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
public class MainViewModel:ViewModelBase
  {
      private FrameworkElement mainContent;
 
      public FrameworkElement MainContent
      {
          get { return mainContent; }
          set { mainContent = value; OnPropertyChanged(); }
      }
 
 
      public ICommand ChangePageCommand { get; set; }
 
      public MainViewModel()
      {
          ChangePageCommand = new CommandBase(ChangePage);
      }
 
      private void ChangePage(object obj)
      {
          //【 * 】这里需要拼接路径
          Type type = Type.GetType("WpfApp2.Views." + obj.ToString());
          MainContent = (FrameworkElement)System.Activator.CreateInstance(type);
      }
  }

3.实现效果

WPF实现页面的切换的示例代码

总结

到此这篇关于WPF实现页面的切换的示例代码的文章就介绍到这了,更多相关WPF 页面切换内容请搜索服务器之家以前的文章或继续浏览下面的相关文章希望大家以后多多支持服务器之家!

原文链接:https://blog.csdn.net/qq_39847278/article/details/128386432

延伸 · 阅读

精彩推荐
  • C#c#图片上传和显示的实现方法

    c#图片上传和显示的实现方法

    这篇文章主要介绍了c#实现图片上传和显示的实现方法,可实现图片上传效果预览功能,需要的朋友可以参考下。...

    叶超Luka8922021-12-08
  • C#c# volatile 关键字的拾遗补漏

    c# volatile 关键字的拾遗补漏

    这篇文章主要介绍了c# volatile 关键字的相关资料,帮助大家更好的理解和学习c#的相关知识,感兴趣的朋友可以了解下...

    精致码农 • 王亮6952022-10-12
  • C#利用C#代码将html样式文件与Word文档互换的方法

    利用C#代码将html样式文件与Word文档互换的方法

    这篇文章主要给大家介绍了关于利用C#代码将html样式文件与Word文档互换的方法,文中通过示例代码将两种转换介绍的非常详细,对大家的学习或者工作具有...

    begrateful3862022-02-12
  • C#C# 使用 OleDbConnection 连接读取Excel的方法

    C# 使用 OleDbConnection 连接读取Excel的方法

    Connection类有四种:SqlConnection,OleDbConnection,OdbcConnection和OracleConnection。...

    郑金旭10042022-10-21
  • C#C#学习教程之Socket的简单使用

    C#学习教程之Socket的简单使用

    这篇文章主要给大家介绍了关于C#学习教程之Socket的简单使用,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要...

    张子浩8612022-03-09
  • C#C#动态加载组件后如何在开发环境中调试详解

    C#动态加载组件后如何在开发环境中调试详解

    这篇文章主要给大家介绍了关于C#动态加载组件后如何在开发环境中调试的相关资料,文中通过图文介绍的非常详细,对大家的学习或者使用C#具有一定的参...

    旦旦7312022-07-11
  • C#WPF换肤设计原理浅析

    WPF换肤设计原理浅析

    这篇文章主要为大家详细介绍了WPF换肤设计原理,具有一定的参考价值,感兴趣的小伙伴们可以参考一下...

    sunny90612052021-12-08
  • C#Quartz.Net实现原理及使用方法详解

    Quartz.Net实现原理及使用方法详解

    这篇文章主要介绍了Quartz.Net实现原理及使用方法详解,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,需要的朋友可以...

    David Huang4002022-10-19