主頁 >
.NET開發 > C# CM框架下打造符合MVVM思想的WPF登錄表單
C# CM框架下打造符合MVVM思想的WPF登錄表單
2022-03-13 06:06:42 .NET開發
?概述
- 登錄表單無論在bs還是cs中都很常見,使用winform或者wpf ui進行設計都相對比較簡單,但是如果在WPF框架,比如:Caliburn.Micro下,設計一個符合MVVM思想的登錄表單就相對有了點難度,因為CM框架本身的設計理念是VM first而非View first.接下來開始講解我的設計.
后臺設計
-
資料模型:定義一個用戶登錄類,類中囊括三個屬性
-
public class UserInformation
{
public UserInformation()
{
UserName = "zls20210502";
Password = "123456";
}
/// <summary>
/// 用戶名
/// </summary>
public string UserName { get; set; }
?
/// <summary>
/// 密碼
/// </summary>
public string Password { get; set; }
?
/// <summary>
/// 性別
/// </summary>
public int Gender { get; set; }
?
?
}
登錄資訊驗證:這里按理應該增加注冊資訊,應該是個list,我只是舉例寫了一組:
-
public string ValidateLoginData()
{
StringBuilder sb = new StringBuilder();
if (UserInformation.UserName == "zls20210502"
&& UserInformation.Password == "12345678")
{
sb.Append("");
}
else
{
sb.AppendLine("賬號或者密碼輸入有誤,請檢查!");
}
return sb.ToString();
}
登錄方法:這里首先驗證登錄資訊,驗證失敗就彈窗提示報錯資訊,否則通過GetView()方法獲取當前view并隱藏,然后通過IOC獲取IWindowManager,再通過ShowDialog顯示主表單,這幾個方法都CM框架集成的方法.登錄表單需要繼承Screen.
-
public void BtnLogin()
{
var str = ValidateLoginData();
if(!string.IsNullOrEmpty(str))
{
MessageBox.Show(str);
}
else
{
var loginWindow = (Window)this.GetView();
loginWindow.Hide();
?
MainWindowViewModel mainWindowViewModel = new MainWindowViewModel();
IWindowManager windowManager = IoC.Get<IWindowManager>();
windowManager.ShowDialog(mainWindowViewModel);
this.TryClose();
}
?
}
前臺設計
全部代碼如下:
-
<Window x:
xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation"
xmlns:dxe="http://schemas.devexpress.com/winfx/2008/xaml/editors"
xmlns:d="http://schemas.microsoft.com/expression/blend/2008"
xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml"
xmlns:mc="http://schemas.openxmlformats.org/markup-compatibility/2006"
mc:Ignorable="d"
WindowStyle="None" AllowsTransparency="True" Background="{x:Null}"
Title="LoginWindow" Height="320" WindowStartupLocation="CenterScreen">
<Grid Height="{Binding Height, ElementName=w}">
<Grid.RowDefinitions>
<RowDefinition Height="150" />
<RowDefinition Height="50" />
<RowDefinition Height="50" />
<RowDefinition />
</Grid.RowDefinitions>
<Border Grid.RowSpan="4" BorderBrush="Gray" BorderThickness="3" CornerRadius="20" Margin="10" Opacity="1" Background="White"></Border>
<Button Name="BtnClose" Grid.Row="0" Margin="20"
Height="48" BorderBrush="{x:Null}" Background="{x:Null}"
HorizontalAlignment="Right" VerticalAlignment="Top">
<Image Source="/Images/exit1.png"/>
</Button>
<Image Grid.Row="0" VerticalAlignment="Center" Height="120" Source="/Images/login.png" />
?
<TextBox x:Name="UserTextBox" Text="{Binding UserInformation.UserName}" Grid.Row="1" VerticalAlignment="Bottom" BorderThickness="0,0,0,1" Height="25"></TextBox>
<TextBlock Foreground="DarkGray" Grid.Row="1" IsHitTestVisible="False" HorizontalAlignment="Center" Height="25" Text="請輸入用戶名" VerticalAlignment="Bottom" FontFamily="Microsoft YaHei">
<TextBlock.Style>
<Style TargetType="{x:Type TextBlock}">
<Setter Property="Visibility" Value="https://www.cnblogs.com/zls366/archive/2022/03/12/Collapsed"/>
<Style.Triggers>
<DataTrigger Binding="{Binding Text, ElementName=UserTextBox}" Value="">
<Setter Property="Visibility" Value="https://www.cnblogs.com/zls366/archive/2022/03/12/Visible"/>
</DataTrigger>
</Style.Triggers>
</Style>
</TextBlock.Style>
</TextBlock>
<dxe:PasswordBoxEdit x:Name="PwdTextBox" Text="{Binding UserInformation.Password}"
Grid.Row="2"
VerticalAlignment="Bottom" BorderThickness="0,0,0,1" Height="25"></dxe:PasswordBoxEdit>
<TextBlock Foreground="DarkGray" Grid.Row="2" IsHitTestVisible="False" HorizontalAlignment="Center" Height="25" Text="請輸入密碼" VerticalAlignment="Bottom" FontFamily="Microsoft YaHei">
<TextBlock.Style>
<Style TargetType="{x:Type TextBlock}">
<Setter Property="Visibility" Value="https://www.cnblogs.com/zls366/archive/2022/03/12/Collapsed"/>
<Style.Triggers>
<DataTrigger Binding="{Binding Text, ElementName=PwdTextBox}" Value="">
<Setter Property="Visibility" Value="https://www.cnblogs.com/zls366/archive/2022/03/12/Visible"/>
</DataTrigger>
</Style.Triggers>
</Style>
</TextBlock.Style>
</TextBlock>
?
<Button Name="BtnLogin" Grid.Row="2" Margin="0,0,20,0"
BorderBrush="{x:Null}" Background="{x:Null}"
Height="48" HorizontalAlignment="Right" VerticalAlignment="Top">
<Image Source="/Images/userlogin.png"/>
</Button>
</Grid>
</Window>
效果演示
百度網盤鏈接:https://pan.baidu.com/s/1lvR7VCJTWI3cD1c0EUIDqA
提取碼:
獲取方式1:添加小編微信mm1552923,備注:登錄;
轉載請註明出處,本文鏈接:https://www.uj5u.com/net/441888.html
標籤:.NET技术
上一篇:.NET中的HashSet
下一篇:C# CM框架下一行代碼實作多頁面管理
-
- 標籤雲
-
-
- 熱門瀏覽
-
-
WebAPI簡介
Web體系結構: 有三個核心:資源(resource),URL(統一資源識別符號)和表示 他們的關系是這樣的:一個資源由一個URL進行標識,HTTP客戶端使用URL定位資源,表示是從資源回傳資料,媒體型別是資源回傳的資料格式。 接下來我們說下HTTP. HTTP協議的系統是一種無狀態的方式,使用請求/ ......
uj5u.com 2020-09-09 22:07:47 more
-
asp.net core 3.1 入口:Program.cs中的Main函式
本文分析Program.cs 中Main()函式中代碼的運行順序分析asp.net core程式的啟動,重點不是剖析原始碼,而是理清程式開始時執行的順序。到呼叫了哪些實體,哪些法方。asp.net core 3.1 的程式入口在專案Program.cs檔案里,如下。ususing System; us ......
uj5u.com 2020-09-09 22:07:49 more
-
asp.net網站作為websocket服務端的應用該如何寫
最近被websocket的一個問題困擾了很久,有一個需求是在web網站中搭建websocket服務。客戶端通過網頁與服務器建立連接,然后服務器根據ip給客戶端網頁發送資訊。 其實,這個需求并不難,只是剛開始對websocket的內容不太了解。上網搜索了一下,有通過asp.net core 實作的、有 ......
uj5u.com 2020-09-09 22:08:02 more
-
ASP.NET 開源匯入匯出庫Magicodes.IE Docker中使用
Magicodes.IE在Docker中使用 更新歷史 2019.02.13 【Nuget】版本更新到2.0.2 【匯入】修復單列匯入的Bug,單元測驗“OneColumnImporter_Test”。問題見(https://github.com/dotnetcore/Magicodes.IE/is ......
uj5u.com 2020-09-09 22:08:05 more
-
在webform中使用ajax
如果你用過Asp.net webform, 說明你也算是.NET 開發的老兵了。WEBform應該是2011 2013左右,當時還用visual studio 2005、 visual studio 2008。后來基本都用的是MVC。 如果是新開發的專案,估計沒人會用webform技術。但是有些舊版 ......
uj5u.com 2020-09-09 22:08:50 more
-
iis添加asp.net網站,訪問提示:由于擴展配置問題而無法提供您請求的
今天在iis服務器配置asp.net網站,遇到一個問題,記錄一下: 問題:由于擴展配置問題而無法提供您請求的頁面。如果該頁面是腳本,請添加處理程式。如果應下載檔案,請添加 MIME 映射。 WindowServer2012服務器,添加角色安裝完.netframework和iis之后,運行aspx頁面 ......
uj5u.com 2020-09-09 22:10:00 more
-
WebAPI-處理架構
帶著問題去思考,大家好! 問題1:HTTP請求和回傳相應的HTTP回應資訊之間發生了什么? 1:首先是最底層,托管層,位于WebAPI和底層HTTP堆疊之間 2:其次是 訊息處理程式管道層,這里比如日志和快取。OWIN的參考是將訊息處理程式管道的一些功能下移到堆疊下端的OWIN中間件了。 3:控制器處理 ......
uj5u.com 2020-09-09 22:11:13 more
-
微信門戶開發框架-使用指導說明書
微信門戶應用管理系統,采用基于 MVC + Bootstrap + Ajax + Enterprise Library的技術路線,界面層采用Boostrap + Metronic組合的前端框架,資料訪問層支持Oracle、SQLServer、MySQL、PostgreSQL等資料庫。框架以MVC5,... ......
uj5u.com 2020-09-09 22:15:18 more
-
WebAPI-HTTP編程模型
帶著問題去思考,大家好!它是什么?它包含什么?它能干什么? 訊息 HTTP編程模型的核心就是訊息抽象,表示為:HttPRequestMessage,HttpResponseMessage.用于客戶端和服務端之間交換請求和回應訊息。 HttpMethod類包含了一組靜態屬性: private stat ......
uj5u.com 2020-09-09 22:15:23 more
-
部署WebApi隨筆
一、跨域 NuGet參考Microsoft.AspNet.WebApi.Cors WebApiConfig.cs中配置: // Web API 配置和服務 config.EnableCors(new EnableCorsAttribute("*", "*", "*")); 二、清除默認回傳XML格式 ......
uj5u.com 2020-09-09 22:15:48 more
-
- 最新发布
-
-
C#多執行緒學習(二) 如何操縱一個執行緒
<a href="https://www.cnblogs.com/x-zhi/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2943582/20220801082530.png" alt="" /></...
uj5u.com 2023-04-19 09:17:20 more
-
C#多執行緒學習(二) 如何操縱一個執行緒
C#多執行緒學習(二) 如何操縱一個執行緒 執行緒學習第一篇:C#多執行緒學習(一) 多執行緒的相關概念 下面我們就動手來創建一個執行緒,使用Thread類創建執行緒時,只需提供執行緒入口即可。(執行緒入口使程式知道該讓這個執行緒干什么事) 在C#中,執行緒入口是通過ThreadStart代理(delegate)來提供的 ......
uj5u.com 2023-04-19 09:16:49 more
-
記一次 .NET某醫療器械清洗系統 卡死分析
<a href="https://www.cnblogs.com/huangxincheng/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/214741/20200614104537.png" alt="" /&g...
uj5u.com 2023-04-18 08:39:04 more
-
記一次 .NET某醫療器械清洗系統 卡死分析
一:背景 1. 講故事 前段時間協助訓練營里的一位朋友分析了一個程式卡死的問題,回過頭來看這個案例比較經典,這篇稍微整理一下供后來者少踩坑吧。 二:WinDbg 分析 1. 為什么會卡死 因為是表單程式,理所當然就是看主執行緒此時正在做什么? 可以用 ~0s ; k 看一下便知。 0:000> k # ......
uj5u.com 2023-04-18 08:33:10 more
-
SignalR, No Connection with that ID,IIS
<a href="https://www.cnblogs.com/smartstar/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/u36196.jpg" alt="" /></a>...
uj5u.com 2023-03-30 17:21:52 more
-
一次對pool的誤用導致的.net頻繁gc的診斷分析
<a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...
uj5u.com 2023-03-28 10:15:33 more
-
一次對pool的誤用導致的.net頻繁gc的診斷分析
<a href="https://www.cnblogs.com/dotnet-diagnostic/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/3115652/20230225090434.png" alt=""...
uj5u.com 2023-03-28 10:13:31 more
-
C#遍歷指定檔案夾中所有檔案的3種方法
<a href="https://www.cnblogs.com/xbhp/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/957602/20230310105611.png" alt="" /></a&...
uj5u.com 2023-03-27 14:46:55 more
-
C#/VB.NET:如何將PDF轉為PDF/A
<a href="https://www.cnblogs.com/Carina-baby/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/2859233/20220427162558.png" alt="" />...
uj5u.com 2023-03-27 14:46:35 more
-
武裝你的WEBAPI-OData聚合查詢
<a href="https://www.cnblogs.com/podolski/" target="_blank"><img width="48" height="48" class="pfs" src="https://pic.cnblogs.com/face/616093/20140323000327.png" alt="" /><...
uj5u.com 2023-03-27 14:46:16 more
- 友情鏈接
-
-