GridView控件常见问题及处理方法===1. 关于隐藏字段的处理:==2. 关于按钮列的事件:==3. 关于按钮的客户端提示:==4. 关于时间字段的格式化输出:==5. 关于绑定空记录:

Asp.net  1 .1版本中的DataGrid控件用于显示表格式的数据,相信大家都用过。Asp.net  2 .0版本中GridView控件是DataGrid控件的继承者,功能比DataGrid增强不少,但是也有很多地方不同。下面把使用中发现的不同点列举如下,希望能对大家的工作有所帮助:

 

1 .     关于隐藏字段的处理:

DataGrid中我们一般把不需要显示又需要在编程中使用的字段在设计期设置为Visible
= False,这样的字段不会显示出来,但在绑定数据时会被绑定值,所以我们可以通过DataGridItem.Cell[x].Text取到所需数据行的数据。

GridView中直接在设计期设置Visible
= False 却不能满足上述需求,因为这样设置,虽然字段不会被显示出来了,但数据也没有被绑定到相应的Cell中,通过GridViewRow.Cell[x]. Text取到的全是空字符串,估计应该是控件的Bug。如果想达到上述的效果,可以通过其它方法实现,只是麻烦一些:

首先,不要设置字段的Visible
= False

然后处理RowDataBound事件。

protected   void  GridView1_RowDataBound( object  sender, GridViewRowEventArgs e)
{
   e.Row.Cells[x].Visible 
= false;
}


 

2 .     关于按钮列的事件:

在DataGrid 中,要响应控钮列中的按钮点击事件,可以处理ItemCommand事件:事件的第一个参数source是object类型的,值为DataGrid,第二个参数e是DataGridCommandEventArgs类型的,e中包含四个属性:Item的值为按钮所在的行,CommandSource的值为所点击的按钮,CommandName的值为按钮在设计期定义的值,CommandArgument的值固定为空字符串。在使用中,可以根据Item来区分点击的是哪个行中的按钮,可以根据CommandName来区分一个行中的多个按钮。

private   void  DataGrid1_ItemCommand( object  source, DataGridCommandEventArgs e)
{
   ...
}


在GridView 中,要响应控钮列中的按钮点击事件,可以处理RowCommand事件:事件的第一个参数sender是object类型的,值为GridView,第二个参数e是GridViewCommandEventArgs类型的,e中仅包含三个属性,比DataGrid控件中的相应事件少了关键的Item属性, CommandSource的值也与DataGrid中的不一样,在这里为GridView,CommandName的值为按钮在设计期定义的值, CommandArgument的值为被点击的按钮所在行的索引。在使用中,可以根据CommandArgument来区分点击的是哪个行中的按钮,可以根据CommandName来区分一个行中的多个按钮。

    
protected   void  GridView1_RowCommand( object  sender, GridViewCommandEventArgs e)

    
{

        GridViewRow item 
= this.GridView1.Rows[Convert.ToInt32(e.CommandArgument)];

    }


 

3 .     关于按钮的客户端提示:

一般情况下,我们希望在最终删除一条数据之前让用户进行确认,这个可以使用模板列,在模板列中放置按钮控件,为按钮设置客户端单击事件。

在Asp.net 
1 .1中,需要使用编程方法才能为按钮指定客户端单击事件,方法如下:

< asp:TemplateColumn >

     
< ItemTemplate >

         
< asp:LinkButton id = " LinkButton1 "  runat = " server "  CausesValidation = " false "  CommandName = " Test "  Text = " Button " ></ asp:LinkButton >

     
</ ItemTemplate >

</ asp:TemplateColumn >

private   void  DataGrid1_ItemCreated( object  sender, DataGridItemEventArgs e)

{

     LinkButton btn 
= e.Item.FindControl("LinkButton1"as LinkButton;

     
if(btn != null)

     
{

         btn.Attributes.Add(
"onclick","return confirm('你确认要删除这条数据吗?');");

     }


}


在Asp.net 
2 .0中,方便了许多,可以在设计期设置OnClientClick属性来为按钮指定客户端单击事件,方法如下:

< asp:TemplateField ShowHeader = " False " >

    
< ItemTemplate >

        
< asp:LinkButton ID = " LinkButton1 "  runat = " server "  CausesValidation = " false "  CommandName = " Test "  Text = " 按钮 "  OnClientClick = " return confirm('你确认要删除这条数据吗?'); " ></ asp:LinkButton >

    
</ ItemTemplate >

</ asp:TemplateField >

 

4 .     关于时间字段的格式化输出:

假如我们有一个时间字段,数据为
" 2005-12-23 10:01:20 " ,想显示为 " 10:01 "

在DataGrid中,我们可以简单的设置字段的显示格式即可,如:

< asp:BoundField DataField = " datetime "  DataFormatString = " {0:HH:mm} "   />  

在GridView中,相同的方法,却显示错误,仍显示为
" 2005-12-23 10:01:20 " ,估计是控件的Bug(呵呵,Bug还真不少,微软这样的公司发布的东西也这么多Bug。可见...),不过,可以使用模板列解决此问题,方法如下:

< asp:TemplateField HeaderText = " 时间 " >

    
< ItemTemplate >

        
< asp:Label ID = " Label1 "  runat = " server "  Text = ' <%# Bind("datetime", "{0:HH:mm}") %> ' ></ asp:Label >

    
</ ItemTemplate >

</ asp:TemplateField >

 

5 .     关于绑定空记录:

在DataGrid中,我们可以把一个包含空记录的DataSet或DataTable绑定给DataGrid,这样,呈现时,DataGrid会把数据源中的字段定义以表头的形式显示出来。

在GridView控件中,却不可以,如果DataSet或DataTable是空记录。则GridView连表头都不显示。只能通过变通的方法实现,稍微有一些麻烦:

    
public   void  BuildNoRecords(GridView gridView, DataSet ds)

    
{

        
if (ds.Tables[0].Rows.Count == 0)

        
{

            ds.Tables[
0].Rows.Add(ds.Tables[0].NewRow());

            gridView.DataSource 
= ds;

            gridView.DataBind();

            
int columnCount = gridView.Rows[0].Cells.Count;

            gridView.Rows[
0].Cells.Clear();

            gridView.Rows[
0].Cells.Add(new TableCell());

            gridView.Rows[
0].Cells[0].ColumnSpan = columnCount;

            gridView.Rows[
0].Cells[0].Text = "No Records Found.";

        }


        
else

        
{

            gridView.DataSource 
= ds;

            gridView.DataBind();

        }


    }


6 .     关于数据绑定,GridView使用新的数据绑定模式,请参考其它文献。
 
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值