Repeater控件的分页问题

Repeater控件的分页问题

以前做ASP的时间不算短,可是做ASP.NET我是个新手。前几天做项目,遇到一个问题,要求比较复杂的数据格式显示,用DataGrid非常难实现,后来改用了Repeater控件来实现。不过这样就带来一个新问题:怎么分页?Repeater没有内置的分页功能。后来自己试着写了一个,侥幸成功了。匆匆写就,肯定不完善,哪位高手有何高见请及时指正,很愿意与各位交流(zhoubin@mail.sdu.edu.cn)

protected System.Web.UI.WebControls.Repeater rptFramework

private void Page_Load(object sender, System.EventArgs e) 
{

//建立DataSet 
(该部分省略)

rptFramework.DataSource = myDataSet; 
rptFramework.DataBind();

Session["page"] = 1;

//将Repeater所有条目隐藏 
int i = 0 ;

for( i = 0 ; i < rptFramework.Items.Count ; i++ ) 

rptFramework.Items[i].Visible = false; 
}

//Repeater控件的页面大小 
int intPageSize = 10;


//rptFramework控件的当前页索引(1起始) 
int intCurrentPageIndex = 0 ;

if ( Request.QueryString["page"] == null || Convert.ToInt32( Request.QueryString["page"] ) == 0 ) 

Session["page"] = 1 ; 

else 

Session["page"] = Convert.ToInt32( Request.QueryString["page"] ); 
}

intCurrentPageIndex = Convert.ToInt32( Session["page"] );

//上一页按钮屏蔽 
if ( Convert.ToInt32( Session["page"] ) == 1 ) 

btnPre.Enabled = false; 
}

//rptFramework控件的当前游标索引(1起始) 
int intCurrentItemIndex = 1 ; 
intCurrentItemIndex = intPageSize * ( intCurrentPageIndex - 1 ) + 1 ;

//下一页按钮屏蔽 
if ( (rptFramework.Items.Count - intCurrentItemIndex) < intPageSize ) 

btnNext.Enabled = false; 
}


//设置窗体加载时的默认视图 
if ( rptFramework.Items.Count > intPageSize ) 

for (i = intCurrentItemIndex ; i < GetMin( rptFramework.Items.Count , intCurrentItemIndex + intPageSize ) ; i++ ) 

rptFramework.Items[i-1].Visible = true; 
}


}

}


//取两个数值中较小的值,但是不改变原数值大小 
private int GetMin( int a , int b ) 

int c ; 
if ( a > b ) 

c = b; 

else 

c = a; 

return c; 
}

//点击上一页按钮 
private void btnPre_Click(object sender, System.EventArgs e) 
{

int intPrePageIndex = 2;

if ( Convert.ToInt32( Session["page"] ) != 1 ) 

intPrePageIndex = Convert.ToInt32( Session["page"] ) - 1; 

else 

intPrePageIndex = 1; 
}

Response.Redirect( "jggk.aspx?page=" + intPrePageIndex.ToString() ); 
}

//点击下一页按钮 
private void btnNext_Click(object sender, System.EventArgs e) 

int intNextPageIndex = Convert.ToInt32( Session["page"] ) + 1; 
Response.Redirect( "jggk.aspx?page=" + intNextPageIndex.ToString() ); 
}

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
<h3>回答1:</h3><br/>ASP.NET Repeater控件是一个数据绑定控件,它允许开发人员在Web应用程序中显示重复的数据。它可以绑定到数据源,如数据库或XML文件,并使用模板来定义如何呈现每个数据项。Repeater控件非常灵活,可以用于创建各种类型的列表和表格,包括新闻列表、产品目录、图库和评论区等。它还支持分页和排序功能,使用户可以方便地浏览和查找数据。 <h3>回答2:</h3><br/>asp.net repeater控件是用于在asp.net web页面中进行数据展示的控件。它可以根据绑定的数据源重复呈现一个模板,在每一次呈现时显示相应的数据。这个重复的模板由开发者自己通过HTML标记及ASP.NET控件来自定义。开发者可以使用多种技术来绑定数据源,常见的有:绑定到数据库、XML文件、内存中的对象等。 使用asp.net repeater控件可以极大的简化数据展示的工作,在一个web页面上可以通过多个repeater控件展示不同的数据,这些控件可以实现很多的布局方式,如列表、表格等。使用asp.net repeater控件不但可以提高数据展示效率,而且使页面更加灵活和可定制化。 除了数据绑定,asp.net repeater控件还有一些重要的属性和事件,例如:ItemDataBound事件,可以在绑定数据时对每一项进行处理;ItemTemplate属性,可以自定义重复模板;HeaderTemplate和FooterTemplate属性,不仅可以定义页眉和页脚,还可以在此处添加一些类似于数据汇总的统计信息,方便用户阅读和分析。 总的来说,asp.net repeater控件是一个非常实用和灵活的控件,可以帮助开发者快速实现复杂的数据展示需求,同时也可以提高网站的交互度和用户体验。 <h3>回答3:</h3><br/>asp.net repeater 控件是一种用于在 web 应用程序中绑定和显示数据的控件,它允许我们针对重复数据绑定一组控件,实现数据的动态显示和编辑。换句话说,repeater 控件是一种用于展示数据的控件,它提供了一种非常灵活的方式来自定义显示数据的方式。 使用 repeater 控件的第一步是绑定数据源,数据源可以是任何实现了 System.Collections.IEnumerable 接口的集合。我们可以在页面的服务器端代码中绑定数据源,也可以在 aspx 文件中使用 DataSource 属性实现数据绑定。 在绑定数据源之后,我们可以根据自己的需要使用 asp.net 控件来自定义数据的显示方式。repeater 控件中最常用的控件是 Label、HyperLink、Literal 和 Image 等,它们可以帮助我们方便地绑定、格式化和展示数据。 另一个重要的功能是 repeater 控件允许我们自定义数据的分组方式。我们可以在绑定数据源之前对数据进行分组,然后在组的总览页面中展示数据。这种方式可以帮助我们轻松地将数据进行分类,并按照某种规律进行显示。 除此之外,repeater 控件还提供了一些事件和方法,例如 ItemDataBound、ItemCommand 等。通过这些事件和方法,我们可以在控件绑定数据时添加一些逻辑,以实现数据的进一步处理和操作。 总之,asp.net repeater 控件是一个非常实用的控件,可以帮助我们高效、灵活地展示数据。无论是在网站开发、数据管理、数据可视化等方面都具有重要的应用价值。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

qkjhlvsd

你的鼓励将是我创作的最大动力

¥2 ¥4 ¥6 ¥10 ¥20
输入1-500的整数
余额支付 (余额:-- )
扫码支付
扫码支付:¥2
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、C币套餐、付费专栏及课程。

余额充值