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?

Foi útil?

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.

Licenciado em: CC-BY-SA com atribuição
Não afiliado a StackOverflow
scroll top