在一个空的dataGrid中添加行

时间:2015-09-30 02:44:47

标签: c# wpf mvvm datagrid

我正在构建一个MVVM - WPF应用程序。 我有很少的dataGrids,CRUD操作工作正常。

现在,我希望dataGrid在开头总是空的,当然我可以添加行。所以我可以填写它,但是当我点击保存时,什么都没有保存。

为什么?

视图模型:

public class InvoiceViewModel : ViewModelBase
{
    public Context ctx = new Context();
    public InvoiceViewModel()
    {
        this.Collection = new ObservableCollection<Invoice>();
    }
    private ObservableCollection<Invoice> collection;
    public ObservableCollection<Invoice> Collection
    {
        get
        {
            return collection;
        }
        set
        {
            collection = value;
            OnPropertyChanged("Collection");
        }
    }
    private Invoice _selected;
    public Invoice Selected
    {
        get
        {
            return _selected;
        }
        set
        {
            _selected = value;
            OnPropertyChanged("Selected");
        }
    }
    private void Get()
    {
        ctx.Invoices.ToList().ForEach(invoice => ctx.Invoices.Local.Add(invoice));;
        Collection = ctx.Invoices.Local;
    }
    private void Save()
    {
        foreach (Invoice item in Collection)
        {
            if (ctx.Entry(item).State == System.Data.Entity.EntityState.Added)
            {
                ctx.Invoices.Add(item);
            }
        }
        ctx.SaveChanges();
    }
    private void Delete()
    {
        var id = Selected;
        var invoice = (from i in ctx.Invoices
                    where i.idInvoice == id.idInvoice
                    select i).SingleOrDefault();
        Collection.Remove(invoice);
    }

    #region "Command"
    // private ICommand getCommand;
    private ICommand saveCommand;
    private ICommand removeCommand;

    /*public ICommand GetCommand
    {
        get
        {
            return getCommand ?? (getCommand = new RelayCommand(p => this.Get(), p => this.CanGet()));
        }
    }
    private bool CanGet()
    {
        return true;
    }*/
    public ICommand SaveCommand
    {
        get
        {
            return saveCommand ?? (saveCommand = new RelayCommand(p => this.Save(), p => this.CanSave()));
        }
    }
    private bool CanSave()
    {
        return true;
    }
    public ICommand DeleteCommand
    {
        get
        {
            return removeCommand ?? (removeCommand = new RelayCommand(p => this.Delete(), p => this.CanDelete()));
        }
    }
    public bool CanDelete()
    {
        if (Selected != null)
            return true;
        else
            return false;
    }
    #endregion
}

查看:

<Page.Resources>
    <local:InvoiceViewModel x:Key="invoice" />
    <local:ShopViewModel x:Key="shop" />
    <local:SupplierViewModel x:Key="supplier" />
    <local:ProductViewModel x:Key="product" />
    <DataTemplate x:Key="ProductDataTemplate">
        <TextBlock Text="{Binding product}" />
    </DataTemplate>
</Page.Resources>
<DataGrid x:Name="dataGridInvoice"
          Margin="5"
          Grid.Row="1"
          ItemsSource="{Binding Collection}"
          AutoGenerateColumns="False"
          SelectedItem="{Binding Selected, Mode=TwoWay}"
          SelectionMode="Extended"
          SelectionUnit="FullRow">
    <DataGrid.Columns>
        <DataGridTextColumn x:Name="dataGridTextColumn"
                            Header="Supplier Invoice Nb"
                            Width="*" />
        <DataGridComboBoxColumn Header="Ref Supplier"
                                ItemsSource="{Binding Products, Source={StaticResource supplier}, Mode=OneWay}"
                                DisplayMemberPath="refsup"
                                SelectedValueBinding="{Binding refSupp}"
                                SelectedValuePath="refsup"
                                Width="*" />
        <DataGridTextColumn Header="Unit"
                            Binding="{Binding unit, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"
                            Width="*" />
        <DataGridTextColumn Header="Quantity"
                            Binding="{Binding quantity, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"
                            Width="*" />
        <DataGridTextColumn Header="Prix/MOQ"
                            Binding="{Binding unitPrice, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"
                            Width="*" />
        <DataGridTextColumn Header="Total Price"
                            Binding="{Binding totalPrice, UpdateSourceTrigger=PropertyChanged, Mode=TwoWay}"
                            Width="*" />
    </DataGrid.Columns>
</DataGrid>
<StackPanel Orientation="Horizontal">
    <Button  x:Name="BtnDelete"
             Content="Delete"
             Command="{Binding DeleteCommand}"
             HorizontalAlignment="Center"
             Margin="100,5,5,5"
             Width="85" />
    <Button  x:Name="BtnAdd"
             Content="Save"
             Command="{Binding SaveCommand}"
             HorizontalAlignment="Center"
             Margin="20,5,5,5"
             Width="85" />
</StackPanel>

1 个答案:

答案 0 :(得分:0)

您有这种方法实际上将Collection绑定到实体集的缓存本地。没有绑定,保存添加的项目就更难了:

private void Get() {
        ctx.Invoices.ToList().ForEach(invoice => ctx.Invoices.Local.Add(invoice));;
        Collection = ctx.Invoices.Local;
}

实际上,将所有发票和缓存加载到Local:

就可以这样
private void Get() {
   ctx.Invoices.Load();
   Collection = ctx.Invoices.Local;
}

但是正如你所说的那样,你想要一个空的数据网格(仅用于添加),那么你可以重构Get方法来接受一个bool,指示数据是否应该首先从db加载:< / p>

private void Get(bool loadDataFirst) {
   if(loadDataFirst) ctx.Invoices.Load();
   Collection = ctx.Invoices.Local;
}

现在,通过使用Get方法而不首先加载数据,您的Collection仍然可以很好地绑定到Local缓存(应该为空)。向Collection添加新项目后,Local会自动添加这些项目,而Save只能调用SaveChanges

private void Save() {
   ctx.SaveChanges();
}

应该在构造函数中使用Get方法替换this.Collection = new ObservableCollection<Invoice>();,如下所示:

public InvoiceViewModel() {
   Get(false);
}