<rt id="bn8ez"></rt>
<label id="bn8ez"></label>

  • <span id="bn8ez"></span>

    <label id="bn8ez"><meter id="bn8ez"></meter></label>

    302班

    java突擊隊(duì)
    posts - 151, comments - 74, trackbacks - 0, articles - 14
      BlogJava :: 首頁 :: 新隨筆 :: 聯(lián)系 :: 聚合  :: 管理
    關(guān)于VS2005中GridView的自定義分頁,單選、多選、排序、自增列的簡單應(yīng)用。
        多選時(shí),只有全部選中時(shí)“多選”才選中。

        圖片效果:

         簡單示例,代碼如下,
        fenpage.aspx的代碼
    <%@ Page Language="C#" AutoEventWireup="true" CodeFile="fenpage.aspx.cs" Inherits="gridview_fenpage" %>

    <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd">
    <html xmlns="http://www.w3.org/1999/xhtml">
    <head runat="server">
        
    <title></title>

        
    <script language="javascript" type="text/javascript">    
        
    // 判斷多選是否與選中項(xiàng)(沒有選中的返回false)
        function slcNo_click()
        
    {
            
    if (document.form1.checkboxname.length)
            
    {
                
    for (var i=0;i<document.form1.checkboxname.length;i++)
                
    {
                    
    if(document.form1.checkboxname[i].checked)
                    
    {
                        
    return true;
                    }

                }

            }

            
    else
            
    {
                
    if(document.form1.checkboxname.checked)
                
    {
                    
    return true;
                }

            }

            alert(
    "請(qǐng)選擇后再操作!");
            
    return false;
        }

        
        
    // 鼠標(biāo)經(jīng)過改變行的顏色
        if (!objbeforeItem)
        
    {
            
    var objbeforeItem=null;
            
    var objbeforeItembackgroundColor=null;
        }
        
        
    function ItemOver(obj)
        
    {
            
    if(objbeforeItem)
            
    {
                objbeforeItem.style.backgroundColor 
    = objbeforeItembackgroundColor;
            }

            objbeforeItembackgroundColor 
    = obj.style.backgroundColor;
            objbeforeItem 
    = obj;
            obj.style.backgroundColor 
    = "#B9D1F3";     
        }

        
    //        
     
        
    // 多選的全選與取消
        function checkJs(boolvalue)
        
    {
            
    if(document.all.checkboxname.length>1)
            
    {
                
    for(var i=0;i<document.all.checkboxname.length;i++)
                
    {
                    document.all.checkboxname[i].checked 
    = boolvalue;            
                }

            }

            
    else
                document.all.checkboxname.checked 
    = boolvalue;
        }

        
    //
        
        
    // 只有全部選中時(shí)“全選”選中
        function SingleCheckJs()
        
    {
            
    var flag1=false;
            
    var flag2=false;
            
            
    if (document.form1.checkboxname.length)
            
    {
                
    for (var i=0;i<document.form1.checkboxname.length;i++)
                
    {
                    
    if(document.form1.checkboxname[i].checked)
                        flag1 
    = true;
                    
    else
                        flag2 
    = true;
                }

            }

            
    else
            
    {
                
    if(document.form1.checkboxname.checked)
                    flag1 
    = true;
                
    else
                    flag2 
    = true;
            }

            
            
    if(flag1==true&&flag2==false)
                document.getElementById(
    "chk").checked = true;
            
    else
                document.getElementById(
    "chk").checked = false;
        }

        
    //
        
    </script>
    </head>
    <body>
        
    <form id="form1" runat="server">
            
    <div>
                
    <table cellpadding="0" cellspacing="0" border="0" width="80%" style="font-size: 11px">
                    
    <tr>
                        
    <td align="center">
                            
    <asp:GridView ID="GridView1" runat="server" Width="100%" CellPadding="4" ForeColor="#333333"
                                AutoGenerateColumns
    ="False" AllowPaging="True" PageSize="12" BorderColor="Silver"
                                BorderStyle
    ="Solid" BorderWidth="1px" OnRowDataBound="GridView1_RowDataBound"
                                ShowFooter
    ="True" EmptyDataText="沒有數(shù)據(jù)記錄!!" AllowSorting="True" OnSorting="GridView1_Sorting">
                                
    <Columns>
                                    
    <asp:BoundField HeaderText="編號(hào)" DataField="id" Visible="False" />
                                    
    <asp:TemplateField HeaderText="&lt;input type='checkbox' id='chk' name='chk' onclick='checkJs(this.checked);'  /&gt;全選" FooterText="全選">
                                        
    <ItemTemplate>
                                            
    <input type="checkbox" id="checkboxname" name="checkboxname" value='<%# DataBinder.Eval(Container.DataItem, "id")%>' onclick='SingleCheckJs();' />
                                        
    </ItemTemplate>
                                    
    </asp:TemplateField>
                                    
    <asp:TemplateField HeaderText="單選" FooterText="單選">
                                        
    <ItemTemplate>
                                            
    <input type="radio" id="RadioName" name="RadioName" value='<%# Eval("id")%>' />
                                        
    </ItemTemplate>
                                    
    </asp:TemplateField>
                                    
    <asp:TemplateField HeaderText="自增列" FooterText="自增列">
                                        
    <ItemTemplate>
                                            
    <%# (Container.DataItemIndex+1).ToString()%>
                                        
    </ItemTemplate>
                                    
    </asp:TemplateField>
                                    
    <asp:BoundField HeaderText="姓名" FooterText="姓名" DataField="name" SortExpression="name" />
                                    
    <asp:BoundField HeaderText="身份證號(hào)" FooterText="身份證號(hào)" DataField="card" SortExpression="card" />
                                    
    <asp:BoundField HeaderText="價(jià)格" FooterText="價(jià)格" DataField="price" DataFormatString="{0:¥#,##0.00}"
                                        HtmlEncode
    ="False" SortExpression="price" />
                                    
    <asp:BoundField HeaderText="數(shù)字" FooterText="數(shù)字" DataField="price" DataFormatString="{0:0.00}"
                                        HtmlEncode
    ="False" SortExpression="price" />
                                    
    <asp:BoundField HeaderText="建立時(shí)間" FooterText="建立時(shí)間" DataField="createdate" DataFormatString="{0:yyyy年MM月dd日 hh時(shí)mm分ss秒}"
                                        HtmlEncode
    ="False" SortExpression="createdate" />
                                
    </Columns>
                                
    <RowStyle BackColor="#F7F6F3" ForeColor="#333333" />
                                
    <EditRowStyle BackColor="#999999" />
                                
    <SelectedRowStyle BackColor="#E2DED6" Font-Bold="True" ForeColor="#333333" />
                                
    <PagerStyle BackColor="#284775" ForeColor="White" HorizontalAlign="Center" />
                                
    <AlternatingRowStyle BackColor="White" ForeColor="#284775" />
                                
    <PagerSettings Visible="False" />
                                
    <FooterStyle Font-Bold="True" />
                                
    <HeaderStyle Font-Bold="False" Font-Italic="False" />
                            
    </asp:GridView>
                        
    </td>
                    
    </tr>
                    
    <tr>
                        
    <td align="center" style="height: 25px">
                            
    <asp:LinkButton ID="btnFirst" CommandArgument="first" OnClick="PagerButtonClick"
                                runat
    ="server">首 頁</asp:LinkButton>
                            
    <asp:LinkButton ID="btnPrev" CommandArgument="prev" OnClick="PagerButtonClick" runat="server">上一頁</asp:LinkButton>
                            
    <asp:LinkButton ID="btnNext" CommandArgument="next" OnClick="PagerButtonClick" runat="server">下一頁</asp:LinkButton>
                            
    <asp:LinkButton ID="btnLast" CommandArgument="last" OnClick="PagerButtonClick" runat="server">尾 頁</asp:LinkButton>
                            
    <asp:Label ID="LblCurrentIndex" runat="server"></asp:Label>
                            
    <asp:Label ID="LblPageCount" runat="server"></asp:Label>
                            
    <asp:Label ID="LblRecordCount" runat="server"></asp:Label></td>
                    
    </tr>
                    
    <tr>
                        
    <td>
                            
    <asp:Button ID="Button2" runat="server" Text="checkbox得到選擇的行" OnClick="Button2_Click">
                            
    </asp:Button>
                            
    <asp:Button ID="Button1" runat="server" Text="radio得到選擇的行" OnClick="Button1_Click"></asp:Button>
                        
    </td>
                    
    </tr>
                
    </table>
            
    </div>
        
    </form>
    </body>
    </html>

         fenpage.aspx.cs的代碼
    using System;
    using System.Data;
    using System.Configuration;
    using System.Collections;
    using System.Web;
    using System.Web.Security;
    using System.Web.UI;
    using System.Web.UI.WebControls;
    using System.Web.UI.WebControls.WebParts;
    using System.Web.UI.HtmlControls;
    using System.Data.SqlClient;

    public partial class gridview_fenpage : System.Web.UI.Page
    {
        
    protected void Page_Load(object sender, EventArgs e)
        
    {
            Button2.Attributes[
    "onclick"= "return slcNo_click();";
            GridViewBind(
    "");
        }


        
    private void GridViewBind(string Sqlsort)
        
    {
            
    string connStr = ConfigurationManager.ConnectionStrings["ConnString1"].ConnectionString;
            
    string SqlStr = "SELECT * FROM test01 where id<1000" + Sqlsort;
            DataSet ds 
    = new DataSet();
            
            
    try
            
    {
                SqlConnection conn 
    = new SqlConnection(connStr);
                
    if (conn.State.ToString() == "Closed") conn.Open();

                SqlDataAdapter da 
    = new SqlDataAdapter(SqlStr, conn);
                da.Fill(ds, 
    "test01");            
                
    if (conn.State.ToString() == "Open") conn.Close();

                GridView1.DataSource 
    = ds.Tables[0].DefaultView;
                GridView1.DataBind();

                LblCurrentIndex.Text 
    = "第 " + (GridView1.PageIndex + 1).ToString() + " 頁";
                LblPageCount.Text 
    = "共 " + GridView1 .PageCount.ToString()+ " 頁";
                LblRecordCount.Text 
    = "總共 "+ds.Tables[0].Rows.Count.ToString()+" 條";
                
    if (ds.Tables[0].Rows.Count == 0)
                
    {
                    btnFirst.Visible 
    = false;
                    btnPrev.Visible 
    = false;
                    btnNext.Visible 
    = false;
                    btnLast.Visible 
    = false;

                    LblCurrentIndex.Visible 
    = false;
                    LblPageCount.Visible 
    = false;
                    LblRecordCount.Visible 
    = false;
                }

                
    else if (GridView1.PageCount == 1)
                
    {
                    btnFirst.Visible 
    = false;
                    btnPrev.Visible 
    = false;
                    btnNext.Visible 
    = false;
                    btnLast.Visible 
    = false;
                }


                
    // 計(jì)算生成分頁頁碼,分別為:"首 頁" "上一頁" "下一頁" "尾 頁"
                btnFirst.CommandName = "1";
                btnPrev.CommandName 
    = (GridView1.PageIndex == 0 ? "1" : GridView1.PageIndex.ToString());

                btnNext.CommandName 
    = (GridView1.PageCount == 1 ? GridView1.PageCount.ToString() : (GridView1.PageIndex + 2).ToString());
                btnLast.CommandName 
    = GridView1.PageCount.ToString();
                
    //
            }

            
    catch(Exception ex)
            
    {
                Response.Write(
    "數(shù)據(jù)庫錯(cuò)誤,錯(cuò)誤原因:"+ex.Message);
                Response.End();
            }

        }

        
    protected void PagerButtonClick(object sender, EventArgs e)
        
    {
            GridView1.PageIndex 
    = Convert.ToInt32(((LinkButton)sender).CommandName)-1;
            GridViewBind(
    "");        
        }


        
    protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)
        
    {
            e.Row.Attributes[
    "onmouseover"= "ItemOver(this)";
        }


        
    protected void Button2_Click(object sender, EventArgs e)
        
    {
            
    string str=""
            
    string []ckb=null

            str
    =Request.Form.Get("checkboxname"); 
            ckb
    =str.Split(new char[]{','}); 

            Response.Write(
    "直接在頁面中得到的值為:"+str+"<br>"); 

            Response.Write(
    "處理后存放在數(shù)組中,如下:<br>"); 
            
    for(int i=0;i<ckb.Length;i++
            

                Response.Write(
    "ckb["+i+"]的值為:"+ckb[i]+"<br>"); 
            }
     
        }

        
    protected void Button1_Click(object sender, EventArgs e)
        
    {
            Response.Write(Request.Form.Get(
    "RadioName"));
        }

        
    protected void GridView1_Sorting(object sender, GridViewSortEventArgs e)
        
    {
            
    string sql = "";

            
    if (ViewState["SortDirection"== null || ViewState["SortDirection"].ToString().CompareTo(""== 0)
            
    {
                ViewState[
    "SortDirection"= " desc";
            }

            
    else
                ViewState[
    "SortDirection"= "";

            sql 
    = " order by " + e.SortExpression + ViewState["SortDirection"];
            
            GridViewBind(sql);
        }

    }


        數(shù)據(jù)庫中表的生成代碼:
    CREATE TABLE [dbo].[test01] (
        
    [id] [decimal](180IDENTITY (11NOT NULL ,
        
    [name] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
        
    [card] [varchar] (50) COLLATE Chinese_PRC_CI_AS NULL ,
        
    [createdate] [datetime] NULL 
    ON [PRIMARY]
    GO

    ALTER TABLE [dbo].[test01] ADD 
        
    CONSTRAINT [DF_test01_createdate] DEFAULT (getdate()) FOR [createdate],
        
    CONSTRAINT [PK_test01] PRIMARY KEY  CLUSTERED 
        (
            
    [id]
        )  
    ON [PRIMARY] 
    GO

     

    評(píng)論

    # re: GridView的自定義分頁,單選、多選、排序、自增列的簡單應(yīng)用   回復(fù)  更多評(píng)論   

    2013-06-25 16:17 by zhangsan
    這個(gè)排序有一點(diǎn)問題,就是點(diǎn)一下之后是升序排序,再點(diǎn)一下之后是降序,然后再點(diǎn)的話就一直是降序了。
    主站蜘蛛池模板: 亚洲美女免费视频| 亚洲成Av人片乱码色午夜| 亚洲色大成网站www尤物| 182tv免费视视频线路一二三| 日日噜噜噜噜夜夜爽亚洲精品| 国产午夜亚洲精品不卡| 成人免费视频试看120秒| 亚洲国产精品人久久电影| 久爱免费观看在线网站| 亚洲熟妇丰满多毛XXXX| 国产免费A∨在线播放| 亚洲成人国产精品| 国产一区二区三区亚洲综合| 破了亲妺妺的处免费视频国产| 国产精品亚洲午夜一区二区三区| 99re免费99re在线视频手机版| 亚洲av永久无码精品漫画| 在线免费观看h片| 精品亚洲一区二区| 水蜜桃视频在线观看免费播放高清| 精品国产人成亚洲区| 一级特黄aaa大片免费看| 亚洲阿v天堂在线2017免费| 黄页视频在线观看免费| 免费人成视频x8x8入口| 污视频网站在线观看免费| 亚洲第一区在线观看| 日韩精品无码免费视频| 亚洲伦乱亚洲h视频| 国产精品成人69XXX免费视频| 中文字幕亚洲专区| 韩日电影在线播放免费版| 亚洲精品无码久久久久去q | A级毛片内射免费视频| 久久亚洲精品专区蓝色区| 在线不卡免费视频| 国产精品亚洲色图| 久久久久亚洲AV成人网人人网站| 香蕉视频在线免费看| 亚洲av午夜福利精品一区人妖| 久久国产精品免费专区|