Как и было обещано
Вы не можете визуализировать @section
, поскольку это не поддерживается при визуализации с помощью частичных представлений, до тех пор вы можете выполнить этот трюк:
в вашем _Layout.cshtml
написать
@RenderSection("scripts", false)
@Html.RenderSection("scripts")
Первый - по умолчанию , вторая строка - ваш новый способ визуализации раздела, я использую оба в своем коде ...
Теперь давайте добавим немного кода в наше Частичное представление
вместо
@section scripts {
<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>
<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>
}
заменить его на:
@Html.Section(
@<script src="@Url.Content("~/Scripts/jquery.validate.min.js")" type="text/javascript"></script>, "scripts"
)
@Html.Section(
@<script src="@Url.Content("~/Scripts/jquery.validate.unobtrusive.min.js")" type="text/javascript"></script>, "scripts"
)
и наш маленький помощник , который вы просто поместили в папку Models
и сослались на нее на странице частичного просмотра и макета
// using idea from /5530560/ispolzovanie-razdelov-v-redaktore-pokazat-shablony#5530571
public static class HtmlExtensions
{
public static MvcHtmlString Section(this HtmlHelper htmlHelper, Func<object, HelperResult> template, string addToSection)
{
htmlHelper.ViewContext.HttpContext.Items[String.Concat("_", addToSection, "_", Guid.NewGuid())] = template;
return MvcHtmlString.Empty;
}
public static IHtmlString RenderSection(this HtmlHelper htmlHelper, string sectionName)
{
foreach (object key in htmlHelper.ViewContext.HttpContext.Items.Keys)
{
if (key.ToString().StartsWith(String.Concat("_", sectionName, "_")))
{
var template = htmlHelper.ViewContext.HttpContext.Items[key] as Func<object, HelperResult>;
if (template != null)
{
htmlHelper.ViewContext.Writer.Write(template(null));
}
}
}
return MvcHtmlString.Empty;
}
}
Чтобы отобразить CSS , все, что вам нужно, так это использовать другое имя раздела, например:
В _Layout.cshtml
@Html.RenderSection("styles")
в ваших частичных представлениях
@Html.Section(
@<link rel="stylesheet" href="http://twitter.github.com/bootstrap/1.3.0/bootstrap.min.css">, "styles"
)
Надеюсь, это поможет.