RadGrid -批量编辑每个列的多个编辑模板
本文关键字:编辑 -批 RadGrid | 更新日期: 2023-09-27 18:12:25
我可以根据背后代码的数据创建不同的每列控件,并且它可以工作。
我想在代码后面的每一行创建不同的控件。例子:
<EditMode>
ColumnA ColumnB
Row I: RadComboBox RadComboBox
Row II: RadNumericTextBox RadNumericTextBox
Row III: CheckBox CheckBox
...
问题是Rad-grid批处理模式在每个列的一个编辑模板中只有一个控件,这意味着所有行都具有相同的编辑模板和控件。
this I can Do
ColumnA (RadComboBox) ColumnB(RadNumericTextBox)
Row I: RadComboBox RadNumericTextBox
Row II: RadComboBox RadNumericTextBox
Row III: RadComboBox RadNumericTextBox
是否有可能有多个编辑模板每列或什么是我的替代品?
您可以在网格的ItemDataBound事件中为单元格添加控件。在下面的示例中,我将单元格的内容更改为您列出的控件类型,而不是仅显示其默认文本ID。你也可以根据你的情况做同样的事情。我用rgTest_OnNeedDataSource
方法中的测试数据填充示例网格,然后应用rgTest_ItemDataBound
方法中的更改。
aspx:
<telerik:RadGrid ID="rgTest" runat="server" PageSize="10" GridLines="None" AccessKey="0" Skin="Office2007"
OnNeedDataSource="rgTest_OnNeedDataSource" OnItemDataBound="rgTest_ItemDataBound" AllowFilteringByColumn="true" AllowPaging="true" AllowSorting="true" AutoGenerateColumns="false" ImagesPath="~/Skins/Office2007/Grid/Images">
<MasterTableView>
<Columns>
<telerik:GridBoundColumn UniqueName="ID" DataField="ID" SortExpression="ID" HeaderText="ID" HeaderStyle-Width="40px" FilterControlWidth="40px" AllowSorting="true" AllowFiltering="true" AutoPostBackOnFilter="false" ShowFilterIcon="true" />
<telerik:GridBoundColumn UniqueName="Value" DataField="Value" SortExpression="Value" HeaderText="Value" HeaderStyle-Width="80px" FilterControlWidth="40px" AllowSorting="true" AllowFiltering="true" AutoPostBackOnFilter="false" ShowFilterIcon="true" />
</Columns>
</MasterTableView>
</telerik:RadGrid>
aspx.cs:
protected void rgTest_OnNeedDataSource(object source, GridNeedDataSourceEventArgs e)
{
DataTable batchChecks = new DataTable("checksRandomName");
batchChecks.Columns.Add("ID");
batchChecks.Columns.Add("Value");
batchChecks.Rows.Add(new ArrayList() { "1", "ABC" }.ToArray());
batchChecks.Rows.Add(new ArrayList() { "2", "BCD" }.ToArray());
batchChecks.Rows.Add(new ArrayList() { "3", "CDE" }.ToArray());
batchChecks.Rows.Add(new ArrayList() { "4", "DEF" }.ToArray());
DataSet dsBatch = new DataSet("rcBatch");
dsBatch.Tables.Add(batchChecks);
rgTest.VirtualItemCount = dsBatch.Tables.Count;
rgTest.DataSource = dsBatch;
}
protected void rgTest_ItemDataBound(object sender, Telerik.Web.UI.GridItemEventArgs e)
{
if (e.Item is GridDataItem)
{
GridDataItem item = (GridDataItem)e.Item;
TableCell cell = item["Id"];
switch (cell.Text)
{
case "1":
cell.Controls.Add(new RadComboBox());
break;
case "2":
cell.Controls.Add(new RadNumericTextBox());
break;
case "3":
cell.Controls.Add(new System.Web.UI.WebControls.CheckBox());
break;
}
}
}