Как бы вы провели рефакторинг этого Asp.net MVC 2 Html Helper?
Быстрый вопрос.
Как бы вы провели рефакторинг этого Asp.net MVC 2 HtmlHelper? В частности, имеет ли смысл использовать класс TagBuilder в этом сценарии?
public static MvcHtmlString BusinessDisplayContacts(this HtmlHelper helper, string phone, string cellPhone,
string fax, string website, string email, bool hideEmail)
{
StringBuilder sb = new StringBuilder();
sb.AppendLine("<ul>");
if (!string.IsNullOrEmpty(phone)) {
sb.AppendLine("<li class=\"tel\">");
sb.AppendLine("<span class=\"type\">Work</span>:");
sb.AppendFormat("<span class=\"value\">{0}</span>",phone);
sb.AppendLine("</li>");
}
if (!string.IsNullOrEmpty(cellPhone)) {
sb.AppendLine("<li class=\"tel\">");
sb.AppendLine("<span class=\"type\">Cell</span> Phone:");
sb.AppendFormat("<span class=\"value\">{0}</span>",cellPhone);
sb.AppendLine("</li>");
}
if (!string.IsNullOrEmpty(fax)) {
sb.AppendLine("<li class=\"tel\">");
sb.AppendLine("<span class=\"type\">Fax</span>:");
sb.AppendFormat("<span class=\"value\">{0}</span>",fax);
sb.AppendLine("</li>");
}
if (!string.IsNullOrEmpty(website)) {
sb.AppendFormat("<li><a class=\"url\" href=\"{0}\">{0}</a></li>",website);
}
if (!hideEmail && !string.IsNullOrEmpty(email)) {
sb.AppendFormat("<li><a class=\"email\" href=\"mailto:{0}\">{0}</a></li>",email);
}
sb.AppendLine("</ul>");
if (sb.Length < 10)
{
return MvcHtmlString.Create("");
}
else {
return MvcHtmlString.Create(sb.ToString());
}
}
Заранее спасибо.
ОБНОВИТЬ:
Спасибо за все конструктивные комментарии. В конце я решил переместить приведенный выше код в строго типизированное частичное представление согласно предложению @queen3.
1 ответ
Одна вещь, которую я вижу, что люди часто скучают, это использование дословных строк C# для подобных вещей... например
sb.AppendLine("<li class=\"tel\">");
sb.AppendLine("<span class=\"type\">Work</span>:");
sb.AppendLine(string.Format("<span class=\"value\">{0}</span>",phone));
sb.AppendLine("</li>");
можно сделать в
sb.AppendFormat(@"
<li class=""tel"">
<span class=""type"">Work</span>: <span class=""value"">{0}</span>
</li>
", phone);
который является более читабельным.
Еще одна вещь: я бы поместил все эти строки + bool внутри объекта, как ContactInfo
или что-то, изменяя подпись вашего помощника на BusinessDisplayContacts(this HtmlHelper helper, ContactInfo info)
- таким образом, вы сможете добавлять / удалять / изменять номера телефонов и условия, не нарушая существующий код.