×

repeater分页 pea ate

repeater分页(两个Repeater嵌套,内层Repeater分页问题,求大神)

admin admin 发表于2022-09-07 01:54:57 浏览129 评论0

抢沙发发表评论

本文目录

两个Repeater嵌套,内层Repeater分页问题,求大神


我也试了一下,想法和你的差不多。。但是刚开始发现一个问题,就是内嵌的,没法绑定repeater,我试了几张方法都不行,应该是个bug还是什么的。
后来在CSDN找了个,他是转换成list,发现居然行了。。。我就无语了= =!~估计是我数据源没弄好吧。。把代码贴给你,因为是个测试,所以比较随便,这个代码就是在ListView1_ItemDataBound里的。(我外面那个用的是listview1)然后用的是强类型,不懂再问哈~
list2TableAdapter ad = new list2TableAdapter();

var bid = ((DataRowView)e.Item.DataItem).Row[“bid“];
var table =
ad.GetDataById(new Guid(bid.ToString())).ToList();//重点是这个。。转成这个居然就可以了- -#
Repeater r = (Repeater)e.Item.FindControl(“Repeater1“);
r.DataSource = table;
r.DataBind();
其实。后来想想,用mvc的话会简单很多,完全业务和逻辑分开。而且效果做的可以更灵活呵呵。

dropdownlist的内容在repeater里实现分页跳转


protected void DropDownList1_SelectedIndexChanged(object sender, EventArgs e)
{
Response.Redirect(Request.Path + “?page=“ + ((DropDownList)(sender)).SelectedValue);
}

c#的repeater怎样实现分页


分页的实现有好多种方式,你可以使用用户的自定义控件来实现,也可以使用类来实现,具体的可以看下http://blog.sina.com.cn/s/blog_83a4857e01011tyw.html

Repeater分页问题


Paging函数里似乎是没问题的.
每次点击按钮.Page_Load都会执行.所以加上 !ispostback 试试.
protected void Page_Load(object sender, EventArgs e)
{
if (!ispostback)
Paging();
}
补充--Sql语句.确实没写分页,补上.
select top 10 * from lyb where lyb_id not in (select top 1*10 lyb_id from lyb order by lyb_id) order by lyb_id
其中的两个数字(1 和 10)需要在页面做处理.
1是你的页数,10是你每页要显示的记录数.
之所以写成(1*10)是为了你能弄清关系.需要在页面处理后使用,sql文中不能有乘号“*“.
-pea

三层架构repeater怎么分页


持久层用来固化数据,如常说的DAO层,操作数据库将数据入库 业务层用来实现整体的业务逻辑 如 前台获得了数据,逻辑层去解析这些数据,效验这些数据等操作 表现层很好解释 你现在看到的网页 一些界面 都属于表现层的东西可以用一些Html,jsp,Swing来实现 至于mvc么对应的是 model(模型) view(视图) Controller(控制) 在javaweb中就很好理解了再XX系统中,前台页面属于view 贯穿前台后台持久层的一套模型就是model(EJB,Spring来实现) 而连接前台后台进行逻辑操作的就是Controller(Struts来实现)
-ate

repeater怎么分页


创建一个分页数据源的对象
这样:protected PagedDataSource pds=new PagedDataSource();//这个放在Page_Load上面
在绑定的时候这样写
pds.AllowPaging = true;//设置可以分页
pds.PageSize = 2;//每页的项数
pds.CurrentPageIndex = 0;//获取或设置当前页的索引
pds.DataSource = ds.Tables.DefaultView;//ds是从数据库获取的DataSet
Repeater1.DataSource = pds;//绑定数据
Repeater1.DataBind();
然后在添加一些button控件来做上一页,下一页这些
希望对你有用
-pea

Repeater + URL字符串参数实现分页的问题


这个你需要在后台控制url参数。
先假设你的 url是 search.aspx?key=xxx&page=1
你后台的 下一页链接,就需要改为 search.aspx?key=xxx&page=当前页+1
key和page都要保留。
-----------
汗死,不太明白你所说的,你的意思是不是点击了第几页,然后第几页的数字就变色? 如果你用的是 独立写的分页类,并且返回翻页链接的话,比较好解决。其他的话,没做过尝试。
-ate

Repeater绑定数据后,数据过多怎么把绑定后的结果分成两行两列谢谢了


的确要美工,不过你自己也可以来,例如
《asp:Repeater ID=“Repeater1“ runat=“server“》
《ItemTemplate》
《div style=“float: left; width: 50%;“》
《%#Eval(“UserName“)%》
《/div》
《/ItemTemplate》
《/asp:Repeater》
这样循环出来就是两列 50%有时候可能有些兼容问题,可以改成49%
-pea

repeater分页如何控制
标签的属性


