所以我有一个 Dev Express 网格视图,它在后面的 cod 中绑定到它的数据源。这个数据源只是一个普通的 ORM 对象,它工作正常。当我在记录上点击编辑时,我试图让其中一列变成一个组合框。到目前为止,我已经能够使用以下代码完成此操作:
<dx:GridViewDataComboBoxColumn Caption="Invoice/Return#"
FieldName="InvoiceNumber" ToolTip="Invoice/Return#"
VisibleIndex="4" Settings-AllowSort="False" Name="cmbOtherCostsInvoice">
<PropertiesComboBox ClientInstanceName="cmbOtherCostsInvoice">
</PropertiesComboBox>
<Settings AllowSort="False"></Settings>
</dx:GridViewDataComboBoxColumn>
我拦截行编辑事件并像这样绑定组合框:
protected void gridViewOtherCost_StartRowEditing(object sender, DevExpress.Web.Data.ASPxStartRowEditingEventArgs e)
{
var allInvoices = GetCollection<PurchaseOrderInvoice>("PURCHASE_ORDER_KEY = " + purchaseOrder.Key);
foreach (var item in allInvoices)
{
(gridViewOtherCost.Columns[4] as GridViewDataComboBoxColumn).PropertiesComboBox.Items.Add(item.InvoiceNumber, item.InvoiceKey);
}
}
所以这可行,但我想让组合框成为多列。我在整个应用程序中还有一些其他的多列,但没有一个嵌套在 gridview 中,所以我不知道该怎么做。这是独立多列组合框的示例。
<dx:ASPxComboBox ID="cmbAssetPart" runat="server" CssClass="requiredfield" Width="100px
ValueField="AssetKEY" TextField="AssetID" TextFormatString="{0}">
<Columns>
<dx:ListBoxColumn FieldName="AssetID" Name="AssetID" />
<dx:ListBoxColumn FieldName="EntityName" Name="Entity" />
</Columns>
知道如何让它发挥作用吗?