4

我试图找出任何方法来检索特定类实例的某些元素,以便在我试图对其执行一些维护的下拉列表中使用。目标是选择所有联系人并将其分配给键/值对字符串数组(联系人是公司的相关实体,具体而言,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();
    }

虽然默认情况下不会在选择列表中显示第一个“主要”联系人。我希望第一个 isPrimary=1 联系人成为选择列表中的第一个选择。我很确定 InitContactList 中的 firstOrDefault 变量需要让密钥执行 .contains(“true”) 以外的其他操作。任何帮助将不胜感激。先感谢您。

4

1 回答 1

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 或更高版本,您可以轻松地将其更改为静态实用程序方法。

于 2012-11-06T18:22:57.797 回答