看你是要插入到最后还是中间了,最后的话有newRow方法,中间的话我所知道的只有改写数据源了,还有进行 *** 作是对gridcontrol内的GridView进行 *** 作。
1. 将NewItemRowPosition属性设置为Top或Bottom,在这样的新行中输入数据后,会自动添加到绑定的数据源中的,如果你希望在按回车时焦点跳至下一列,只需要设置GridView的OptionNavigations->EnterMoveNextColumn为True即可。
2. 当在最后一可见列按回车,数据自动在GridView中显示出来。很多时候我们真的只想单纯的手动添加一行数据,而不想修改数据源再回来绑定。如果你有这种想法。
3. 我已经两次遇到过这样的问题,尝试手动添加,整整两天时间都没有成功。网上说的方法基本都是绑定数据源,偶尔有人说用SetRowCellValue方法,用法如下:gridView1.SetRowCellValue(0, gridView1.Columns[0], "qwe")。
4. 即在0行0列的单元格设为qwe值,看起来多好,可问题是它就是不显示,更改了无数属性都无法生效,真怀疑是不是dev公司把这个方法取消了,如果哪位使用了这个方法成功的添加了数据,那么请通知我一下,万分感谢。
5. 所以如果各位初学者看到了我这篇文章就不要花时间去用上述方式添加了(当然时间多时可以试试),就我得出的结论是gridcontrol添加数据的方法只能去修改数据源。
6. gridcontrol数据源也分两种,datetable和list,datetable想要添加一行数据可以new一个新行,分别设定各列的值,再将新行add到datetable;list则new一个新的实例,设置各字段的值,再add到list即可。详细方法网上太多,不在此赘述。
具体代码如下:protected void GridView1_DataBound(object sender, EventArgs e)
{
int rowCnt = GridView1.VisibleRowCount //这个属性
int pageSize = GridView1.SettingsPager.PageSize
if (rowCnt != 0 &&rowCnt != pageSize)
{
DataTable dt = (DataTable)GridView1.DataSource
if (table != null)
{
for (int i = 0i <pageSize - rowCnti++)
{
int rowIndex = rowCnt + i + 1
DataRow row = dt.NewRow() //这个方法
for (int j = 0j <GridView1.Columns.Countj++)
{
row[j] = ""
}
dt.Rows.Add(row) //增加一行
}
}
}
GridView.DataSource=dt
GridView.DataBind()
}
可以在绑定数据前,对数据源进行 *** 作,每一行数据添加一空白行。DataTable dt=数据源;
DataTable newTable = dt.Clone()//克隆dt结构
DataRow[] filter = dt.Select("1=1")//获取dt数据行集合
//遍历添加dt数据和空数据行
foreach (DataRow dr in filter)
{
newTable.Rows.Add(dr.ItemArray)
//添加空数据行
dt.Rows.Add("","","","")//假如数据源只有四列数据
}
//绑定数据源
this.gridView1.DataSource = newTable
this.gridView1.DataBind()
欢迎分享,转载请注明来源:内存溢出
评论列表(0条)