一個帶checkbox的webcontrol
2024-07-21 02:16:49
供稿:網友
謝謝大家,無以回報,貼點兒東西吧。
剛才看到下邊不少人問給datatable或table添加一個選擇框,實際上如果你可以自己做一個webcontrol來實現這個功能,下邊是我做的一個帶checkbox的webcontrol,由于注釋比較全,所以我就不加說明了。
using system;
using system.collections ;
using system.web.ui.webcontrols ;
using system.web.ui ;
namespace bigeagle.web.webcontrols
{
/// <summary>
/// <br>自定義控件,帶選擇框的table</br>
/// <br>author: [email protected]</br>
/// <br>date: 2001/10/10</br>
/// <br>history: 2001/10/10 finished</br>
/// </summary>
/// <remarks>
/// 繼承system.web.ui.webcontrols.table,增加checkedvalue屬性,
/// 用于多項選擇的場合,返回被選擇的checktablerow的值的數組
/// </remarks>
public class checktable : system.web.ui.webcontrols.table
{
/// <summary>
/// 是否使用checkbox
/// </summary>
/// <remarks>如果為false則不顯示checkbox</remarks>
private bool m_busecheck ;
/// <summary>
/// ֵ選擇數組
/// </summary>
/// <remarks>返回選定的checktablerow的值</remarks>
private arraylist m_arrcheckedvalue ;
/// <summary>
/// 取得選擇數組的屬性
/// </summary>
/// <remarks>只讀屬性</remarks>
public arraylist checkedvalue
{
get
{
return this.m_arrcheckedvalue ;
}
}
/// <summary>
/// 存取是否使用checkbox的屬性
/// </summary>
public bool usecheck
{
get
{
return this.m_busecheck ;
}
set
{
this.m_busecheck = value ;
}
}
/// <summary>
/// 構造函數
/// </summary>
public checktable()
{
this.m_arrcheckedvalue = new arraylist() ;
this.m_busecheck = true ;
}
/// <summary>
/// 重載父類方法
/// </summary>
/// <param name="e"></param>
protected override void onload(system.eventargs e)
{
if(this.m_busecheck)
{
try
{
for(int i = 0 ; i < this.rows.count ; i++)
{
checktablerow ctr = (checktablerow)this.rows[i] ;
checkbox cb = (checkbox)ctr.findcontrol(ctr.value) ;
if(cb.checked)
{
this.m_arrcheckedvalue.add(ctr.value) ;
}
}
}
catch(exception) //一般出現異常是因為有重復的控件id
{
throw(new exception("出現重復的控件id")) ;
}
}
}//end method
}//end class
}//end method
using system;
using system.web.ui.webcontrols ;
using system.web.ui ;
namespace bigeagle.web.webcontrols
{
/// <summary>
/// <br>自定義控件,帶選擇框的tablerow</br>
/// <br>author: [email protected]</br>
/// <br>date: 2001/10/10</br>
/// <br>history: 2001/10/10 finished</br>
/// </summary>
/// <remarks>
/// 繼承system.web.ui.webcontrols.tablerow , 作為自定義控件checktable的tablerow,
/// 與tablerow相比,增加一個值屬性和一個checkbox
/// </remarks>
public class checktablerow : system.web.ui.webcontrols.tablerow
{
/// <summary>
/// 值
/// </summary>
private string m_strvalue ;
/// <summary>
/// 是否使用checkbox
/// </summary>
/// <remarks>如果為false則不顯示checkbox</remarks>
private bool m_busecheck ;
/// <summary>
/// 存取value的屬性
/// </summary>
public string value
{
get
{
return this.m_strvalue ;
}
set
{
this.m_strvalue = value ;
}
}
/// <summary>
/// 存取是否使用checkbox的屬性
/// </summary>
public bool usecheck
{
get
{
return this.m_busecheck ;
}
set
{
this.m_busecheck = value ;
}
}
/// <summary>
/// 構造函數
/// </summary>
public checktablerow()
{
this.m_strvalue = "" ;
this.m_busecheck = true ;
}
/// <summary>
/// 重載父類方法
/// </summary>
/// <returns>控件結合</returns>
/// <remarks>增加一個帶有checkbox的td</remarks>
protected override system.web.ui.controlcollection createcontrolcollection()
{
controlcollection cc = base.createcontrolcollection() ;
if(this.m_busecheck)
{
tablecell td = new tablecell() ;
td.backcolor = this.backcolor ;
td.verticalalign = verticalalign.top ;
checkbox cb = new checkbox() ;
cb.id = this.m_strvalue ;
td.controls.add(cb) ;
cc.add(td) ;
}
return cc ;
}//end method
}//end class
}//end namespace