作者热门文章
- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我的情况是,我有“tablegenerateModel”类的 ObservableCollection,该类进一步包含“column_Data”类的 ObservableCollection,并且这个“column_Data”类包含 3 个 UI 元素,这些元素必须绑定(bind)到包含三列的 DataGrid。 如果需要,您可以复制粘贴我的代码,我已经编写了所有类和 xaml 供您验证我的代码
所以我的 Model.cs 如下:
public class tablegenerateModel {
public ObservableCollection < column_Data > Column_data_List {
get;
set;
}
public int NumberOfColumns {
get;
set;
}
private ICommand _CreatColumnCommand; //THIS IS THE BUTTON EVENT GENERATED WHEN USER PRESS AN INTEGER VALUE IN "NumberOfColumns" AND PRESS "Create" button. So the "Column_data_List" will repeat that many times the value user entered
ViewModel vm;
public ICommand CreatColumnCommand {
get {
if (_CreatColumnCommand == null) {
_CreatColumnCommand = new RelayCommand(
param => vm = new ViewModel(this)
);
}
return _CreatColumnCommand;
}
}
}
public class column_Data {
public string Column_Name {
get;
set;
}
}
public class ViewModel: INotifyPropertyChanged {
private ObservableCollection < tablegenerateModel > _lb_GlobalList;
private ObservableCollection < column_Data > _Column_data_List;
public ObservableCollection < tablegenerateModel > lb_GlobalList {
get {
return _lb_GlobalList;
}
set {
if (value != _lb_GlobalList) {
_lb_GlobalList = value;
RaisePropertyChanged("lb_GlobalList");
}
}
}
public ObservableCollection < column_Data > Column_data_List {
get {
return _Column_data_List;
}
set {
if (value != _Column_data_List) {
_Column_data_List = value;
RaisePropertyChanged("Column_data_List");
}
}
}
public ICommand ClickCommand
private bool _canExecute;
public ViewModel() {
_canExecute = true;
lb_GlobalList = new ObservableCollection < tablegenerateModel > ();
for (int i = 1; i < 6; i++) {
//Add To it data here
}
}
public ViewModel(tablegenerateModel tablegenerateModels) //IT WILL BE CALLED WHEN BUTTON WILL BE CLICKED (see tablegenerateModel class ICommand for it)
{
Column_data_List = new ObservableCollection < column_Data > ();
for (int i = 1; i < tablegenerateModels.NumberOfColumns; i++) { //Add data here
}
MessageBox.Show("The NumberOfColumns value is:" + tablegenerateModels.NumberOfColumns);
}
}
}
<Window x:Class="PyXgen.MainWindow" xmlns="http://schemas.microsoft.com/winfx/2006/xaml/presentation" xmlns:x="http://schemas.microsoft.com/winfx/2006/xaml" xmlns:vM="clr-namespace:PyXgen" Title="MainWindow" Height="350" Width="525">
<Window.DataContext>
<vM:ViewModel></vM:ViewModel>
</Window.DataContext>
<Grid Name="ButtonsContainer">
<ListBox Grid.Row="1" ItemsSource="{Binding lb_GlobalList}" ScrollViewer.VerticalScrollBarVisibility="Auto" BorderBrush="Gray" Margin="0,30,0,0" Grid.RowSpan="2">
<ListBox.ItemTemplate>
<DataTemplate>
<Grid>
<StackPanel>
<Grid Margin="0,2">
<Grid.ColumnDefinitions>
<ColumnDefinition Width="*" />
<ColumnDefinition Width="*" />
</Grid.ColumnDefinitions>
<Grid.RowDefinitions>
<RowDefinition Height="45" />
<RowDefinition Height="45" />
<RowDefinition Height="45" />
<RowDefinition Height="*" />
<RowDefinition Height="*" />
<RowDefinition Height="*" />
</Grid.RowDefinitions>
<Grid Grid.Row="4">
<StackPanel>
<Grid Margin="0,2">
Grid.Row="0" Width="80px" Height="20px" Margin="20,5,0,0" Name="fname4"/>
<Button Grid.Row="1" Grid.Column="1" Height="25" Width="70" Content="Create" Command="{Binding CreatColumnCommand}" HorizontalAlignment="Center" VerticalAlignment="Center"></Button>
</Grid>
</StackPanel>
</Grid>
<Grid Margin="0,2" Grid.Row="5">
<DataGrid x:Name="gvSelectedCourses" Grid.Column="1" HorizontalAlignment="Center" ItemsSource="{Binding Column_data_List , Mode=TwoWay}" AutoGenerateColumns="False" Width="450">
<DataGrid.Columns>
<DataGridTextColumn Header="Column Name" Binding="{Binding ,Mode=TwoWay}" Width="150" />
</DataGrid.Columns>
</DataGrid>
</Grid>
</Grid>
</StackPanel>
</Grid>
</DataTemplate>
</ListBox.ItemTemplate>
</ListBox>
</Grid>
</Window>
MessageBox.Show("The NumberOfColumns value is:" + tablegenerateModels.NumberOfColumns);
最佳答案
如下更新您的代码。您在 tablegeneratedModel 中绑定(bind)了 observable 集合,但您正在更新 ViewModel 上的集合。
public ViewModel(tablegenerateModel tablegenerateModels) //IT WILL BE CALLED WHEN BUTTON WILL BE CLICKED (see tablegenerateModel class ICommand for it)
{
tablegenerateModels.Column_data_List = new ObservableCollection<column_Data>();
for (int i = 1; i < tablegenerateModels.NumberOfColumns; i++)
{
Column_data_List.Add(lb_col = new column_Data()
{
Column_Name = "ColumnName" + i,
Data_Size = i,
Data_types = "Double" + i
});
}
MessageBox.Show("The NumberOfColumns value is:" + tablegenerateModels.NumberOfColumns);
}
关于c# - 如何在我的情况下使用 mvvm 绑定(bind) DataGrid(ObservableCollection 内的 ObservableCollection),我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/32716226/
我是一名优秀的程序员,十分优秀!