带有实体的数据网格求和单元格



我在WPF和实体框架中显示dataGrid,第2列有单位价格,第3列有数量(第4列有折扣),我希望第5列将是摘要。我的问题是如何捕获第三列并计算对总列

的更改

下面是代码如何显示数据

          <DataGrid.Columns>
            <DataGridComboBoxColumn x:Name="ddd"  Header="Expenses" Width="*" SelectedValueBinding="{Binding Path=ExpensesId}" DisplayMemberPath="ExpensesName" SelectedValuePath="ExpensesTypeId"/>
            <DataGridTextColumn Header="price" Width="*" Binding="{Binding Path=Expenses.PricePorEach}"/>
            <DataGridTextColumn Header="quantity" Width="50"  Binding="{Binding Path=Quantity}"/>
            <DataGridTextColumn Header="discount" Width="*" Binding="{Binding Path=Discount}"/>
            <DataGridTextColumn Header="Total" Width="*" Binding="{Binding Path=Total}"/>
        </DataGrid.Columns>
    </DataGrid>
      ContractorEntities ce = new ContractorEntities();
    public MainWindow()
    {
        InitializeComponent();
        BindData();
    }
    private void BindData()
    {
        var dataSource = new  ObservableCollection<Jobs>(ce.Jobs);
        dataSource.CollectionChanged += CollectionChanged;
        dg.ItemsSource = dataSource;
        dg.DataContext = dataSource;
    }
    private void CollectionChanged(object sender,  NotifyCollectionChangedEventArgs e)
    {
        if (e.Action == NotifyCollectionChangedAction.Add)
            foreach (Jobs job in e.NewItems)
                  ce.Jobs.Add(job);
        else if (e.Action == NotifyCollectionChangedAction.Remove)
            foreach (Jobs jobin e.OldItems)
                ce.Jobs.Remove(job);
    }
    private void saveButton_Click(object sender, RoutedEventArgs e)
    {
        ce.SaveChanges();
    }
    [NotMapped]
    public decimal? Total
    {
        get
        {
            return (Price * Quantity) - Discount;
        }
        set { }
    }
    public void OnDiscountChanged()
    {
        base.OnPropertyChanged("Total");//This line is not known
    }
    public void OnPriceChanged()
    {
        base.OnPropertyChanged("Total");//This line is not known
    }
    public void OnQuantityChanged()
    {
        base.OnPropertyChanged("Total");//This line is not known
    }
}

我尝试了几种方法,但没有结果

提前感谢您的帮助

如果您使用CodeFirst创建实体

由于您正在使用实体,您可以在实体类中创建一个未映射的(使用[NotMapped]属性)属性,该属性计算值并将列绑定到该属性。由于实体类在默认情况下实现了INotifyPropertyChanged,所以一切都应该执行,而不需要更多的工作,尽管您可能需要在其他三个(Price, Quantity, Discount)上调用PropertyChangedEventHandler来告诉UI更新Total的值。

[NotMapped]
public int Total
{
    get
    {
        return (Price * Quantity) - Discount;
    {
}

由于您不打算在代码中设置Total,因此该属性为ReadOnly。

如果您使用EDMX和设计器来创建实体

由于使用的是EDMX(通过设计器),因此需要通过分部类添加属性。

  1. 创建一个与你想要修改的实体同名的新类(我认为在这种情况下是Job)。
  2. 将类声明标记为partial。在这种情况下,您现在可以将方法添加到生成的类中。
  3. 添加上述Total属性(根据需要编辑公式)。
  4. 你可能必须重写PriceChanged, QuantityChanged和DiscountChanged方法,并添加一个属性更改事件处理程序调用,指定总属性(例如base.OnPropertyChanged("Total");),以便UI知道更新。

    public partial class Job
    {
        public void OnDiscountChanged()
        {
            base.OnPropertyChanged("Total");
        }
        public void OnPriceChanged()
        {
            base.OnPropertyChanged("Total");
        }
        public void OnQuantityChanged()
        {
            base.OnPropertyChanged("Total");
        }
    }
    
<标题> 更新我得到了你的答案,看了看。实体是通过T4模板生成的。我在这些方面没有太多经验,但在大多数情况下,"如果您使用EDMX和设计器来创建实体"一节中的答案仍然适用。您需要修改T4模板以实现属性更改通知,就像您可以访问属性更改方法一样,并将Total属性(不带NotMapped属性)放在您的部分类中。这里提供的答案看起来是相关的和正确的(基于我对这个主题的了解)。

最新更新