我的一亩三分地 我就喜欢!
13fen  设为主页
 收藏本站
 
当前位置: > 一亩三分地:首页 > 网络学院 > 网络编程 > net专区 > 如何利用DataGrid纵向显示数据?
热门文章排行
热门文章排行 ASP.NET中上传下载文件(11-23)
灵活正确的实现.NET插件机制(11-21)
教你用Asp.NET生成静态页(11-21)
分享:C#技术内幕学习笔记(11-21)
浅析VB.NET文件操作类System.IO(11-21)
精采文章排行
精采文章排行 ASP.NET与MySQL数据库简明图示入门教(11-16)
ASP.NET与MySQL数据库简明图示入门教(11-16)
ASP.NET 链接数据库基础(11-16)
webconfig的设置节点说明(11-16)
部署ASP.NET的三大技术(上)(11-16)
技术专题推荐
网管论坛交流
 

如何利用DataGrid纵向显示数据? 

作者:   来源:   点击:   日期:2006-11-16

有的时候想实现类似下图,第二个图示的效果:
 

我们可能首先会想到DataList,其实DataList我们这里设置:

<asp:DataList id="DataList1" runat="server" RepeatColumns="10">
                
<ItemTemplate>
                    
<%# DataBinder.Eval(Container.DataItem,"test"%>
                
</ItemTemplate>
        
</asp:DataList>

这样显示出来的是上图的效果,并不能得到预期的纵向显示一定行的效果。
其实遇到这样的情况可以对数据源做一下转换。
比如我们建立这样的测试数据源:

 

DataTable dt=new DataTable();
            DataColumn dc
=new DataColumn("test",Type.GetType("System.String"));
            dt.Columns.Add(dc);
            
for(int i=1;i<=54;i++)
            
{
                DataRow dr
=dt.NewRow();
                dr[
"test"]="测试"+i;
                dt.Rows.Add(dr);
            }


数据表中有54行数据,我们希望它一列显示8行,也就是分7列显示,达到上图的效果,写一个方法进行转换。

private DataTable MakeData(DataTable dt,int iSize,int iColumnID)
        
{
            
int itmp=dt.Rows.Count%iSize;
            
int iColumn;
            
if(itmp==0)
                iColumn
=dt.Rows.Count/iSize;
            
else
                iColumn
=dt.Rows.Count/iSize+1;
            DataTable newdt
=new DataTable();
            
for(int i=0;i<iColumn;i++)
            
{
                DataColumn dc
=new DataColumn(dt.Columns[iColumnID].ColumnName+i,dt.Columns[iColumnID].DataType);
                newdt.Columns.Add(dc);
            }

            
for(int i=0;i<iSize;i++)
            
{        
                DataRow dr
=newdt.NewRow();
                
for(int j=0;j<iColumn;j++)
                
{
                    
if((i+j*iSize)<dt.Rows.Count)dr[dt.Columns[iColumnID].ColumnName+j]=dt.Rows[i+j*iSize][iColumnID];
                }

                newdt.Rows.Add(dr);                
            }

            
return newdt;
        }


然后绑定即可:

this.DataGrid1.DataSource=MakeData(dt,8,0);
            
this.DataGrid1.DataBind();


在这里仅仅说明一下这个方法三个参数的含义:
第一个参数传递一个原来的数据表进去
第二个参数表示希望这一列显示多少行
第三个参数表示这个字段是数据表的第几列的字段,这里的数据表只有1列,所以写0



文章评论】 【收藏本文】 【推荐好友】 【打印本文】 【论坛讨论

   相关文章:
·ADO.NET2.0的十大新特性 ·细细品味ASP.NET(2)
·ASP.NET开发简明手册 ·ASP.NET 2.0中层次数据的处理
·用PHP和SQL Sever实现分页显示 ·如何动态创建网页的RSS内容摘要

   文章评论:(条)
  
 请留名: 匿名评论   点击查看所有评论 网管论坛
 

  责任编辑:一分  声明:刊登此文章是为了传递更多信息,文章内容仅供参考,转载请注明出处。