我正在试图找出任何方法来检索特定类实例的某些元素,以便在我尝试执行某些维护的下拉列表中使用。目标是选择并将所有联系人分配给键/值对字符串数组(联系人是公司的相关实体,特别是1:n关系--1公司有多个联系人)然后选择第一个联系人的名字和姓氏属性超出布尔类属性Primary设置为True的顺序。
public class Company
{
public string Name { get; set; }
public virtual ICollection<Contact> Contacts { get; set; }
}
public class Contact
{
public string FirstName { get; set; }
public string LastName { get; set; }
public bool IsPrimary { get; set; }
}
以下代码:
private Company CreateViewModel(Company company)
{
var contacts = _contactService.CompanyContacts(company);
}
public Dictionary<string, string> CompanyContacts(Company company)
{
var results = new Dictionary<string, string>();
foreach (var contact in company.Contacts)
{
var key = string.Format("{0} {1}|{2}", contact.FirstName, contact.LastName, contact.IsPrimary());
var val = string.Format("{0} {1}|{2}", contact.FirstName, contact.LastName, contact.IsPrimary());
if (results.ContainsKey(key)) continue;
results.Add(key, val);
}
return results;
}
public void InitContactList(Dictionary<string, string> contacts)
{
var firstOrDefault = contacts
.Where(x => x.Key.Contains("true"))
.Select(x => x.Value)
.FirstOrDefault();
var selectedContact = contacts.FirstOrDefault().Value;
if (firstOrDefault != null)
{
var selectedContact = firstOrDefault;
ContactList = new SelectList(contacts, "Key", "Value")
.SelectByText(selectedContact.ToString()).ToList();
}
ContactList = new SelectList(contacts, "Key", "Value")
.SelectByText(selectedContact.ToString()).ToList();
}
默认情况下不会在select-list中显示第一个'is primary'联系人。我希望第一个isPrimary = 1联系人成为选项列表中的第一个选择。我很确定InitContactList中的firstOrDefault变量需要让键做除.contains之外的其他操作(“true”)任何帮助都将不胜感激。 提前谢谢。
答案 0 :(得分:1)
使用代码中的内容突出显示的是
x.Key.Contains("true")
一部分。这与区分大小写进行字符串比较。您对字典项的值将布尔值转换为值为“False”或“True”的字符串。最简单的解决方案是将你的linq where语句更改为:
x.Key.Contains("True")
但这可能不是最佳解决方案,因为它在字符串的任何部分中查找“True”,并且仍然区分大小写。 “更好”的解决方案是使用允许不区分大小写的比较方法。我在项目中使用了几次的扩展方法是这样的:
public static bool Contains(this string source, string toCheck, StringComparison comp)
{
if (string.IsNullOrEmpty(toCheck) || string.IsNullOrEmpty(source))
return false;
return source.IndexOf(toCheck, comp) >= 0;
}
您可以将where语句更改为:
x.Key.Contains("True", StringComparison.InvariantCultureIgnoreCase)
如果您不使用.NET 3.0或更高版本,则可以轻松地将其更改为静态实用程序方法。