我创建了一个自定义 gridview 控件并将其导出到一个 dll 中,以便我可以重用它。在 dll 中,我创建了一个函数来获取数据源,我试图从那里填充一个下拉列表,但失败了。
所以在我的网站上我有这个
public partial class _Management : System.Web.UI.Page
{
public class _ManagementHelper
{
public int ID;
public string CompanyName;
public string ResourceName;
}
protected void Page_Load(object sender, EventArgs e)
{
ucGridViewEx.DataSource = ucGridViewEx_Source();
ucGridViewEx.DataBind();
}
private List<dynamic> ucGridViewEx_Source()
{
var source = dl.ComapniesResources.Select(x => new _ManagementHelper
{
ID = x.ResourceID,
CompanyName = x.Supplier1.SupplierName,
ResourceName = x.Name
});
return ucGridViewEx.GridViewExDataSource(source);
}
然后dll里面的自定义控件有这个相关代码
public List<dynamic> GridViewExDataSource<T>(IQueryable<T> query)
{
foreach (var column in this.Columns)
{
var gridViewExColumn = column as ColumnEx;
if (gridViewExColumn != null
&& gridViewExColumn.SearchType == SearchTypeEnum.DropDownList)
{
gridViewExColumn.DropDownDataSource = query.GetDropDownDataSource(gridViewExColumn.DataField);
}
}
return ((IQueryable<dynamic>)query).ToList<dynamic>();
}
函数 GetDropDownDataSource() 位于与 gridview 相同的 dll 内的另一个扩展类中
internal static List<ListItem> GetDropDownDataSource<T>(this IQueryable<T> query,
string dataField)
{
var ddlSource = new List<ListItem>();
// x =>
var xParameter = Expression.Parameter(typeof(T), "x");
// x.Property
var propery = typeof(T).GetProperty(dataField);
// x => x.Property
var columnLambda = Expression.Lambda(Expression.Property(xParameter, propery), xParameter);
return ddlSource;
}
代码在我将值分配给 columnLambda 时失败,因为属性为空,而不是因为它不存在(它确实存在),因为没有获得任何属性。我尝试使用 GetProperties() 并且没有返回任何内容。
奇怪的是,自从我移至 DataSource 以选择 _ManagementHelper 后发生这种情况。我之前在 ucGridViewEx_Source() 上使用了动态( Select(x => new {}) ),并且效果很好。请不要提供继续使用动态的解决方案,因为我需要允许使用动态和使用自定义对象这两种类型。