DataGridView列页脚c#.net winforms

有没有办法在datagridview添加一个不是数据绑定的列页脚? 我正在使用它来获取用户输入以添加库存。 目前我正在使用标签来显示总数,但我希望尽可能将其更改为页脚。

我之前遇到了同样的问题,经过长时间的搜索,我意识到了;

  1. Winform Datagridview不支持向其添加页脚。

  2. 我尝试添加一个额外的行,可以保存摘要,但仍然无法正常工作。

  3. 您可以创建一个具有两个网格的用户控件,并使用包含摘要的下部网格。

解 – 在此处输入图像描述

  1. 我使用数据绑定的解决方案。(1)-I用(Name,Cost)属性创建一个抽象对象Item 。(2)-I创建一个Concrete项,即inheritanceItem (3)的ConcItem -I创建一个页脚项,即FooterItem还inheritanceItem (4) – Item的集合,即ItemList,你实例化页脚项。(5)最后,在你进行数据绑定之前,调用添加页脚项的方法。

     public abstract class Item { public virtual string Name { get; set; } public virtual int Cost { get; set; } } public class ConcItem:Item { public override string Name { get; set; } public override int Cost { get; set; } } public class FooterItem:Item { public override string Name { get { return "Total"; } } public override int Cost { get; set; } } public class ItemList : List { private Item _footer; public void SetFooter() { _footer = new FooterItem(); foreach (var item in this) { _footer.Cost += item.Cost; } this.Add(_footer); } } public partial class Form1 : Form { Item _item; ItemList _itemList; public Form1() { InitializeComponent(); dgv.DataBindingComplete += dgv_DataBindingComplete; _itemList = new ItemList(); SetSampleData(); } private void SetSampleData() { _item = new ConcItem(); _item.Name = "Book"; _item.Cost = 250; _itemList.Add(_item); _item = new ConcItem(); _item.Name = "Table"; _item.Cost = 500; _itemList.Add(_item); _item = new ConcItem(); _item.Name = "PC"; _item.Cost = 700; _itemList.Add(_item); dgv.DataSource = null; _itemList.SetFooter(); //Add the footer item b4 data binding dgv.DataSource = _itemList; } void dgv_DataBindingComplete(object sender, DataGridViewBindingCompleteEventArgs e) { //If you want to do some formating on the footer row int rowIndex = dgv.Rows.GetLastRow(DataGridViewElementStates.Visible); if (rowIndex <= 0) { return; } dgv.Rows[rowIndex].DefaultCellStyle.BackColor = Color.Red; dgv.Rows[rowIndex].DefaultCellStyle.SelectionBackColor = Color.Red; dgv.Rows[rowIndex].DefaultCellStyle.Font = new Font("Microsoft Sans Serif", 12f, FontStyle.Bold); } } 

在我的一个应用程序中,我通过利用DataRridView的NewRow来解决它。

 using System; using System.Drawing; using System.Windows.Forms; namespace WindowsFormsApplication2 { public partial class Form1 : Form { public Form1() { InitializeComponent(); this.dataGridView1.CellFormatting += dataGridView1_CellFormatting; this.dataGridView1.CellValueChanged += dataGridView1_CellValueChanged; } void dataGridView1_CellValueChanged(object sender, DataGridViewCellEventArgs e) { if (e.RowIndex != this.dataGridView1.NewRowIndex && e.ColumnIndex == 2) { this.dataGridView1.InvalidateRow(this.dataGridView1.NewRowIndex); } } void dataGridView1_CellFormatting(object sender, DataGridViewCellFormattingEventArgs e) { if (e.RowIndex == this.dataGridView1.NewRowIndex) { e.CellStyle.Font = new Font(e.CellStyle.Font, FontStyle.Bold); e.CellStyle.ForeColor = Color.Red; switch (e.ColumnIndex) { case 0: e.Value = "Total"; break; case 2: var sum = 0.0d; for (int i = 0; i < this.dataGridView1.NewRowIndex; i++) { var value = this.dataGridView1[2, i].Value; if (value is double) { sum += ((double)value); } } e.Value = Math.Round(sum, 2); break; } } } } } 

这是它如何工作的实时截图。

在此处输入图像描述