这是我的代码:代码使用第一个+第二个参数,当我添加第三个参数时,它不再编译,我需要更改什么才能使其正常工作?
/// <summary>
/// Binds all dataObjects e.g. IPersonList, IDepartmentList, ITopicList... and creates a visual list of elements to display in the ElementTextBox
/// </summary>
/// <typeparam name="T">Type of dataObject in the dataObjects list</typeparam>
/// <typeparam name="TProperty">value for the Type specified by the TResult paramter</typeparam>
/// <param name="dataObjects">entity from database the user wants to show in the ElementTextBox</param>
/// <param name="selectorDisplayMember">The property like FirstName that is shown as the elements text</param>
/// <param name="selectorSortMember">The property like SortId that is used to pre-sort the dataObjects so the elements appear in the order before they were saved</param>
public void BindElements<T, TProperty>(IEnumerable<T> dataObjects, Func<T, TProperty> selectorDisplayMember, Func<T, TProperty> selectorSortMember)
{
if (dataObjects != null)
{
var sortedDataObjects = from d in dataObjects
orderby selectorSortMember(d) ascending
select d;
Paragraph para = new Paragraph();
foreach (T item in dataObjects)
{
TProperty displayMemberValue = selectorDisplayMember(item);
InlineUIContainer uiContainer = ElementList.CreateElementContainer(displayMemberValue);
para.Inlines.Add(uiContainer);
}
FlowDocument flowDoc = new FlowDocument(para);
ElementList.Document = flowDoc;
}
}
这有效:
ElementUserControl.BindElements(customers, c => c.CustomerId);
但是当我添加第三个参数时:
ElementUserControl.BindElements(customers, c => c.CustomerId, c => c.SortId);
它不再起作用了吗?
最佳答案
问题在于您引入的歧义,因为第二个和第三个参数都可以推断 TProperty
。您可能想尝试引入第三个泛型类型参数,以便您拥有适合您的用例的 TDisplayProperty
和 TSortProperty
。
关于c# - 无法推断 C# 中的类型,必须显式设置它吗?,我们在Stack Overflow上找到一个类似的问题:https://stackoverflow.com/questions/4294443/