以下是我目前在开发项目中使用AspxGridView中遇到的问题,现总结如下:
1.分页问题
在利用AspxGridVIew动态绑定数据时,需要利用onpageindexchanged事件来重新绑定数据源,代码如下
protected void searchbtn_Click(object sender, EventArgs e)
{
DataBindSearch();
}
2. 快速查询方法设置问题
在控件中将<settings>中的ShowFilterRow设置为true,并且需要再后台的page_load中重新绑定数据,且该绑定数据不能在isPostBack中
3.数据导出
在ASPxGridView中,直接利用代码来导出数据,虽然可行,但导出的数据会连带ASPxGridView的图片一起导出,且导出表单需要做后续处理。同时也可能会遇到中文乱码的情况,所以这里推荐使用ASPxGridviewExporter导出控件,使用起来也比较方便:只需要在前台页面中引用ASPxGridviewExporter控件,并添加GridViewID,在后台的导出按钮事件中执行
exportBtn.WriteXlsToResponse();
即可,这里需要注意的是在执行以上代码时需对列表进行数据绑定,否则将没有数据导出
4.AspxGridView优化日期格式显示
在ASPxGridView中,默认是以5/1/1992显示的,如需要设定其它数据显示格式,可以做如下操作:
<dx:GridViewDataTextColumn Caption="创建时间" FieldName="whendo" VisibleIndex="5" Width="15%">
<CellStyle HorizontalAlign="Center" />
<Settings AllowAutoFilter="False" />
<HeaderStyle HorizontalAlign="Center" />
<PropertiesTextEdit DisplayFormatString="{0:yyyy-MM-dd}">
</PropertiesTextEdit>
</dx:GridViewDataTextColumn>
5.在GridView里加入checkbox,解决分页保存checkbox问题
//用session保存checkbox勾选的内容
private void RememberOldValues()
{
ArrayList NewIDList = new ArrayList();
string index = "-1";
foreach (GridViewRow row in publist.Rows)
{
index = (string)publist.DataKeys[row.RowIndex].Value;
bool result = (row.FindControl("CheckBox1") as CheckBox).Checked;
string id = (row.FindControl("CheckBox1") as CheckBox).Text;
if (Session["Checked_Item"] != null)
{
NewIDList = (ArrayList)Session["Checked_Item"];
}
if (result)
{
if (!NewIDList.Contains(id))
{
NewIDList.Add(id);
}
}
else
{
NewIDList.Remove(id);
}
if (NewIDList != null && NewIDList.Count > 0)
{
Session["Checked_Item"] = NewIDList;
}
}
}
//翻页后重新保存之前页面的选项状态
private void RePopularValues()
{
ArrayList NewIDList = (ArrayList)Session["Checked_Item"];
if (NewIDList != null && NewIDList.Count > 0)
{
foreach (GridViewRow row in publist.Rows)
{
string index = (string)publist.DataKeys[row.RowIndex].Value;
if (NewIDList.Contains(index))
{
CheckBox cb = row.FindControl("CheckBox1") as CheckBox;
cb.Checked = true;
}
}
}
}