這兩天試了下Stylet框架,這個框架雖然很小,但是功能齊全,簡化了很多MVVM的代碼,比如Command,對Dialog,MessageBox都有很好的支持。 開源地址 https://github.com/canton7/Stylet 新建一個WPF項目,添加NuGet引用 安裝完成後會自動添加 ...
這兩天試了下Stylet框架,這個框架雖然很小,但是功能齊全,簡化了很多MVVM的代碼,比如Command,對Dialog,MessageBox都有很好的支持。
開源地址 https://github.com/canton7/Stylet
新建一個WPF項目,添加NuGet引用
安裝完成後會自動添加一個BootStrapper文件,這個文件是項目啟動文件
public class Bootstrapper : Bootstrapper<ShellViewModel>
BootStrapper<ShellViewModel>,這個是對應的啟動窗體,Stylet是根據ViewModel去找對應的View去顯示,ViewModel與View的名稱要一致。
我們新添加一個窗體,界面上放一個文本和三個按鈕,來體驗下Stylet的綁定,命令,顯示消息框和子窗體。
<Window x:Class="StyletTestNew.Pages.Window1View" 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:StyletTestNew.Pages" mc:Ignorable="d" xmlns:s="https://github.com/canton7/Stylet" Title="Window1" Height="450" Width="800" d:DataContext="{d:DesignInstance local:Window1ViewModel}"> <Grid> <TextBox HorizontalAlignment="Left" Height="23" Margin="106,100,0,0" TextWrapping="Wrap" Text="{Binding FName,UpdateSourceTrigger=PropertyChanged}" VerticalAlignment="Top" Width="120"/> <Button Content="ChangeTxt" HorizontalAlignment="Left" Margin="365,179,0,0" VerticalAlignment="Top" Width="75" Command="{s:Action BtnCommand}"/> <Button Content="ShowMessage" HorizontalAlignment="Left" Command="{s:Action ShowMessage}" Margin="533,179,0,0" VerticalAlignment="Top" Width="75"/> <Button Content="ShowDialog" HorizontalAlignment="Left" Command="{s:Action ShowDialog}" Margin="649,179,0,0" VerticalAlignment="Top" Width="75"/> </Grid> </Window>
添加ViewModel,添加對應的屬性和方法
public class Window1ViewModel : Screen { private IWindowManager _windowManger; private ShellViewModel _ChildDialog; public Window1ViewModel(IWindowManager windowManager,ShellViewModel ChildDialog) { _windowManger = windowManager; _ChildDialog = ChildDialog; } public string FName { get; set; } = "ly"; public void BtnCommand() { FName = DateTime.Now.ToString(); } public bool CanBtnCommand { get { return !string.IsNullOrWhiteSpace(FName); } } public void ShowMessage() => _windowManger.ShowMessageBox(FName); public void ShowDialog() => _windowManger.ShowDialog(_ChildDialog); }
我們可以看到Button綁定的是方法而不是命令對象
Stylet也可以像Command一樣做CanCommandExecute的功能。
比如,文本框的Text為空,則不可以點按鈕
public bool CanBtnCommand { get { return !string.IsNullOrWhiteSpace(FName); } } public void BtnCommand() { FName = DateTime.Now.ToString(); }
在按鈕綁定的方法名稱前加個Can屬性,實現的功能和CanCommandExecute功能一樣。
大家發現我的ViewModel中沒有實現INotifyPropertyChanged介面,這時,我們需要nuget一個類庫PropertyChanged.Fody。Stylet完美支持PropertyChanged.Fody,不需要我們在去實現下INotifyPropertyChanged介面了。
關於PropertyChanged.Fody,大家可以看這篇文章,介紹的蠻詳細的。
https://www.cnblogs.com/cqgis/p/6360231.html
Stylet也提供了ShowMessage和ShowDialog功能。IWindowManager介面內包含這些方法。
Stylet通過IOC依賴註入,將實例化的WindowManager對象傳入ViewModel中。這樣我們就可以在ViewModel中使用這些功能。
private IWindowManager _windowManger; private ShellViewModel _ChildDialog; public Window1ViewModel(IWindowManager windowManager,ShellViewModel ChildDialog) { _windowManger = windowManager; _ChildDialog = ChildDialog; }
public void ShowMessage() => _windowManger.ShowMessageBox(FName); public void ShowDialog() => _windowManger.ShowDialog(_ChildDialog);
其中,ShowDialog時,傳入的是ShellViewModel,Stylet通過ViewModel去找到了對應的View去顯示。
先寫到這!