在winform开发中,一般对数据都是动态从数据库绑定,然后再datagridview中进行显示,当然这种方式比较简单高效,但带来的数据显示的不灵活,无法动态添加行和列。
我们在最近的项目开发中都遇到了这样的情况,自己写了大致的算法思路,算法思路比较简单就是再数据显示时不是数据绑定而是一列一行的添加数据然后再进行数据显示。这样较好的处理了这个问题。废话少说上代码:
datagridview1.Rows.Clear();
datagridview1.AllowUserToAddRows = false;
datagridview1.AutoGenerateColumns = false;
datagridview1.ColumnHeadersDefaultCellStyle.Alignment = DataGridViewContentAlignment.MiddleCenter;
List<dataModel> dataList =new List<dataModel>;
初始化 datalist
int i = 0;
foreach ( datamodel item in dataList)
{
this.dgvTapeOut.Rows.Add();
dgvTapeOut.Rows[i].Cells[i].Value = item.id;
dgvTapeOut.Rows[i].Cells[i+1].Value = item.name;
dgvTapeOut.Rows[i].Cells[i+2].Value = item.address;
dgvTapeOut.Rows[i].Cells[i+3].Value = item.phone;
i++;
}
这样就可以动态自己灵活的添加数据了
接下来就可以实现再现有的数据基础上前插后插入数据。原理很简单就是如果在当前行插入数据,实际上是把插入最后一行然后数据依次后移,即可实现;同理列的添加删除同样采用类似的原理即可实现。