现在的位置: 首页 > 综合 > 正文

GridView全攻略

2013年08月02日 ⁄ 综合 ⁄ 共 3533字 ⁄ 字号 评论关闭

作者: zyf0808 发表日期: 2006-09-21 21:47

    小文将通过实例对 2.0 下的数据控件GridView进行一个完整的应用描述,涉及基本数据绑定,高级数据绑定,自定义模板设计,分页状态保持等等。本文根据项目实例,代码已经经过详细测试,蕴涵了作者的辛苦劳动,欢迎转载,请注明出处。

1、基本绑定,方式和DataGrid没什么区别。简单附代码如下:

 String strSQL = "SELECT * FROM ....";
        WorksData workData 
= new WorkSystem().LoadWork(strSQL);
        gvWorks.DataSource 
= workData;
        gvWorks.DataBind();

2、通过模板列来增加“编辑 删除”命令的连接,并在单击“删除”时给出确认提示,这是数据操作中经常使用的方式。将列转化为模板列后,通过右键单击GridView控件,选择“编辑模板”,然后选择相应的命令列,去掉默认的TextBox,然后添加两个LinkButton,Text属性分别为:"编辑"和"删除",ID分别为lbEdit和lbDelete。模板列

 

a.为删除按钮添加确认对话框:

 foreach (GridViewRow gvr in gvWorks.Rows)
        
{
            LinkButton lbDelete
= (LinkButton)gvr.FindControl("lbDelete");
            
if (lbDelete!= null)
            
{
               lbDelete.Attributes.Add(
"onclick""javascript:return confirm('是否确定要删除?');");
            }

        }

b.为两个命令按钮绑定参数:(以下代码是通过右键在lbEdit的可绑定参数中将CommandArgument的值绑定为Container.DataItemIndex的方式,需要注意的是,如果分页,需要做一个处理,即代码中- gvWorks.PageSize * gvWorks.PageIndex,以得到处于该页的正确的索引,然后通过DataKeys[commandArg].Value来得到ID值;当然,也可以直接将该属性绑定为你的ID,这样,更易于理解和操作,也不必处理分页的索引问题)编辑模板

 

 
 
//编辑
     protected void lbEdit_Click(object sender, EventArgs e)
     
{
         LinkButton lb 
= (LinkButton)sender;
         
int commandArg = int.Parse(lb.CommandArgument) - gvWorks.PageSize * gvWorks.PageIndex;
         
int id = (int)this.gvWorks.DataKeys[commandArg].Value;
         Response.Redirect(
"EditWork.aspx?workid=" + id);
     }
 

同理,删除按钮也可以采用两种方式的处理。
3、如何保持分页的状态:如果你需要在一个GridView中加一个CheckBox,以选择某行数据,然后进入下一页继续选择,而返回上一页时仍旧能够显示你已经选择了的数据行,那么,这里将提供一种方式给你。因为分页时,页面发生变化时,是要postback回服务器的,这样,虽然你做了选择,但是未更新到服务器,所以,不做处理的话是保存不住已经选择的项的。
    思路:通过一个ArrayList来保持你已经选择的项的ID,当页索引变化时,将触发DataBinding事件,在该事件内调用CollectSelected()方法,来保存所有CheckBox选中的行,去掉那些未选中的行ID。在RowDataBound(),通过SelectedItems中保存的ID来设置是否选中,以回显你的操作。需要注意的是,在你提交的时候,一定要再调用一次CollectSelected(),以最后一次收集当前页的选中情况。
以下代码参考了部分网络资源,特此表示感谢。

     protected ArrayList SelectedItems
     
{
        
get
        
{
            
return (ViewState["mySelectedItems"!= null? (ArrayList)ViewState["mySelectedItems"] : null;
        }

        
set
        
{
            ViewState[
"mySelectedItems"= value;
        }

    }


    
/// <summary>
    
/// 从当前页收集选中项的情况
    
/// </summary>

    protected void CollectSelected()
    
{
        ArrayList selectedItems 
= null;
        
if (this.SelectedItems == null)
            selectedItems 
= new ArrayList();
        
else
            selectedItems 
= this.SelectedItems;

        
for (int i = 0; i < this.gvWorks.Rows.Count; i++)
        
{
            CheckBox cb 
= (CheckBox)gvWorks.Rows.FindControl("cbChoose");
            
string id = ((Label)gvWorks.Rows.FindControl("lbID")).Text;
            
if (selectedItems.Contains(id) && !cb.Checked)
                selectedItems.Remove(id);
            
if (!selectedItems.Contains(id) && cb.Checked)
               selectedItems.Add(id);
       }

       SelectedItems 
= selectedItems;
    }


 

    
protected void gvWorks_DataBinding(object sender, EventArgs e)
    
{
       
//在每一次重新绑定之前,需要调用CollectSelected方法从当前页收集选中项的情况
       CollectSelected();
    }

    
protected void gvWorks_RowDataBound(object sender, GridViewRowEventArgs e)
    
{
        
//这里的处理是为了回显之前选中的情况
       if (e.Row.RowIndex > -1 && SelectedItems!=null)
        
{
            DataRowView row 
= e.Row.DataItem as DataRowView;
            CheckBox cb 
= (CheckBox)e.Row.FindControl("cbChoose");
            Label lbID 
= (Label)e.Row.FindControl("lbID");
            
if(SelectedItems.Contains(lbID.Text))
                cb.Checked 
= true;
            
else
                cb.Checked 
= false;
        }

    }


 
 

【上篇】
【下篇】

抱歉!评论已关闭.