WPF入門教程系列二十八 ——DataGrid使用示例MVVM模式(5)

来源:https://www.cnblogs.com/chillsrc/archive/2023/06/11/17472473.html
-Advertisement-
Play Games

最近需要在計算大文件的 MD5 值時顯示進度,於是我寫瞭如下的代碼: ``` cs public long Length {get; private set; } public long Position { get; private set; } public async Task Compute ...


WPF入門教程系列目錄 WPF入門教程系列二——Application介紹 WPF入門教程系列三——Application介紹(續) WPF入門教程系列四——Dispatcher介紹

WPF入門教程系列五——Window 介紹

WPF入門教程系列十一——依賴屬性(一) WPF入門教程系列十五——WPF中的數據綁定(一)    

添加ClickAction的實現

      通過上面兩步,我們將準備工具全部做完了,現在需要在.xmal文件中給Button按鈕的Command屬性綁定了一個方法叫做ClickSaveAction,DataGrid控制項的SelectItem綁定MainWindowVM(ViewModel)中的AreaVM屬性。

1. 在Visual Studio 2022中打開MainWindows.xmal文件。

2. 對DataGrid的SelectItem進行了數據綁定。具體代碼如下:

 <DataGrid x:Name="gridArea" Grid.Row="1" d:ItemsSource="{d:SampleData ItemCount=5}" 
AutoGenerateColumns
="False"
HorizontalAlignment="Left" VerticalAlignment="Top" SelectedItem="{Binding Path=AreaVM,
Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}
">

3.將ClickSaveCommand綁定到Button按鈕的Command屬性上,這個ClickSaveCommand指令將代替保存按鈕的click事件,將數據保存到資料庫。具體代碼如下:

<Button  x:Name="btnSave" Height="22" Width="120" Command="{Binding ClickSaveAction}" >保存</Button>

註意:Command屬性僅僅作為Click行為的綁定,其他行為,如滑鼠移入、移出等事件,要使用另外的MVVM方式進行綁定。

4.MainWindow.xmal的全部代碼如下:

<Window x:Class="WpfGridDemo.NET7.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:WpfGridDemo.NET7"
        mc:Ignorable="d"
        Title="MainWindow" Height="600" Width="960">
    <Grid>
        <Grid.RowDefinitions>
            <RowDefinition Height="100"></RowDefinition>
            <RowDefinition Height="*"></RowDefinition>
            <RowDefinition Height="25"></RowDefinition>
        </Grid.RowDefinitions>

        <DataGrid x:Name="gridArea" Grid.Row="1" d:ItemsSource="{d:SampleData ItemCount=5}" 
AutoGenerateColumns
="False"
HorizontalAlignment
="Left" VerticalAlignment="Top" SelectedItem="{Binding Path=AreaVM, Mode=TwoWay,UpdateSourceTrigger=PropertyChanged}"> <DataGrid.Columns> <DataGridComboBoxColumn Header="城市" Width="120" x:Name="cboCity"
ClipboardContentBinding
="{x:Null}" SelectedValuePath="Code"
SelectedValueBinding
="{Binding Path=CityCode,UpdateSourceTrigger=PropertyChanged}"
DisplayMemberPath
="Name" SelectedItemBinding="{x:Null}" /> <DataGridTextColumn Header="縣區鎮" Width="*" Binding="{Binding Name}"
ClipboardContentBinding
="{x:Null}"/> <DataGridTextColumn Header="郵編" Width="100" Binding="{Binding Code}"
ClipboardContentBinding="{x:Null}"/> <DataGridTextColumn Header="創建時間" Width="160" Binding="{Binding Created}"
ClipboardContentBinding="{x:Null}"/> <DataGridTextColumn Header="更新時間" Width="160" Binding="{Binding Updated}"
ClipboardContentBinding="{x:Null}"/> </DataGrid.Columns> </DataGrid> <WrapPanel Grid.Row="2"> <Button x:Name="btnRefresh" Height="22" Width="120" Click="btnRefresh_Click">刷新</Button> <Button x:Name="btnSave" Height="22" Width="120" Command="{Binding ClickSaveAction}" >保存</Button> </WrapPanel> </Grid> </Window>

5.在Visual Studio 2022中按F5鍵,啟動WPF應用程式,使用滑鼠左鍵點擊“刷新”按鈕,在數據呈現之後,使用滑鼠左鍵選中DataGrid中的一條記錄,進行修改,然後點擊“保存”按鈕。如下圖。

6. 使用滑鼠左鍵點擊“刷新”按鈕,在數據呈現之後,我們發現,剛纔所做的修改,已經保存到資料庫了。如下圖。 

數據已經保存到資料庫,如下圖。

 

7.如果我們要讓保存按鈕禁用,可以將執行的方法返回為False,具體代碼如下:

        /// <summary>

        /// 命令是否可以執行
        /// </summary>
        /// <returns></returns>
        bool CanSaveExecute()
        {
return false; }

8. 在Visual Studio 2022中按F5鍵,啟動WPF應用程式,能夠看到,界面中按鈕已經是禁用狀態了,我們綁定的這個命令是否可以執行,是直接影響到按鈕能否被點擊的!這個值會直接作用在按鈕的IsEnabled上。如下圖。

 

 

七、ComboBox下拉事件轉為Command命令

用於 DataGridComboBoxColumn 顯示有一組項可供選擇的數據,例如枚舉。 DataGridComboBoxColumn 允許用戶從下拉列表中選擇項。本文通過將Command命令綁定到comboBox的SelectionChanged事件上,實現自動刷新用戶選擇的省份的相應城市信息。

在WPF中預設的Command綁定往往不能滿足覆蓋所有的事件,例如ComboBox的SelectionChanged事件,DataGrid的SelectionChanged事件等等,這時就可以用到一個擴展庫,來實現事件綁定Command。

微軟從WPF 4.0開始,引入了一個比較實用的庫——Interactions,這個庫主要是通過附加屬性來對UI控制項註入一些新的功能,除了內置了一系列比較好用的功能外,還提供了比較良好的擴展介面。

    本文這裡簡單的介紹一下Behavior這個擴展,顧名思義,Behavior可以賦予控制項新的行為能力。

    事件綁定到Command需要用到Interaction.Triggers這個屬性 ,在這個屬性裡面添加一個或多個EventTrigger並指定關註的的事件名稱,在EventTrigger中通過InvokeCommandAction來綁定事件對應的command。

1. 在Visual Studio 2022中打開MainWindows.xmal文件,併在文件的開頭添加如下命名空間。

          xmlns:be="http://schemas.microsoft.com/xaml/behaviors"

2. 在MainWindows.xmal文件中添加一個ComboBox控制項,具體代碼如下:

<WrapPanel Grid.Row="0" HorizontalAlignment="Left">
            <ComboBox x:Name="cboProvince" DisplayMemberPath="Name" SelectedValuePath="Code" >
                <be:Interaction.Triggers>

                    <be:EventTrigger EventName="SelectionChanged">
                        <be:InvokeCommandAction Command="{Binding ProviceChangedAction}"/>

                    </be:EventTrigger>
                </be:Interaction.Triggers>
            </ComboBox>
        </WrapPanel>

3.     在寫完了以上代碼之後,Visual Studio 2022的界面設計器中原來呈現的UI界面,消失了,顯示“無效標記,有關詳細信息,請查看錯誤列表”。如下圖。

4.從錯誤信息中來查看,應用程式缺少程式集,沒有安裝相應的程式包。使用滑鼠在菜單欄中選擇“工具--》NuGet軟體包管理器- -》 管理此解決方案的NuGet程式包”,如下圖。

5.    在Visual Studio 2022的NuGet-解決方案標簽頁中,瀏覽頁面的搜索框中輸入“Microsoft.Xaml.Behaviors.Wpf”進行搜索,然後使用滑鼠左鍵先選中要安裝的項目名稱,然後再點擊“安裝”按鈕。如下圖。

6.安裝成功之後,錯誤列表中的錯誤信息消失了,UI設計器中的UI又回來了。如下圖。

 

 


您的分享是我們最大的動力!

-Advertisement-
Play Games
更多相關文章
  • 博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ...
  • title: "Go 語言連接資料庫實現增刪改查" date: 2023-06-10T18:55:16+08:00 draft: true tags: ["Go"] categories: ["Go"] # Go 連接 MySQL實現增刪改查 ## 一、初始化連接 ### 創建項目 ![](http ...
  • 一、Maven常用命令及其作用 Maven的生命周期包括:clean、validate、compile、test、package、verify、install、site、deploy,其中需要註意的是:執行後面的命令時,前面的命令自動得到執行,(其中,也可以跳過其中的步驟,如:test,在mvn i ...
  • 博客推行版本更新,成果積累制度,已經寫過的博客還會再次更新,不斷地琢磨,高質量高數量都是要追求的,工匠精神是學習必不可少的精神。因此,大家有何建議歡迎在評論區踴躍發言,你們的支持是我最大的動力,你們敢投,我就敢肝 ...
  • ## 簡介 猜拳小游戲是一個經典的小游戲項目,也是初學者學習編程的必要練手題目之一。在 Python 中,我們可以使用多種方式來實現一個簡單的猜拳小游戲。 本文將依次介紹六種Python實現猜拳小游戲的方法,包括:使用 `if-else` 條件語句、使用 `random` 模塊、使用字典映射勝負關係 ...
  • 在分散式環境中,當需要控制對某一資源的不同進程併發訪問時就需要使用分散式鎖;可以使用 ZooKeeper + Curator 來實現分散式鎖,本文主要介紹 Curator 中分散式鎖的使用,文中所使用到的軟體版本:Java 1.8.0_341、Zookeeper 3.7.1、curator 5.4. ...
  • 馬哥原創,淄博燒烤分析大屏,含:詞雲圖、玫瑰圖、柱形圖、折線圖、地圖等圖表,jieba分詞、snownlp情感分析、stopwords停用詞、flask網頁服務等技術。 ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...