26

我想在一个选定的列表中添加 EF 模型人员的姓名和姓氏。我试过这个:

public ActionResult Insert()
        {
            ViewData["accountlist"] = new SelectList(time.Anagrafica_Dipendente.ToList(), "ID_Dipendente", "Surname Name", null);             
            Giustificativi g = new Giustificativi();
            return View(g);
        }

但是 VS 返回一个错误,因为没有一个名为“姓氏”的属性。如何在选择列表标签中连接姓名和姓氏?

谢谢

4

4 回答 4

57

你可以这样做:

ViewData["accountlist"] = 
    new SelectList((from s in time.Anagrafica_Dipendente.ToList() select new { 
        ID_Dipendente=s.ID_Dipendente,
        FullName = s.Surname + " " + s.Name}), 
        "ID_Dipendente", 
        "FullName", 
        null);
于 2010-05-03T14:36:13.993 回答
36

添加一个新属性time.Anagrafica_Dipendente,将表示两个属性的串联:

public string Fullname 
{
    get 
    {
        return string.Format("{0} {1}", Surname, Name);
    }
}

然后使用这个:

ViewData["accountlist"] = new SelectList(
    time.Anagrafica_Dipendente.ToList(), 
    "ID_Dipendente", 
    "Fullname", 
    null
); 

更新:从 C# 6.0 开始,该属性可以更简洁地写成:

public string Fullname => string.Format("{0} {1}", Surname, Name);

在此处了解有关表达式主体属性的更多信息。

于 2010-05-03T14:37:52.317 回答
4

我一直在寻找这个答案,我的简单方法是添加一个 NotMapped 属性,这是我的代码:

[NotMapped]
public string FullName
   {
     get
       {
         return Name + " " + LastName;
       }
   }

然后就可以在控制器中使用正常的方式了,这是我的代码, Owner 相关的外键AspNetUsers

ViewBag.Owner = new SelectList(db.AspNetUsers, "Id", "FullName", product.Owner);
于 2018-12-13T14:06:49.467 回答
1

On view

<select asp-for="AccountId" 
            asp-items='new SelectList(from x in Accounts select new { Value = x.AccountId ,Text = x.Name + " " + x.Surname}, "Value","Text")'></select>
于 2021-01-13T09:24:24.120 回答