关于ASPxGridView动态添加列的问题

liladlove 2014-02-11 10:40:53
刚接触这个控件,还不能熟练运用。
我现在的问题是列名是从数据库动态读取的DataColumns 字段有ColumnName
数据源DataTable的列名是DataColumns的ColumnName。

所以我需要遍历DataColumns,把ColumnName动态添加到ASPxGridView的列里。
具体如何操作,我尝试了没有成功
请有经验的高手来帮我一下,最好能贴出代码,谢谢!
...全文
408 9 打赏 收藏 转发到动态 举报
写回复
用AI写文章
9 条回复
切换为时间正序
请发表友善的回复…
发表回复
cy2889792 2014-02-12
  • 打赏
  • 举报
回复
你直接指定DataGridView的Datasource=DataTable 不就行了,然后AutoGenerateColumn(自动生成列)设为True,这样DataGridView里的列就和DataTable 里面的列一样了
Dotar 2014-02-12
  • 打赏
  • 举报
回复
引用 8 楼 kxm_2012 的回复:
这样就可以动态设置GridView列了
次图截得好
魂之挽歌来袭 2014-02-12
  • 打赏
  • 举报
回复

这样就可以动态设置GridView列了
likevs 2014-02-12
  • 打赏
  • 举报
回复
我记得有一位前辈,他的博客里有两篇文章是关于楼主这种需求的详细讲解,并附加多个例子。 请楼主百度一下 猛子E章 看到他的CSDN博客网址,你自己就可以进去查找到这几篇文章了
liladlove 2014-02-11
  • 打赏
  • 举报
回复
引用 1 楼 a01589 的回复:
你的意思是把数据库读出来的列名作为控件中每一列的列名吗?没有太好的办法,试试用foreach动态添加属性,也就是给每个列在后台赋上列名那个属性
我知道思路,但是后台循环的时候不知道怎么给ASPxGirdView添加列
  • 打赏
  • 举报
回复
你的意思是把数据库读出来的列名作为控件中每一列的列名吗?没有太好的办法,试试用foreach动态添加属性,也就是给每个列在后台赋上列名那个属性
liladlove 2014-02-11
  • 打赏
  • 举报
回复
csdn里这么多大神呢,快点来个大神教教我吧!
火拼阿三 2014-02-11
  • 打赏
  • 举报
