• gridview 万能分页代码


    实现如下图片的分页:第【】页,共【】页,首页,上一页,下一页,末页 跳到某页;图片在最下面;gv里面的模板PagerTemplate复制到你的gv对应位置,然后在

    protected void gvgetall_PageIndexChanging(object sender, GridViewPageEventArgs e)事件里面写.cs里代码就可以实现。 

    复制代码
    <asp:GridView ID="gvgetall" runat="server" AllowSorting="True" AutoGenerateColumns="False"
                                Width
    ="100%" OnRowCommand="gvgetall_RowCommand" EmptyDataText="没有任何数据可以显示" AllowPaging="True"
                                OnPageIndexChanging
    ="gvgetall_PageIndexChanging" PageSize="2" OnSorting="gvgetall_Sorting"
                                OnRowCreated
    ="gvgetall_RowCreated" OnRowDataBound="gvgetall_RowDataBound">
                                
    <Columns>
                                    
    <asp:BoundField DataField="En_id" HeaderText="编号" Visible="False">
                                        
    <ItemStyle HorizontalAlign="Center" />
                                    
    </asp:BoundField>
                                    
    <asp:TemplateField HeaderText="企业名称" SortExpression="name">
                                        
    <ItemTemplate>
                                            
    <asp:LinkButton ID="btnupdate" CommandName="update" CommandArgument='<%#Eval("ID") %>'
                                                runat
    ="server" Text='<%# trimFieldLength(Eval("name").ToString())%>' ForeColor="blue" />
                                        
    </ItemTemplate>
                                        
    <ItemStyle HorizontalAlign="Center" />
                                        
    <FooterTemplate>
                                            RETGRYTRYTYGTY
                                        
    </FooterTemplate>
                                    
    </asp:TemplateField>
                                    
    <asp:TemplateField SortExpression="WEBSITE" HeaderText="企业网址">
                                        
    <ItemTemplate>
                                            
    <asp:Label ID="lbweb" Visible="false" runat="server" Text='<%# trimFieldLength1(Eval("WEBSITE").ToString())%>'></asp:Label>
                                            
    <a href='<%=ViewState["web"]%>' target="_blank">
                                                
    <%# trimFieldLength1(Eval("WEBSITE").ToString())%>
                                            
    </a>
                                        
    </ItemTemplate>
                                        
    <ItemStyle HorizontalAlign="Center" />
                                    
    </asp:TemplateField>
                                    
    <asp:BoundField DataField="address" HeaderText="企业地址" SortExpression="address">
                                        
    <ItemStyle HorizontalAlign="Center" />
                                    
    </asp:BoundField>
                                
    </Columns>
                                
    <PagerStyle CssClass="cssPager" />
                                
    <AlternatingRowStyle BackColor="#E2F8FF"></AlternatingRowStyle>
                                
    <HeaderStyle HorizontalAlign="Center" BackColor="#99CCFF"></HeaderStyle>
                                
    <PagerTemplate>
                                    
    <table>
                                        
    <tr>
                                            
    <td style="text-align: right">
                                                第
    <asp:Label ID="lblPageIndex" runat="server" Text="<%#((GridView)Container.Parent.Parent).PageIndex + 1 %>"></asp:Label>
                                                共
    <asp:Label ID="lblPageCount" runat="server" Text="<%# ((GridView)Container.Parent.Parent).PageCount %>"></asp:Label>
                                                
    <asp:LinkButton ID="btnFirst" runat="server" CausesValidation="False" CommandArgument="First"
                                                    CommandName
    ="Page" Text="首页" Enabled="<%# ((GridView)Container.Parent.Parent).PageIndex!=0 %>"></asp:LinkButton>
                                                
    <asp:LinkButton ID="btnPrev" runat="server" CausesValidation="False" CommandArgument="Prev"
                                                    CommandName
    ="Page" Text="上一页" Enabled="<%# ((GridView)Container.Parent.Parent).PageIndex!=0 %>"></asp:LinkButton>
                                                
    <asp:LinkButton ID="btnNext" runat="server" CausesValidation="False" CommandArgument="Next"
                                                    CommandName
    ="Page" Text="下一页" Enabled="<%# ((GridView)Container.Parent.Parent).PageIndex!=((GridView)Container.Parent.Parent).PageCount-1 %>"></asp:LinkButton>
                                                
    <asp:LinkButton ID="btnLast" runat="server" CausesValidation="False" CommandArgument="Last"
                                                    CommandName
    ="Page" Enabled="<%# ((GridView)Container.Parent.Parent).PageIndex!=((GridView)Container.Parent.Parent).PageCount-1 %>"
                                                    Text
    ="尾页"></asp:LinkButton>
                                                
    <asp:TextBox ID="txtNewPageIndex" runat="server" onkeyup="value=value.replace(/[^d]/g,'') "
                                                    Text
    ="<%# ((GridView)Container.Parent.Parent).PageIndex + 1%>" Width="20px"></asp:TextBox>
                                                
    <asp:LinkButton ID="btnGo" runat="server" CausesValidation="False" CommandArgument="-1"
                                                    CommandName
    ="Page" Text="GO"></asp:LinkButton>
                                            
    </td>
                                        
    </tr>
                                    
    </table>
                                
    </PagerTemplate>
                            
    </asp:GridView>


     .cs
    protected void gvgetall_PageIndexChanging(object sender, GridViewPageEventArgs e)
        {   

            GridView gvw 
    = (GridView)sender;//当前实例
            if (e.NewPageIndex < 0)
            {
                TextBox pageNum 
    = (TextBox)gvw.BottomPagerRow.FindControl("txtNewPageIndex");
                
    int Pa = int.Parse(pageNum.Text);
                
    if (Pa <= 0)
                {
                    gvw.PageIndex 
    = 0;
                }
                
    else
                {
                    gvw.PageIndex 
    = Pa - 1;
                }
            }
            
    else
            {
                gvw.PageIndex 
    = e.NewPageIndex;
            }    

            bind();
        }
    复制代码

    知识点1

    CausesValidation="False" -----不执行当前页的验证

    还有种不执行验证的方法是ValidationGroup="group1" 给控件进行分组

    这种方法在页面验证用的比较多

    知识点2

    Container.Parent.Parent 绑定数据性能最好

    (GridView)Container.Parent.Parent).PageIndex 的联想!!!

    DataBinder.Eval(Container.DataItem,"Name")和Container.DataItem("Name")有什么区别?

    DataBinder是System.Web里面的一个静态类,它提供了Eval方法用于简化数据绑定表达式的编写,但是它使用的方式是通过Reflection等开销比较大的方法来达到易用性,因此其性能并不是最好的。而Container则根本不是任何一个静态的对象或方法,它是ASP.NET页面编译器在数据绑定事件处理程序内部声明的局部变量,其类型是可以进行数据绑定的控件的数据容器类型(如在Repeater内部的数据绑定容器叫RepeaterItem),在这些容器类中基本都有DataItem属性,因此你可以写Container.DataItem,这个属性返回的是你正在被绑定的数据源中的那个数据项。如果你的数据源是DataTable,则这个数据项的类型实际是DataRowView。

    http://www.qqread.com/aspdotnet/u490415.html

    知识点3:

    如何正确理解ASP.NET中的Sender

    //当前实例


    举个例子:
    <input type="submit" id="a1" value="
    " OnServerClick="Submit_Click" runat="server">
    <input type="submit" id="a2" value="
    " OnServerClick="Submit_Click" runat="server">
    <input type="submit" id="a3" value="
    " OnServerClick="Submit_Click" runat="server">
    <input type="submit" id="a4" value="
    " OnServerClick="Submit_Click" runat="server">
    这是四个Submit 按钮,我们知道它触发的事件是同一个事件,但要怎么来区分呢?看看下面就知道了:
    public void Submit_Click(Object sender, EventArgs E)
    {
    switch (((Control)sender).ID)
    {
    case "a1" :showmsg.Text=""
    宋颜浩; break;
    case "a2" :showmsg.Text=""
    李雁冰; break;
    case "a3" :showmsg.Text=""
    费文华; break;
    case "a4" :showmsg.Text=""
    吴晓桃; break;
    }
    }
    </script>
    <asp:Label id=showmsg runat=server />

    知识点4:

    当单击页面的连接的时候连接到这个连接的页面,这个连接来自数据库

    我用的是ViewState,循环绑定实现的,一下是实现的代码:

     

    protected void gvgetall_RowDataBound(object sender, GridViewRowEventArgs e)

        {

     

            if (e.Row.RowType == DataControlRowType.DataRow)

            {

                Label hlDownload = (Label)e.Row.FindControl("lbweb");

                string lbweb = hlDownload.Text.Trim().ToString();

               ViewState["web"] = lbweb;        

              

            }

    知识点5:

    正则表达式:

    只可以输入数字 onkeyup="value=value.replace(/[^d]/g,'') "

    http://www.cnblogs.com/muer/archive/2010/03/26/1697149.html

  • 相关阅读:
    Android Studio 2.3.1导出jar文件不能生成release解决办法
    AndroidStudio 3.0 生成jar包的方法
    Android Studio如何打jar包
    Android Studio 如何打JAR包(修订版)
    6款程序员必备的开源中文处理工具
    Qt5.8 下链接 Mysql 错误以及解决方法(无论 Mysql 是什么版本的,64 位 Qt 要用 64 位的 Mysql 驱动,32 位的 Qt 要用 32 位的Mysql 驱动)
    Go 语言如果按这样改进,能不能火过 Java?
    基于 CSP 的设计思想和 OOP 设计思想的异同
    DELPHI下多线程编程的几个思维误区(QDAC)
    如何使用表单
  • 原文地址:https://www.cnblogs.com/YoungPop-Chen/p/3388262.html
Copyright © 2020-2023  润新知