设为首页
加入收藏
联系站长
您现在的位置: 网贝 >> 建站学院 >> ASP.NET >> winform应用 >> 文章正文 用户登录 新用户注册
[组图]如何用DataGrid实现类似DataList多列的效果         ★★★
如何用DataGrid实现类似DataList多列的效果
相关网站:
作者:lovecher… 文章来源:http://www.cnblogs.com/lovecherry 点击数: 更新时间:2005-6-21

上一次说了怎么利用DataGrid纵向显示
http://www.netbei.com/Article/aspx/aspx7/200506/3885.html
其实这么做的好处在于DataGrid能够方便的进行分页,这个排列次序接近于DataList的RepeatDirection="Vertical"效果
今天再来对上次的程序进行一下修改,实现RepeatDirection="Horizontal"的效果,同时启用DataGrid的分页。
这样可以弥补DataList不能自动分页的不足,但是效率上来说其实是很差的。


<asp:DataGrid id="DataGrid1" runat="server" AllowPaging="True" PageSize="4"></asp:DataGrid>

这里的Pagesize是代表行数,下面那个方法的iSize参数代表列数

private DataTable MakeData(DataTable dt,int iSize,int iColumnID) 
        

            
int itmp=dt.Rows.Count%iSize; 
            
int iRow; 
            
if(itmp==0
                iRow
=dt.Rows.Count/iSize; 
            
else 
                iRow
=dt.Rows.Count/iSize+1
            DataTable newdt
=new DataTable(); 
            
for(int i=0;i<iSize;i++
            

                DataColumn dc
=new DataColumn(dt.Columns[iColumnID].ColumnName+i,dt.Columns[iColumnID].DataType); 
                newdt.Columns.Add(dc); 
            }
 
            
for(int i=0;i<iRow;i++
            
{         
                DataRow dr
=newdt.NewRow(); 
                
for(int j=0;j<iSize;j++
                

                    
if((j+i*iSize)<dt.Rows.Count)dr[dt.Columns[iColumnID].ColumnName+j]=dt.Rows[j+i*iSize][iColumnID]; 
                }
 
                newdt.Rows.Add(dr);                 
            }
 
            
return newdt; 
        }
 

private void Page_Load(object sender, System.EventArgs e)
        
{
            
// 在此处放置用户代码以初始化页面
            if(!IsPostBack)
            
{
                SetBind();
            }

        }


        
private void SetBind()
        
{
            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); 
            }
 
            
this.DataGrid1.DataSource=MakeData(dt,4,0); 
            
this.DataGrid1.DataBind();
        }

    private void DataGrid1_PageIndexChanged(object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
        
{
            
this.DataGrid1.CurrentPageIndex=e.NewPageIndex;
            SetBind();
        }
文章录入:admin    责任编辑:admin 
  • 上一篇文章:

  • 下一篇文章:
  • 【字体: 】【发表评论】【加入收藏】【告诉好友】【打印此文】【关闭窗口
    相关网站:

    文章 下载 图片
    普通文章[组图]DataGrid在Po
    普通文章[图文]DataGrid的Ed
    普通文章[图文]方便的使用单
    普通文章[组图]为DataGrid添
    普通文章[组图]如何用DataGr
    普通文章[组图]嵌套的DataGr
    普通文章[组图]如何利用Data
    普通文章[组图]联合主键的情
  • 此栏目下没有推荐文章
  • 普通文章把手教你写私服列表
    普通文章WEB标准
    普通文章GOOGLE sitemap官方
    普通文章用php定制404错误页
    普通文章WAP(wml)开发问答
    普通文章[组图]PS教程系列:快
    普通文章时使用apache和IIS,
    普通文章[组图]2005年的第一
    推荐文章[组图]彻底掌握IIS6
    推荐文章[组图]CSS 全攻略
    推荐文章各种脚本错误详解!
    推荐文章直接生成XML的Googl
    推荐文章九个常见的错误原因
    推荐文章Win XP家用版也能装
    推荐文章JSP入门初级教程之J
    推荐文章ASP入门及提高
  • DataGrid在PostB

  • DataGrid的EditC

  • 方便的使用单击和

  • 为DataGrid添加自

  • 嵌套的DataGrid如


  • DataGrid在PostBack

    DataGrid的EditComm

    方便的使用单击和双

    为DataGrid添加自定
    (只显示最新10条。评论内容只代表网友观点,与本站立场无关!)

    Copyright © 2003-2005 NetBei.com All rights reserved.