asp.net动态网站repeater控件使用及分页操作介绍
asp.net动态网站repeater控件使用及分页操作介绍
1.简单介绍
Repeater 控件是一个容器控件,可用于从网页的任何可用数据中创建自定义列表。Repeater 控件没有自己内置的呈现功能,这意味着用户必须通过创建模板来提供 Repeater 控件的布局。当网页运行时,Repeater 控件会循环通过数据源中的记录,并为每个记录呈现一个项。
2.布局
一个完整的Repeater包括:
<!--头部模板,放表格开始及第一行标题-->
<HeaderTemplate></HeaderTemplate>
<!--项目模板,会进行循环显示,放置表格第二行-->
<ItemTemplate></ItemTemplate>
<!--底部模板,放表格结束部分-->
<FooterTemplate> </FooterTemplate>
3.使用repeater进行数据绑定
代码见下
//从Person表中查出所有数据
string sqlselect = "select * from Person";
//使用自己封装好的类从数据库里查询信息,返回一个DataTable类型的数据
DataTable dt = SQLHelper.DataT(sqlselect);
//将数据绑定到repeater的数据源上
this.RptPreson.DataSource = dt;
//显示数据
this.RptPreson.DataBind();
4.repeater的删除功能
在Repeater中添加删除的LinkButton:
<asp:LinkButton ID="lbtDelete" CommandName="Delete" CommandArgument='<%#Eval("id") %>' runat="server">删除</asp:LinkButton>
给LinkButton的CommandName属性和CommandArgument属性赋值,然后通过OnCommand事件中,就可以得到CommandEventArgs类中的数据,从而到判断是哪个LinkButton被按动了。CommandEventArgs类存储了与Button事件相关的数据,并且可以在事件处理中通过CommandEventArgs类的属性来访问这些数据。说的明白些,就是当LinkButton被按动后,这个LinkButton所触发的数据都被储存到服务器的CommandEventArgs类中,访问CommandEventArgs类中的属性也就访问了被按动的LinkButton了。
简单地讲,系统通过CommandName来确定哪一类Button被按下,进而确定应该执行的操作,通过CommandArgument来确定应该对哪一条数据进行操作。
if (e.CommandName == "Delete")
{//删除行内容命令
id = int.Parse(e.CommandArgument.ToString());
string sqlDelete = "delete from Person where ID='" + Convert.ToInt32(id) + "'";
SQLHelper.OperateSql(sqlDelete);
Response.Write("<script>alert('删除成功'),location='Person.aspx'</script>");
}
5.repeater实现分页操作
//PagedDataSource 类封装 Repeater控件的属性,这些属性使之可以执行分页。
PagedDataSource pds = new PagedDataSource();
pds.DataSource = dt.DefaultView; //获取或设置数据源
pds.AllowPaging = true;//允许分页
pds.PageSize = 2;//单页显示项数
lbTotal.Text = pds.PageCount.ToString();//获取页面总数
int CurPage=1;
pds.CurrentPageIndex = CurPage - 1;////当前页数,因为从0开始,所以接收到的数减1
RptBook.DataSource = pds;//将数据绑定到repeater控件上
RptBook.DataBind();
6.repeater嵌套使用
<asp:Repeater ID="RptPerson" runat="server" OnItemDataBound="RptPerson_ItemDataBound">
<ItemTemplate>
<h2>
姓名:
<%#Eval("name") %>
</h2>
<h3>拥有的书籍</h3>
<%--嵌套Repeater,显示每个人的书籍 --%>
<asp:Repeater ID="RptBook" runat="server" OnItemCommand="RptBook_ItemCommand">
<ItemTemplate>
<%#Eval("book") %>
</ItemTemplate>
</asp:Repeater>
<%--嵌套Repeater结束--%>
<br />
</ItemTemplate>
</asp:Repeater>
后台.cs文件部分:
Repeater数据分为 Item 和AlternatingItem ,比如 第一行 数据是Item,第二行 数据是AlternatingItem ,第三行 数据是Item……….
//
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
{
}
//作用就是判断Reaperter的第几行
Repeater嵌套实现“楼中楼”
if (e.Item.ItemType == ListItemType.Item || e.Item.ItemType == ListItemType.AlternatingItem)
{
//找到外层Repeater的数据项
DataRowView rowv = (DataRowView)e.Item.DataItem;
//提取外层Repeater的数据项的ID
int ID = Convert.ToInt32(rowv["ID"]);
//找到对应ID下的Book
string select = "select * from Book where ownerid=" + ID.ToString();
//找到内嵌Repeater
Repeater rept = (Repeater)e.Item.FindControl("RptBook");
//数据绑定
rept.DataSource = SQLHelper.SelectS(select);
rept.DataBind();
}
asp.net动态网站repeater控件使用及分页操作介绍的更多相关文章
- asp.net学习之Repeater控件
asp.net学习之Repeater控件 文章摘自:http://www.cnblogs.com/shipfi/archive/2009/10/19/1585703.html Repeater控件和D ...
- ASP.NET Repeater控件实现简单分页
早上,有看MSDN,看到了 PagedDataSource 类 http://msdn.microsoft.com/zh-cn/library/system.web.ui.webcontrols.pa ...
- ASP.NET动态添加用户控件的方法
本文实例讲述了ASP.NET动态添加用户控件的方法.分享给大家供大家参考.具体实现方法如下: 为了让用户控件能ASP.NET页面实现动态添加,首先写一个接口IGetUCable,这个接口有一个函数,返 ...
- 动态变更Repeater控件HeaderTemplate列名
本博文,Insus.NET教你动态实现变更Repeater控件HeaderTemplate列名.一般情况之下,是不需要动态变更,只有动态有Repeater控件不变情况之下,来显示多种数据源进行绑定.这 ...
- asp.net动态增加服务器端控件并提交表单
为什么要用原生的呢? 1.目的 原生出现浏览器兼容性问题 极少,不用测试多浏览兼容性 .需要考虑到市面上的其他垃圾浏览器. 2.性能不好 如果不考虑第一条 你可以换一种方式 直接上代码 .aspx页面 ...
- 动态合并Repeater控件数据列
前天Insus.NET实现<动态合并GridView数据行DataRow的列>.今天再玩玩Repeater控件,功能也是动态合并某列栏位.Repeater控件跟GridView控件一样集成 ...
- Asp.net Repeater控件的绑定与操作
由于repeater 控件具有的一个特性--循环 <ItemTemplate>的内容,Repeater 控件里的某个元素对象的绑定与获取,不像平常的,直接使用控件的 id 便可以给该控件进 ...
- repeater控件自定义Url分页带参数
repeater控件的效果图如下: 该页面实现的功能如下: 1.上下分页,(也可以带首页和末页,我只是禁掉了没用) 2.根据用户输入的指定分页索引进行跳转 3.根据筛选数据的参数进行URL分页的参数传 ...
- asp.net动态解析用户控件(UserControl)
模块化的时候需要用到: #region asp.net解析用户控件 /// <summary> /// asp.net 解析用户控件 /// </summary> /// &l ...
随机推荐
- CentOS 通过yum来升级php到php5.6
在文章中,我们将展示在centOS系统下如果将php升级到5.6,之前通过yum来安装lamp环境,直接升级的话,提示没有更新包,也就是说默认情况下php5.3.3是最新 1.查看已经安装的php版本 ...
- 第三方模块paramiko的使用
"Paramiko" is a combination of the Esperanto words for "paranoid" and "frie ...
- Tomcat(五):nginx/httpd + tomcat及负载均衡tomcat
*/ .hljs { display: block; overflow-x: auto; padding: 0.5em; color: #333; background: #f8f8f8; } .hl ...
- Markdown内嵌Html语言
概述 Markdown是内嵌Html语言的,这使得我们可以在Markdown文档里面实现很多有趣的东西.现在记录在此,供自己以后参考,相信对其他人也有用. 介绍 Markdown的语法只有一个目标:作 ...
- 树莓派用U盘安装系统
* 需要使用Raspbian / Raspbian Lite或更高版本的2017-04-10版本 *不会SD卡装系统? 1. 先用装好Raspbian系统的SD卡启动 在命令行输入 echo ...
- 在线生成PDF的网站-HTML 转 PDF 在线
http://pdf.df5d.com/ (服务器问题,演示暂停了,但是 下面介绍的组件还是可以使用的) 将前面用到的wkhtmltopdf用一个服务器程序集成在一起,接受一个URL参数,在生成一 ...
- 给HttpClient添加Socks代理
本文描述http client使用socks代理过程中需要注意的几个方面:1,socks5支持用户密码授权:2,支持https:3,支持让代理服务器解析DNS: 使用代理创建Socket 从原理上来看 ...
- 编译安装 python 2.7
下载python2.7 Python-2.7.6.tgz 下载链接:http://pan.baidu.com/s/1c0AJDDI 配置./configure 编译make 安装 make insta ...
- MySQL用户授权与权限
MySQL权限如下表 权限名字 权限说明 Context CREATE 允许创建新的数据库和表 Databases, tables, or indexes DROP 允许删除现有数据库.表和视图 Da ...
- MySQL5学习笔记(三)
系统变量 mysqld服务器维护两种变量.全局变量(GLOBAL)影响服务器整体操作.会话变量(SESSION)影响具体客户端连接的操作. 当服务器启动时,它将所有全局变量初始化为默认值.这些 ...