DataList分页方法的核心原理是利用PagedDataSource对象,PagedDataSource类封装了DataGrid 控件的属性,这些属性使 DataGrid 可以执行分页,下面是PagedDataSource的公共属性:
AllowCustomPaging 获取或设置指示是否启用自定义分页的值。
AllowPaging 获取或设置指示是否启用分页的值。
Count 获取要从数据源使用的项数。
CurrentPageIndex 获取或设置当前页的索引。
DataSource 获取或设置数据源。
DataSourceCount 获取数据源中的项数。
FirstIndexInPage 获取页中的第一个索引。
IsCustomPagingEnabled 获取一个值,该值指示是否启用自定义分页。
IsFirstPage 获取一个值,该值指示当前页是否是首页。
IsLastPage 获取一个值,该值指示当前页是否是最后一页。
IsPagingEnabled 获取一个值,该值指示是否启用分页。
IsReadOnly 获取一个值,该值指示数据源是否是只读的。
IsSynchronized 获取一个值,该值指示是否同步对数据源的访问(线程安全)。
PageCount 获取显示数据源中的所有项所需要的总页数。
PageSize 获取或设置要在单页上显示的项数。
VirtualCount 获取或设置在使用自定义分页时数据源中的实际项数。
那么如何使用 PagedDataSource对象进行DataList分页呢?(网上有很多的讲DataList分页的文章,有一些是糊弄人的,有的还无法起作用,我被骗过一次,本文是我经过个人实践经验得到,可以顺利执行。希望对大家有所帮助。)
现在开始拉!
第一步,取出数据到datatable中,然后获得dataview,付给PagedDataSource对象
DataView objView = objTable.DefaultView;
PagedDataSource objPds = new PagedDataSource();
objPds.DataSource = objView;
第二步,PagedDataSource对象objPds的设置
objPds.AllowPaging = true;
objPds.PageSize = 4;
objPds.CurrentPageIndex = int.Parse(ViewState[“pageindex“].ToString());
上面的这两段代码都是写在BindData()函数中的,供每次点击分页按钮时调用。BindData()函数如下:
private void BindData()
{
string sql = “SELECT * From team“;
DataTable objTable = data.GetDataTable(sql);
if (objTable != null && objTable.Rows.Count 》 0)
{
DataView objView = objTable.DefaultView;
PagedDataSource objPds = new PagedDataSource();
objPds.DataSource = objView;
objPds.AllowPaging = true;
objPds.PageSize = 4;
objPds.CurrentPageIndex = int.Parse(ViewState[“pageindex“].ToString());
if (!objPds.IsFirstPage)
{
lkPre.Visible = true;
}
else
{
lkPre.Visible = false;
}
if (!objPds.IsLastPage)
{
lkNext.Visible = true;
}
else
{
lkNext.Visible = false;
}
dlData.DataSource = objPds;
dlData.DataBind();
}
}
到此为止,我们已经将数据交给了PagedDataSource,剩下的分页将利用PagedDataSource 进行处理。可能大家注意到了,这个数据交付是完整的数据交付,如果数据量很大会造成一定的效率低下,不过这里暂时不考虑这个问题。有兴趣的朋友可以一起探讨一下。
上面的第三行代码中的 ViewState[“pageindex“] 是用来控制PagedDataSource的当前页的,我们在Page_Load事件中和第三步将要将的函数中来具体讲解如何利用 ViewState[“pageindex“]控制当前页。
BindData()函数中后面的部分是控制向前向后按钮的显隐的,不再多说。
第三步,分页控制
第二步中说过利用 ViewState[“pageindex“] 来控制当前页,为了在页面加载的时候就显示第一页,我们当然要在Page_load事件中将 ViewState[“pageindex“]置为0。
protected void Page_Load(object sender, EventArgs e)
{
if (!IsPostBack)
{
ViewState[“pageindex“] = “0“;
BindData(); }
}
我们需要加两个按钮(Previous、Next)来点击进行分页控制。
《asp:DataList ID=“dlData“ runat=“server“ RepeatColumns=“4“ 》
《ItemTemplate》
《asp:Label ID=“lblName“ runat=“server“ /》《br /》
《asp:Label ID=“lblTime“ runat=“server“ /》
《/ItemTemplate》
《/asp:DataList》
《asp:linkbutton ID=“lkPre“ OnCommand=“IndexChanging“ CommandArgument=“pre“ runat=“server“ 》PREVIOUS PAGE》《/asp:linkbutton》
《asp:linkbutton ID=“lkNext“ OnCommand=“IndexChanging“ CommandArgument=“next“ runat=“server“ 》NEXT PAGE《/asp:linkbutton》
两个按钮的 OnCommand都是IndexChanging()函数,我们通过CommandArgument(pre和next)来区分到底是向前翻还是向后翻。下面是IndexChanging()函数
protected void IndexChanging(object sender, EventArgs e)
{
string strCommand = ((LinkButton)sender).CommandArgument.ToString();
int pageindex = int.Parse(ViewState[“pageindex“].ToString());
if (strCommand == “pre“)
{
pageindex = pageindex - 1;
}
else
{
pageindex = pageindex + 1;
}
ViewState[“pageindex“] = pageindex;
BindData();
}
至此,我们的分页函数已经写完了。这里还有一些东西没有说,比如显示一共多少条记录,当前第几页,一共多少页以及每一页的页码。相信看懂了上面所说的后这些东西还是容易写出来的。
总结一下,我们在前台写好DataList等待数据,而数据是由PagedDataSource提供的,分页通过我们新加的两个ImageButton来控制ViewState进而达到控制PagedDataSource的CurrentPageIndex来实现的。所以,其实DataList也没干啥事,就是显示了每一页的数据而已。有一点需要说明,PagedDataSource的CurrentPageIndex是从0开始的,这也是为什么在Page_load事件中要讲ViewState置为0而不是1的缘故。
Asp.net提供了三个功能强大的列表控件:DataGrid、DataList和Repeater控件,但其中只有DataGrid控件提供分页功能。相对DataGrid,DataList和Repeater控件具有更高的样式自定义性,所以很多时候我们喜欢使用DataList或Repeater控件来显示数据。
实现DataList或Repeater控件的分页显示有几种方法:
1、写一个方法或存储过程,根据传入的页数返回需要显示的数据表(DataTable)
2、使用PagedDataSource类(位于System.Web.UI.WebControls命名空间里)
本篇文章主要说怎么使用PagedDataSource类实现DataList和Repeater控件的分页显示。DataGrid控件内部也使用了PagedDataSource类,PagedDataSource 类封装 DataGrid 控件的属性,这些属性使 DataGrid 可以执行分页。
PagedDataSource 类的部分公共属性:
AllowCustomPaging 获取或设置指示是否启用自定义分页的值。
AllowPaging 获取或设置指示是否启用分页的值。
Count 获取要从数据源使用的项数。
CurrentPageIndex 获取或设置当前页的索引。
DataSource 获取或设置数据源。
DataSourceCount 获取数据源中的项数。
FirstIndexInPage 获取页中的第一个索引。
IsCustomPagingEnabled 获取一个值,该值指示是否启用自定义分页。
IsFirstPage 获取一个值,该值指示当前页是否是首页。
IsLastPage 获取一个值,该值指示当前页是否是最后一页。
IsPagingEnabled 获取一个值,该值指示是否启用分页。
IsReadOnly 获取一个值,该值指示数据源是否是只读的。
IsSynchronized 获取一个值,该值指示是否同步对数据源的访问(线程安全)。
PageCount 获取显示数据源中的所有项所需要的总页数。
PageSize 获取或设置要在单页上显示的项数。
VirtualCount 获取或设置在使用自定义分页时数据源中的实际项数。
这些属性是否和DataGrid的属性很相似?没错,DataGrid控件就是使用PagedDataSource类来实现数据分页显示的 。下面举个使用PagedDataSource类实现DataList和Repeater控件的分页显示的例子:
public void Page_Load(Object src,EventArgs e)
{
OleDbConnection objConn=new OleDbConnection(@“Provider=Microsoft.Jet.OLEDB.4.0; Data Source=c:\test.mdb“);
OleDbDataAdapter objCommand=new OleDbDataAdapter(“select * from Users“,objConn);
DataSet ds=new DataSet();
objCommand.Fill(ds);
//对PagedDataSource 对象的相关属性赋值
PagedDataSource objPds = new PagedDataSource();
objPds.DataSource = ds.Tables.DefaultView;
objPds.AllowPaging = true;
objPds.PageSize = 5;
int CurPage;
//当前页面从Page查询参数获取
if (Request.QueryString[“Page“] != null)
CurPage=Convert.ToInt32(Request.QueryString[“Page“]);
else
CurPage=1;
objPds.CurrentPageIndex = CurPage-1;
lblCurrentPage.Text = “Page: “ + CurPage.ToString();
if (!objPds.IsFirstPage)
lnkPrev.NavigateUrl=Request.CurrentExecutionFilePath + “?Page=“ + Convert.ToString(CurPage-1);
if (!objPds.IsLastPage)
lnkNext.NavigateUrl=Request.CurrentExecutionFilePath+ “?Page=“ + Convert.ToString(CurPage+1);
//把PagedDataSource 对象赋给Repeater控件
Repeater1.DataSource=objPds;
Repeater1.DataBind();
}

-ate

c#中的repeater怎样实现分页呢


这里说个比较易懂的分页方法。
repeater.DataSource=一个实现IEnumable的实例数据源。
假设你用的Source是var result=你的source数据,其它都可仿照这个理念。
var totalResults=result.Count;
var currentPage=CurrentPage--》这个参数作为访问器在页面每次点击事件时接收
var perPageItem=自定义当前页面显示多少个,这里定义10;
var currentPageItem=results.Skip((currentPage-1)*perPageItem).Take(perPageItem);
var totalPage=(double)toalResults/perPageItem;
做个for循环输出page。for(int i=1;i《=totalPage;i++)
循环出来的pageLink绑定事件,主要绑定 CurrentPage,然后刷新页面。
-pea