AspxGridView 相关问题总结

以下是我目前在开发项目中使用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;
                }
            }
        }
    }



 


 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值