回复
可以动态创建一个DataTable,最后在绑定这个DataTable就可以了
ASP.NET实现Gridview隐藏/显示源码 介绍: 这篇文章演示如果让用户有显示/隐藏他们需要的GridView的的功能,这是非常有用的,因为在GridView的所有并不是每个的用户都需要的.用户想根据自己的需求看到想要的.而不是显示一个巨大的gridview,霸占了整个屏幕,而是一个整洁的Gridview,而且它有所有你需要的.对于页面的打印这也是一个非常有用的技术,因为用户可以灵活地选择GridView的打印。 背景: RowCreated 和ItemDataBound 事件允许你用多种方式注入HTML, CSS,和JavaScript 来增强GridView 控件的功能。 文章将会演示两种显示和隐藏GridView的方法,一种是客户端的方法,另外一种是服务段的方法. 在客户段显示和隐藏GridView的 大部分代码是在GridView的RowCreated事件生成客户端的功能的。当GridView的Header行被创建后,一个带负号的HyperLink被插入每个Header行的单元格中用来隐藏。 这个hyperlink通过它的onclick事件调用一个HideCol的Javascript方法,CSS类用来增加负号的大小,当每个数据行被创建的时候,一个Id将会被添加到每行中用来让Javascript区分每一行. 代码 protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e) { GridView gridView = (GridView)sender; StringBuilder sb = new StringBuilder(); // For the header row add a link to each header // cell which can call the HideCol javascript method if (e.Row.RowType == DataControlRowType.Header) { // Loop through each cell of the row for (int columnIndex = 0; columnIndex 0) { Label columnTextLabel = new Label(); columnTextLabel.Text = e.Row.Cells[columnIndex].Text; e.Row.Cells[columnIndex].Controls.Add(columnTextLabel); } } } // Give each row an id if (e.Row.RowType == DataControlRowType.Pager) e.Row.Attributes.Add("id", gridView.ClientID + "_pager"); else e.Row.Attributes.Add("id", gridView.ClientID + "_r" + e.Row.RowIndex.ToString()); } SetupShowHideColumns方法中生成“Show Columns”下拉菜单的HTML,输出在Literal控件上面 。 代码 private void SetupShowHideColumns(GridView gridView, Literal showHideColumnsLiteral) { StringBuilder sb = new StringBuilder(); sb.Append(""); sb.Append(""); sb.Append("- Show Column -"); showHideColumnsLiteral.Text = sb.ToString(); } 在数据绑定到GridView之后,其余的工作由ShowHideColumns.js中的javascript来完成.当头的hyperlink被点击的时候后,它将会传递GridView的名字,的索引和名给HideCol方法,这个方法能找到这一的每个单元格,每个单元格的将添加display:none样式,用来隐藏这一. 当选择"Show Column"中的选项后,Javascript方法ShowCol将会被调用,它将移除每个单元格的display:none样式,这一将会被再次显示. 在服务端显示/隐藏GridView的 服务端的例子将通过RowCreated事件给每个添加一个负号,这次是使用LinkButton控件.设置CommandName和CommandArgument属性,这样当通过LinkButton引发RowCommand事件时,相关的都可以隐藏。以前隐藏的索引存储在一个List中,这些在建立时,将会被隐藏的。 代码 protected void GridView1_RowCreated(object sender, GridViewRowEventArgs e) { // For the header row add a link button to each header // cell which can execute a row command if (e.Row.RowType == DataControlRowType.Header) { // Loop through each cell of the header row for (int columnIndex = 0; columnIndex 0) { Label columnTextLabel = new Label(); columnTextLabel.Text = e.Row.Cells[columnIndex].Text; e.Row.Cells[columnIndex].Controls.Add(columnTextLabel); } } } // Hide the column indexes which have been stored in hiddenColumnIndexes foreach(int columnIndex in hiddenColumnIndexes) if (columnIndex 0) { this.GridView1ShowHideColumns.Visible = true; this.GridView1ShowHideColumns.Items.Add(new ListItem("-Show Column-", "-1")); foreach (int i in hiddenColumnIndexes) this.GridView1ShowHideColumns.Items.Add( new ListItem(columnNames[i], i.ToString())); } else { this.GridView1ShowHideColumns.Visible = false; } } 示例项目的例子: 客户端的例子: •C#.NET - Client-side example accessing data stored in session. •C#.NET - Client-side example which includes: MasterPage, UpdatePanel, GridView editing, paging and sorting, accessing data via the SqlDataSource control. •VB.NET - Client-side example accessing data stored in session. 服务端的例子 •C#.NET - Server-side example accessing data stored in session. •C#.NET - Server-side example which includes: MasterPage, UpdatePanel, GridView editing, paging and sorting, accessing data via the SqlDataSource control. •VB.NET - Server-side example accessing data stored in session. 结论: 如果你想让你的用户能够显示和隐藏在ASP.NET GridView的,那么这种技术可能是非常有用的。 原文:http://www.codeproject.com/KB/webforms/ShowHideGridviewColumns.aspx 作者:朱祁林 出处:http://zhuqil.cnblogs.com/ 本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接,否则保留追究法律责任的权利。

62,074

社区成员

发帖
与我相关
我的任务
社区描述
.NET技术交流专区
javascript云原生 企业社区
社区管理员
  • ASP.NET
  • .Net开发者社区
  • R小R
加入社区
  • 近7日
  • 近30日
  • 至今
社区公告

.NET 社区是一个围绕开源 .NET 的开放、热情、创新、包容的技术社区。社区致力于为广大 .NET 爱好者提供一个良好的知识共享、协同互助的 .NET 技术交流环境。我们尊重不同意见,支持健康理性的辩论和互动,反对歧视和攻击。

希望和大家一起共同营造一个活跃、友好的社区氛围。

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