ASP.NET2.0中GridView控件的隐藏列的问题

翻译|其它|编辑:郝浩|2008-01-28 10:03:54.000|阅读 949 次

概述:

# 界面/图表报表/文档/IDE等千款热门软控件火热销售中 >>

  Asp.net2.0GridView隐藏列visible="false" 后你就无法取得这列的值了, 而用datagrid就没有这个问题, MS这个混蛋老是改变游戏规则, 幸好我聪明, 在百度上搜到了别人的解决方法, 然后加入了自己的方法, 才解决问题:

以下是引用片段:
  protectedvoidGVList_RowDataBound(objectsender,GridViewRowEventArgse)
  {
  //隐藏不必要的列
  if((e.Row.RowType==DataControlRowType.DataRow)||(e.Row.RowType==DataControlRowType.Header)||(e.Row.RowType==DataControlRowType.Footer))
  {
  e.Row.Cells[0].Visible=false;
  e.Row.Cells[3].Visible=false;
  }
  }

  这是迄今为止最简洁的解决方法了。

  解决方案

  在RowCreated事件中书写如下代码:

以下是引用片段:
  voidGridView1_RowCreated(objectsender,GridViewRowEventArgse)
  {
  if(e.Row.RowType==DataControlRowType.DataRow||
  e.Row.RowType==DataControlRowType.Header)
  {
  e.Row.Cells[0].Visible=false;//如果想使第1列不可见,则将它的可见性设为false
  }
  //可以根据需要设置更多的列
  }

  因为在RowCreated事件(隐藏)在绑定时候发生,所以这样就即能将数据绑定到列上,又隐藏了该列.所以可以访问到隐藏列的值。

  下面介绍另外一个可以将数据绑定到GridView控件的方法:

以下是引用片段:
PublicvoidmyTestFunction()
  {
  stringconString="....";//省略
  stringsqlquery="...";//省略
  SqlConnectioncon=newSqlConnection(conString);
  SqlDataAdapterda=newSqlDataAdapter(sqlquery,con);
  DataSetds=newDataSet();
  da.Fill(ds);
  ds.Tables[0].Columns[0].ColumnMapping=MappingType.Hidden;
  GridView1.DataSouce=ds.Tables[0];
  GridView1.DataBind();
  }

  文章主要讲述了ASP.NET2.0中GridView控件的隐藏列的问题.


标签:

本站文章除注明转载外,均为本站原创或翻译。欢迎任何形式的转载,但请务必注明出处、不得修改原文相关链接,如果存在内容上的异议请邮件反馈至chenjj@evget.com

文章转载自:豆豆网

为你推荐

  • 推荐视频
  • 推荐活动
  • 推荐产品
  • 推荐文章
  • 慧都慧问
扫码咨询


添加微信 立即咨询

电话咨询

客服热线
023-68661681

TOP