我正在做一个带有搜索的网页,它会从MSsql中获取大量信息.我所做的是一个存储过程,只返回要在网站上看到的页面.
现在我正在进行分页,因为我需要显示类似于谷歌的东西.如果您在第1页,他们会显示前10页,如果您在第19页,则显示自第9页到第28页.
我认为显示页码的最佳选择是在转发器中使用链接按钮.我现在遇到的问题是我不知道在回发时获取页码的最佳方法.
做一个快速示例我将一个ArrayList分配给repeater.datasource:
<asp:Repeater ID="Repeater2" runat="server"> <ItemTemplate> <asp:LinkButton ID="LinkButton1" runat="server" CommandArgument="<%# Container.DataItem %>"><%# Container.DataItem %></asp:LinkButton> </ItemTemplate> </asp:Repeater> <asp:LinkButton ID="LinkButton2" runat="server" CommandArgument="4654">Test #1</asp:LinkButton>
protected void Page_Load(object sender,EventArgs e) { if (this.IsPostBack) { string x = LinkButton2.CommandArgument; //string y = LinkButton1.CommandArgument; //I know this line will not work since the Linkbutton1 is inside the Repeater. }
我该怎么做才能使它有效?
谢谢
杰瑞
解决方法
您正在寻找ItemCommand事件:
<asp:Repeater ID="Repeater1" OnItemCommand="ItemCommand" runat="server"> <ItemTemplate> <asp:LinkButton CommandName="ButtonEvent" CommandArgument="<%# Container.DataItem %>" Text="<%#Container.DataItem %>" runat="server"></asp:LinkButton> </ItemTemplate> </asp:Repeater>
代码背后:
protected void Page_Load(object sender,EventArgs e) { if (!Page.IsPostBack) { Repeater1.DataSource = Enumerable.Range(1,10); Repeater1.DataBind(); } } protected void ItemCommand(Object Sender,RepeaterCommandEventArgs e) { Response.Write("The no. " + ((LinkButton)e.CommandSource).Text + " button was clicked!"); }
…但你真的确定你需要LinkButton吗?一个普通的HTML锚标签也可以正常工作,并且它的模糊性较低.