1.什么是MVVM?
成都創新互聯公司從2013年開始,先為邯山等服務建站,邯山等地企業,進行企業商務咨詢服務。為邯山企業網站制作PC+手機+微官網三網同步一站式服務解決您的所有建站問題。MVVM是Model、View、ViewModel的簡寫,這種模式的引入就是使用ViewModel來降低View和Model的耦合,說是降低View和Model的耦合。也可以說是是降低界面和邏輯的耦合,理想情況下界面和邏輯是完全分離的,單方面更改界面時不需要對邏輯代碼改動,同樣的邏輯代碼更改時也不需要更改界面。同一個ViewModel可以使用完全不用的View進行展示,同一個View也可以使用不同的ViewModel以提供不同的操作。
2.項目目錄
從上面的圖我們可以看出,處理事務的文件有幾個類型:View,ViewModel,Command,Property,Model,這個幾個類型的圖片
最下面的ViewModelBase.cs就是Property,對應處理觸發屬性發現變化的事務。
3.代碼分析:
a):入口 App.xaml
private void Application_Startup(object sender, StartupEventArgs e) { //創建一個ViewModel; MainViewModel mode = new MainViewModel(); //初始化ViewModel內容 mode.ItemDatas = new ObservableCollection(); mode.ItemDatas.Add(new ItemData { Title = "TST", Content = "sss" }); mode.ItemDatas.Add(new ItemData { Title = "2TST", Content = "2sss" }); //初始化View; MainWindow main = new MVVMGridDemo.MainWindow(); //把ViewModel綁定到View上 main.DataContext = mode; //顯示窗口 main.Show(); }
b):MainWindow窗口ViewModel;
view代碼
<Grid> <DataGrid x:Name="dataGrid" AutoGenerateColumns="False" ItemsSource="{Binding ItemDatas}" HorizontalAlignment="Left" Margin="57,59,0,0" VerticalAlignment="Top" Height="173" Width="320"> <DataGrid.Columns> <DataGridTextColumn Header="Title" Width="100" Binding="{Binding Title}" /> <DataGridTextColumn Header="Content" Width="200" Binding="{Binding Content}"/> </DataGrid.Columns> </DataGrid> <Button x:Name="button" Command="{Binding ButtonClick }" CommandParameter="{Binding ElementName=dataGrid}" Content="修改" HorizontalAlignment="Left" Margin="57,10,0,0" VerticalAlignment="Top" Width="75"/> <TextBox x:Name="textBox" HorizontalAlignment="Left" Height="19" Margin="155,10,0,0" TextWrapping="Wrap" Text="{Binding TexxT}" VerticalAlignment="Top" Width="97"/> </Grid>
viewmodel代碼
public class MainViewModel : ViewModelBase { private ObservableCollection _itemdatas;//view 中Name為Texxt的值在這里實現 private string _texxt; public string TexxT { get { return this._texxt; } set { this._texxt = value; OnPropertyChanged("TexxT"); } }//view中itemsourse 為ItemData的數據綁定; public ObservableCollection ItemDatas { get { return _itemdatas; } set { this._itemdatas = value; OnPropertyChanged("ItemDatas"); } }//修改按鈕點擊事件在這里實現 public ICommand ButtonClick { get { return new ActionCommand(p => BClick(p)); } } private void BClick(object obj) { DataGrid box = (DataGrid)obj; ItemDatas[0].Title = TexxT;//刷新dataGrid box.Items.Refresh(); } }
全部源代碼:https://github.com/servucn/MVVMGridDemo
交流地址:http://www.ucasp.net/wpfresources/mvvmgriddemo.shtml
另外有需要云服務器可以了解下創新互聯scvps.cn,海內外云服務器15元起步,三天無理由+7*72小時售后在線,公司持有idc許可證,提供“云服務器、裸金屬服務器、高防服務器、香港服務器、美國服務器、虛擬主機、免備案服務器”等云主機租用服務以及企業上云的綜合解決方案,具有“安全穩定、簡單易用、服務可用性高、性價比高”等特點與優勢,專為企業上云打造定制,能夠滿足用戶豐富、多元化的應用場景需求。
當前題目:WPF中MVVM如何綁定DataGrid并動態修改單元格-創新互聯
URL分享:http://vcdvsql.cn/article36/cdjesg.html
成都網站建設公司_創新互聯,為您提供網站設計、網頁設計公司、品牌網站制作、手機網站建設、網站改版、微信公眾號
聲明:本網站發布的內容(圖片、視頻和文字)以用戶投稿、用戶轉載內容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網站立場,如需處理請聯系客服。電話:028-86922220;郵箱:631063699@qq.com。內容未經允許不得轉載,或轉載時需注明來源: 創新互聯