我在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(通过设计器),因此需要通过分部类添加属性。
- 创建一个与你想要修改的实体同名的新类(我认为在这种情况下是Job)。
- 将类声明标记为partial。在这种情况下,您现在可以将方法添加到生成的类中。
- 添加上述Total属性(根据需要编辑公式)。
你可能必须重写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"); } }