AllowSorting="True" OnSorting="gridvie " /> 久久影院资源网,av综合网站,美女视频一区在线观看

色尼玛亚洲综合影院,亚洲3atv精品一区二区三区,麻豆freexxxx性91精品,欧美在线91

Gridview自定義排序且顯示上下箭頭

        實現功能:單擊Gidview列名按該列升序或降序排列,且在排序列上顯示向上來向下箭頭示意圖片

        //設置Gridview的AllowSorting屬性值為true,即允許排序
        AllowSorting="True" OnSorting="gridview1_Sorting" OnRowCreated="gridview1_RowCreated" >

        //為要排序的列加上SortExpression屬性,其值為綁定的字段,如:
        SortExpression="ID">

        //添加Sorting和RowCreated事件
        OnSorting="gridview1_Sorting" OnRowCreated="gridview1_RowCreated" >

       后臺代碼,創建如下方法:

         //設置默認表達式和排序順序,放到page_load事件中
        public void SetSorting()
        {
            ViewState["SortExpression"] = "ID";
            ViewState["SortDirection"] = SortDirection.Descending;

        }

        //獲取排序列索引
        private int GetSortColumnIndex()
        {
            foreach (DataControlField field in gridview1.Columns)
            {
                if (field.SortExpression == ViewState["SortExpression"].ToString().Trim())
                    return gridview1.Columns.IndexOf(field);
            }
            return -1;
        }

        //添加排序圖片
        private void AddSortImage(int columnIndex, GridViewRow headerRow)
        {
            Image sortImage = new Image();
            if ((SortDirection)ViewState["SortDirection"] == SortDirection.Ascending)
            {
                sortImage.ImageUrl ="向上箭頭圖片的路徑";
            }
            else
            {
                sortImage.ImageUrl = "向下箭頭圖片的路徑";
            }

            headerRow.Cells[columnIndex].Controls.Add(sortImage);
        }
       
     
//Gridview的Sorting事件 
      protected void gridview1_Sorting(object sender, GridViewSortEventArgs e)
     {
        if (ViewState["SortExpression"].ToString().Trim() == e.SortExpression)
        {
            if ((SortDirection)ViewState["SortDirection"] == SortDirection.Ascending)
                ViewState["SortDirection"] = SortDirection.Descending;
            else
                ViewState["SortDirection"] = SortDirection.Ascending;
        }
        else
        {
            ViewState["SortExpression"] = e.SortExpression;
            ViewState["SortDirection"] = SortDirection.Descending;
        }
        
        //你綁定Gridview數據的函數
        GvBind();
    }
    //Gridview的RowCreated事件 
    protected void gridview1_RowCreated(object sender, GridViewRowEventArgs e)
    {
        if (e.Row.RowType == DataControlRowType.Header)
        {
            int sortColumnIndex = GetSortColumnIndex();

            if (sortColumnIndex != -1)
                AddSortImage(sortColumnIndex, e.Row);
        }
    }

   最后,還要修改GvBind()函數中的SQL語句

   //將SortDirection轉化為SQL語句中的ASC和DESC  

   string sortStr = ((SortDirection)ViewState["SortDirection"] == SortDirection.Descending ? "DESC" : "");

   在原SQL語句后加上order by語句: "order by "+ ViewState["SortExpression"]+" "+sortStr

NET技術Gridview自定義排序且顯示上下箭頭,轉載需保留來源!

鄭重聲明:本文版權歸原作者所有,轉載文章僅為傳播更多信息之目的,如作者信息標記有誤,請第一時間聯系我們修改或刪除,多謝。

主站蜘蛛池模板: 长沙市| 鄂托克旗| 中阳县| 普安县| 凤山市| 叙永县| 山东省| 襄城县| 红桥区| 古交市| 鲁山县| 广南县| 米林县| 加查县| 巩义市| 如皋市| 正宁县| 文成县| 安图县| 合水县| 浙江省| 晋江市| 安顺市| 遵义县| 江都市| 阳泉市| 梨树县| 福州市| 怀安县| 荃湾区| 阜平县| 荔波县| 图们市| 库尔勒市| 灌南县| 永平县| 樟树市| 碌曲县| 武安市| 从化市| 沙坪坝区|