Pergunta
Atualmente meu modelo tem propriedades dez que para os nossos propósitos aqui eu vou chamar AnnualizedRate1
, AnnualizedRate2
, ..., AnnualizedRate10
que são revelados a vista no modelo de vista através de propriedades dez Rate1
, Rate2
, ..., Rate10
. Um dos meus pontos de vista mostra esses valores em um DataGrid
. Isto é muito repetitivo e uma dor para se adaptar às mudanças de requisitos. Tem que haver uma maneira melhor do que o seguinte.
Model (MyModel
):
public decimal AnnualizedRate1 { get { return this.AnnualizedRate(1); } }
public decimal AnnualizedRate2 { get { return this.AnnualizedRate(2); } }
...
public decimal AnnualizedRate10 { get { return this.AnnualizedRate(10); } }
onde MyModel.AnnualizedRate
é
public decimal AnnualizedRate(int i);
Model View (MyViewModel
):
public decimal Rate1 { get { return myModel.AnnualizedRate1; } }
public decimal Rate2 { get { return myModel.AnnualizedRate2; } }
...
public decimal Rate10 { get { return myModel.AnnualizedRate10; } }
Vista (MyView
):
xmlns:dg="http://schemas.microsoft.com/wpf/2008/toolkit"
...
<dg:DataGrid>
<dg:DataGrid.Columns>
<dg:DataGridTextColumn
Header="Rate1"
Binding="{Binding Rate1, StringFormat=P}"
IsReadOnly="True"/>
<dg:DataGridTextColumn
Header="Rate2"
Binding="{Binding Rate2, StringFormat=P}"
IsReadOnly="True"/>
...
<dg:DataGridTextColumn
Header="Rate10"
Binding="{Binding Rate10, StringFormat=P}"
IsReadOnly="True"/>
</dg:DataGrid.Columns>
</dg:DataGrid>
Alguém tem alguma idéia?
Solução
Gostaria de usar e ObservableCollection para armazenar os dados e se ligam a grade para.
Outras dicas
Aqui está o código para fazer o que RB Davidson disse que fazer. Quando você achar que este faz o que você queria, por favor, dar-lhe crédito. Sua resposta está correta.
Em seu ViewModel:
public class AnnualizedRateViewModel
{
public string Name { get; set; }
public decimal Rate { get; set; }
}
public MyViewModel : INotifyPropertyChanged
{
public MyViewModel()
{
AnnualizedRates = new ObservableCollection<AnnualizedRateViewModel>();
//I'd recommend your model having a GetAllRates() function rather than this,
//but for demo purposes, this works
for(int i = 1; i <= 10; i++)
{
AnnualizedRates.Add(new AnnualizedRateViewModel()
{
Name = string.Format("Rate {0}", i),
Rate = MyModel.AnnualizedRate(i)
});
}
}
private ObservableCollection<int> _annualizedRates;
public ObservableCollection<int> AnnualizedRates
{
get { return _annualizedRates; }
set
{
_annualizedRates = value;
//Raise OnNotifyPropertyChanged event from your
//implementation of INotifyPropertyChanged in your viewmodel
//the full implementation of this is outside the scope of this demo
}
}
}
A partir daí você realmente usar ligação de dados para criar as colunas na sua opinião. Você iria ligar-se a esta coleção de AnnualizedRates. Desde o WPF Toolkit não faz isso fácil, você tem que escrever um conversor de valor para converter o ObservableCollection<AnnualizedRateViewModel>
a um ObservableCollection<DataGridColumn>
.
<dg:DataGrid AutoGenerateColumns="false" Columns="{Binding AnnualizedRates, ValueConverter={StaticResource AnnualizedRatesToDataGridColumnCollectionConverter}}">
</dg:DataGrid>
A coisa que você deve aprender aqui é quando você está pensando em si mesmo "repetição", e tentar em vez disso pensar "coleção".
Boa sorte ... e novamente, o crédito RB Davidson.