我正在从MS Sql表中检索字符串,它可能只是一个名称或分隔名称:例如Tom或Speaker 1,Speaker 2.
我使用以下命令将字符串转换为控制器中的列表:
Event cevent = db.Events.Find(id);
string speakers = cevent.Speakers;
ViewBag.speakers = "";
if (!String.IsNullOrWhiteSpace(speakers) &&
speakers.Contains(","))
{
ViewBag.speakers = speakers.Split(',').ToList();
}
else
{
ViewBag.speakers = speakers;
}
return View(cevent);
在视图中,我使用以下内容显示列表:
<ul>
@foreach (var item in ViewBag.speakers)
{
<li> @item </li>
}
</ul>
与列表配合得很好,我得到:
• Speaker 1
• Speaker 2
但是,如果ViewBag只有一个项目,我会得到:
• T
• o
• m
答案 0 :(得分:1)
您可以考虑始终将可枚举的扬声器对象传递给视图,无论是否有一个或多个扬声器。
在您的视图中,您将枚举扬声器对象,在“Tom”的情况下,它是一个字符列表。您可以尝试这样的事情,而不是:
在控制器中:
ViewBag.speakers = new List<string>();
string speakers = cevent.Speakers;
var listOfSpeakers = speakers.Split(',').ToList();
foreach (var speaker in listOfSpeakers)
{
ViewBag.speakers.Add(speaker)
}
如果您需要根据是否将多个扬声器传递给视图来不同地格式化HTML输出,则可以在条件块中的扬声器列表上使用if(ViewBag.speakers.Count > 1)
,并在这种情况下以不同方式处理输出。