DataGrid DropDownList 相關處理函數

#region DataGrid 相關處理函數

  /// <summary>
  /// 根據綁定的列的名字,獲得在DataGrid中的Index值
  /// </summary>
  /// <param name="dgcc">DataGridColumnCollection</param>
  /// <param name="FieldName">綁定列的字段名</param>
  /// <returns>Int >0 在DataGrid中的Index,-1:沒有找到</returns>
  public static int DataGrid_FindColumnIndex(DataGridColumnCollection dgcc, string FieldName)

  {
   string temp;
   DataGridColumn column;
   BoundColumn boundColumn;
   int i;
   FieldName = FieldName.ToUpper();
   for(i=0;i<dgcc.Count;i++)
   {
    column = dgcc[i];
    if(column is BoundColumn)
    {
     boundColumn = (BoundColumn)column;
     temp = boundColumn.DataField.ToUpper();
     if(temp==FieldName)
      return i;
    }
   }
   return -1;
  }

  /// <summary>
  /// 根據綁定的列的名字,獲得在DataGrid中的Index值
  /// </summary>
  /// <param name="dg">DataGrid</param>
  /// <param name="FieldName">綁定列的字段名</param>
  /// <returns>Int >0 在DataGrid中的Index,-1:沒有找到</returns>
  public static int DataGrid_FindDataGridColumnIndex(DataGrid dg, string FieldName)
  {
   string temp;
   DataGridColumn column;
   BoundColumn boundColumn;
   int i;
   FieldName = FieldName.ToUpper();
   for(i=0;i<dg.Columns.Count;i++)
   {
    column = dg.Columns[i];
    if(column is BoundColumn)
    {
     boundColumn = (BoundColumn)column;
     temp = boundColumn.DataField.ToUpper();
     if(temp==FieldName)
      return i;
    }
   }
   return -1;
  }

  //當DataGrid中記錄數發生改變時,避免越界
  /// <summary>
  /// 獲得DataGrid的當前頁數
  /// </summary>
  /// <param name="currentPageIndex">原來DataGrid的當前頁碼</param>
  /// <param name="pageSize">DataGrid每頁顯示的記錄數</param>
  /// <param name="rowCount">DataGrid的記錄數</param>
  /// <returns>返回處理後的頁碼</returns>
  public static int DataGrid_GetCurrentPageIndex(int currentPageIndex,int pageSize,int rowCount)
  {
   int pageIndex;
   if(pageSize==0) return 1;

   pageIndex=(rowCount-1)/pageSize;
   if(pageIndex < 0) return 0; //當rowCount=0時,會返回-1,頁面出錯
   if(currentPageIndex > pageIndex)
    return pageIndex;
   else
    return currentPageIndex;
  }
  /*
   * 使用示例代碼
   *
   * /// <summary>
  /// 邦定列表
  /// </summary>
  private void BindDataSource()
  {                                               
   try
   {
    
    IDataGrid1.DataSource = DS;
    IDataGrid1.PageSize = 10;
    IDataGrid1.CurrentPageIndex = DataGrid_GetCurrentPageIndex(IDataGrid1.CurrentPageIndex,IDataGrid1.PageSize,DS.Tables[0].Rows.Count);
    IDataGrid1.DataBind();   
   }
   catch
   {;}
  }
  
  /// <summary>
  /// 分頁操作
  /// </summary>
  /// <param name="source"></param>
  /// <param name="e"></param>
  private void IDataGrid1_PageIndexChanged(object source, System.Web.UI.WebControls.DataGridPageChangedEventArgs e)
  {
   IDataGrid1.CurrentPageIndex = e.NewPageIndex;
   BindDataSource(); 
  }

  /// <summary>
  /// 選擇操作
  /// </summary>
  /// <param name="sender"></param>
  /// <param name="e"></param>
  private void IDataGrid1_SelectedIndexChanged(object sender, System.EventArgs e)
  {
   int idIndex = DataGrid_FindColumnIndex(IDataGrid1.Columns,"ID");
   
   if(idIndex >= 0 )
   {
    Response.Redirect("Default.aspx?ID=" + IDataGrid1.SelectedItem.Cells[idIndex].Text,true);
   }
  }
   *
   * */
  #endregion

  #region DropDownList 相關處理函數

  /// <summary>
  /// 根據綁定的列的Value值,獲得在DropDownList中的Index值
  /// </summary>
  /// <param name="lic">ListItemCollection</param>
  /// <param name="bandValue">綁定列的字段名</param>
  /// <returns>Int >0 在DropDownList中的Index,-1:沒有找到</returns>
  public static int DropDownList_FindListItemIndex(ListItemCollection lic, string bandValue)
  {
   string temp;
   bandValue = bandValue.ToUpper();
   for(int i=0;i<lic.Count;i++)
   {
    temp = lic[i].Value.ToUpper();
    if(temp == bandValue)
    {
     return i;
    }
   }
   return -1;
  }

  /*
   * 使用示例
   *
   * /// <summary>
  /// 獲取DropDownList列表SelectIndex
  /// </summary>
  /// <param name="listItemCol"></param>
  /// <param name="sValue"></param>
  /// <returns></returns>
  private int BindDropDownListSelectIndex(ListItemCollection listItemCol, string sValue)
  {
   int DDLSelectIndex = DropDownList_FindListItemIndex(listItemCol,sValue);
   if(DDLSelectIndex != -1)
   {
    return DDLSelectIndex;
   }
   else
   {
    return 0;
   }
  }
   *
   * */
  #endregion

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章