如何在datagrid中隐藏“userid" 字段呢?

rocker1218 2006-04-04 06:03:48
如何在datagrid中隐藏“userid" 字段呢?

DataTable tbl_user_list = new DataTable();
DataColumn col=new DataColumn();
col.DataType=System.Type.GetType("System.String");
col.ColumnName="username";
tbl_user_list.Columns.Add(col);

col=new DataColumn();
col.DataType=System.Type.GetType("System.String");
col.ColumnName="class";
tbl_veh_user.Columns.Add(col);

col=new DataColumn();
col.DataType=System.Type.GetType("System.String");
col.ColumnName="userid";
tbl_veh_user.Columns.Add(col);

//填充数据
if (veh_list != null)
{
for(int i=sindex;i<eindex;i++)
{
UserInfo auser = (UserInfo)U_list[i];
DataRow row = tbl_user_list.NewRow();
row["username"] = auser.username
row["class"] = auser.class;
row["userid"] = auser.userid;
tbl_user_list.Rows.Add(row);
}
this.dgrdVehList.CellPadding = 1;
this.dgrdVehList.CellSpacing = 1;
this.dgrdVehList.VirtualItemCount = virtualCount-1;
this.dgrdVehList.PageSize = pageSize;
this.dgrdVehList.CurrentPageIndex = pageIndex;
this.dgrdVehList.DataSource = tbl_user_list;
this.dgrdVehList.DataBind();
}

请问,我怎么能把" userid" 这列隐藏呢?
...全文
297 11 打赏 收藏 转发到动态 举报
写回复
用AI写文章
11 条回复
切换为时间正序
请发表友善的回复…
发表回复
zoxn 2006-04-05
  • 打赏
  • 举报
回复
这个问题我已经解决,有一种方法是将“userid" 字段的列width设置为0
这里有一个类似的例子,可以参考

string SQLConn="server=(local);database=StudentDB;user id=sa;password=sa";
System.Data.SqlClient.SqlConnection conn=new System.Data.SqlClient.SqlConnection(SQLConn);

string str="select * from user1";
System.Data.SqlClient.SqlCommand cmd =new System.Data.SqlClient.SqlCommand(str,conn);
conn.Open();
cmd.CommandText =str;
cmd.ExecuteNonQuery();
System.Data.SqlClient.SqlDataAdapter sqlAdapter=new SqlDataAdapter(str,conn);
System.Data.DataSet st=new DataSet() ;
sqlAdapter.Fill(st,"table1");
DataColumn datacol = new DataColumn("birthday1");
System.Data.DataTable datata=new DataTable("aaa");
datata=st.Tables["table1"];
int i=0 ;
datata.Columns.Add(datacol);
dataGrid1.DataSource =st.Tables["table1"];
for(i=0;i<=st.Tables["table1"].Rows.Count -1;i++)
{
if ((dataGrid1[i,1]).ToString() == "1905-3-14 0:00:00")

dataGrid1[i,2]=string.Empty ;
else

dataGrid1[i,2]=dataGrid1[i,1];
}

DataGridTableStyle dgts = new DataGridTableStyle();

dgts.MappingName = "table1";

dataGrid1.TableStyles.Add(dgts);

DataGridTableStyle tableStyle = dataGrid1.TableStyles["table1"];

SetColWidth(tableStyle,1,0);



public void SetColWidth(DataGridTableStyle tableStyle, int colNum, int width)
{
try
{
tableStyle.GridColumnStyles["birthday"].Width = width;
tableStyle.DataGrid.Refresh();
}
catch
{
MessageBox.Show("aaaaaaaaa");
} //empty catch .. do nothing
}


huing 2006-04-05
  • 打赏
  • 举报
回复
宽度设置==0也可以
xiaomatian 2006-04-05
  • 打赏
  • 举报
回复
列Visible=false
Knight94 2006-04-05
  • 打赏
  • 举报
回复
设置datacolumn的ColumnMapping为MappingType.Hidden即可
zhf777 2006-04-04
  • 打赏
  • 举报
回复
在设计界面中右击控件选择属性
在添加列的窗口中选中要隐藏的列
将“显示”的CheckBox中的勾取消就行了
sugarsupper 2006-04-04
  • 打赏
  • 举报
回复
databound里设置所在列为false啊
levin9 2006-04-04
  • 打赏
  • 举报
回复
Visible 置为false
gt5070073 2006-04-04
  • 打赏
  • 举报
回复
Columns.count只是1,从0开始啊,0,1不就是2个了吗?
rocker1218 2006-04-04
  • 打赏
  • 举报
回复
可是程序中,页面只有1列.本身应该有3列,结果我Columns.count只是1;所以我很奇怪这个问题。
孟子E章 2006-04-04
  • 打赏
  • 举报
回复
客户端可以用style="display:none"
服务器端可以设置相应的列的Visible=false
huangsuipeng 2006-04-04
  • 打赏
  • 举报
回复
Visible 置为false

110,567

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术 C#
社区管理员
  • C#
  • Web++
  • by_封爱
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

让您成为最强悍的C#开发者

试试用AI创作助手写篇文章吧