如何利用DataGrid纵向显示数据
2006-08-25 16:20
549 查看
有的时候想实现类似下图,第二个图示的效果:
我们可能首先会想到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
我们可能首先会想到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
相关文章推荐
- (论坛答疑点滴)如何利用DataGrid纵向显示数据?
- (论坛答疑点滴)如何利用DataGrid纵向显示数据?
- 如何利用DataGrid纵向显示数据?
- 如何利用GridView纵向显示数据?
- Flex中如何利用mx:HTTPService标签读取文本文件中的name/value这样的一对数据并显示在DataGrid中的例子
- Easyui Datagrid 如何实现后台交互显示用户数据列表
- 【百度地图API】如何利用自己的数据制作社交地图?只显示可视区域内的标注
- 利用ASP.NET DataGrid显示主次关系的数据
- 【百度地图API】如何利用自己的数据制作社交地图?只显示可视区域内的标注
- 利用ASP.NET DataGrid显示主次关系的数据
- 利用ASP.NET DataGrid显示主次关系的数据
- 利用ASP.NET DataGrid显示主次关系的数据
- DataGrid的使用:(二)、利用ASP.NET DataGrid显示主次关系的数据
- 【百度地图API】如何利用自己的数据制作社交地图?只显示可视区域内的标注
- 利用ASP.NET DataGrid显示主次关系的数据
- 利用ASP.NET DataGrid显示主次关系的数据
- 如何在datagrid中以dd-mmm-yyyy格式显示数据行
- 利用ASP.NET DataGrid显示主次关系的数据(c#版)
- DataGrid的使用:(二)、利用ASP.NET DataGrid显示主次关系的数据
- 如何利用自己的数据制作社交地图?只显示可视区域内的标注