我正在开发一个包含两个 RadGrid 的用户控件。当用户在网格 1 中选择一行时,页面回发。此时,我创建了一个 Datatable 和 DataRow 并将其添加到网格 2 的数据源中。
我总体上遇到的问题是每次回发页面时数据表都会丢失并重新创建。因此,我尝试使用属性将数据表保存在视图状态中,但这似乎没有帮助。我对使用属性句号很陌生,所以我的代码可能是错误的。
我的解决方案:
public class DynamicDocumentSelectorWebUITypeEditor : Telerik.Cms.Web.UI.WebUITypeEditor<string>
{
private System.Data.DataTable _oDataTable;
public System.Data.DataTable getTable() {
System.Data.DataTable oDataTable = new System.Data.DataTable();
oDataTable.Columns.Add(new System.Data.DataColumn("DocumentID", typeof(string)));
oDataTable.Columns.Add(new System.Data.DataColumn("DocumentName", typeof(string)));
oDataTable.Columns.Add(new System.Data.DataColumn("DocumentExtension", typeof(string)));
return oDataTable;
}
public System.Data.DataTable oDataTable {
get {
object o = this.ViewState["DataTable"];
if(o == null) {
return _oDataTable;
}
return (System.Data.DataTable)o;
}
set {
this._oDataTable = value;
this.ViewState["DataTable"] = value;
}
}
protected override void CreateChildControls() {
base.CreateChildControls();
if (this.oDataTable == null) {
this.oDataTable = getTable();
}
}
//the following function is executed when a row in grid 1 is selected
protected void GridDocumentsInLibrary_SelectedIndexChanged(object sender, EventArgs e) {
//loop through each selected row
foreach (Telerik.Web.UI.GridDataItem oItem in GridDocumentsInLibrary.SelectedItems) {
//System.Data.DataTable oDt = this.oDataTable;
foreach (System.Data.DataRow oDataRow in this.oDataTable.Rows) {
//check whether the row already exists in the datatable
//if (oDataRow["DocumentID"] != oItem["DocumentID"].Text) {
System.Data.DataRow dr = this.oDataTable.NewRow();
dr["DocumentID"] = oItem["DocumentID"].Text;
dr["DocumentName"] = oItem["DocumentName"].Text;
dr["DocumentExtension"] = oItem["DocumentExtension"].Text;
this.oDataTable.Rows.Add(dr);
//}
}
}
//set datasource of second grid
GridSelectedDocuments.DataSource = this.oDataTable;
GridSelectedDocuments.DataBind();
}
}
我这样做完全错了吗?任何人都可以帮忙吗?
在此先感谢希格斯