简体   繁体   English

MVC HTML帮助程序扩展

[英]MVC html helper extension

I am trying to reuse html helper found here 我正在尝试重用此处找到的html helper

public static class HtmlHelperExtension
{
    public static string DatePickerDropDowns(this HtmlHelper html, string dayName, string monthName, string yearName)
    {
        var daysList = new TagBuilder("select");
        var monthsList = new TagBuilder("select");
        var yearsList = new TagBuilder("select");

        daysList.Attributes.Add("name", dayName);
        monthsList.Attributes.Add("name", monthName);
        yearsList.Attributes.Add("name", yearName);

        StringBuilder days = new StringBuilder();
        StringBuilder months = new StringBuilder();
        StringBuilder years = new StringBuilder();

        int beginYear = DateTime.UtcNow.Year - 100;
        int endYear = DateTime.UtcNow.Year;

        for (int i = 1; i <= 31; i++)
            days.AppendFormat("<option value='{0}'>{0}</option>", i);

        for (int i = 1; i <= 12; i++)
            months.AppendFormat("<option value='{0}'>{0}</option>", i);

        for (int i = beginYear; i <= endYear; i++)
            years.AppendFormat("<option value='{0}'>{0}</option>", i);

        daysList.InnerHtml = days.ToString();
        monthsList.InnerHtml = months.ToString();
        yearsList.InnerHtml = years.ToString();

        return string.Concat(daysList.ToString(), monthsList.ToString(), yearsList.ToString());
    }
}

but how do I use it on my mvc razor page .I tried by 但是我如何在我的mvc剃刀页面上使用它呢。

@Html.DatePickerDropDowns("dayName","monthName","yearName") @ Html.DatePickerDropDowns( “DAYNAME”, “MONTHNAME”, “yearName”)

but when I loaded my razor page ,it did n't worked ,it's just showing html syntax,I mean it's not showing up the actual dropdown lists. 但是当我加载我的剃须刀页面时,它没有用,它只是显示html语法,我的意思是它没有显示实际的下拉列表。 What I am I doing wrong here .how can I fix this and show three dropdowns 1 for day, 1 for month and 1 for years ? 我在这里做错什么了,如何解决这个问题并显示三个下拉菜单,分别为1天,1月和1年?

You have to change the defined return of your Helper. 您必须更改助手的定义回报。 Make sure you use MvcHtmlString and the return return MvcHtmlString.Create(String.Concat(daysList.ToString(), monthsList.ToString(), yearsList.ToString())); 确保使用MvcHtmlString并返回return MvcHtmlString.Create(String.Concat(daysList.ToString(), monthsList.ToString(), yearsList.ToString()));

Complete code: 完整的代码:

public static MvcHtmlString DatePickerDropDowns(this HtmlHelper html, string dayName, string monthName, string yearName)
{
    var daysList = new TagBuilder("select");
    var monthsList = new TagBuilder("select");
    var yearsList = new TagBuilder("select");

    daysList.Attributes.Add("name", dayName);
    monthsList.Attributes.Add("name", monthName);
    yearsList.Attributes.Add("name", yearName);

    StringBuilder days = new StringBuilder();
    StringBuilder months = new StringBuilder();
    StringBuilder years = new StringBuilder();

    int beginYear = DateTime.UtcNow.Year - 100;
    int endYear = DateTime.UtcNow.Year;

    for (int i = 1; i <= 31; i++)
        days.AppendFormat("<option value='{0}'>{0}</option>", i);

    for (int i = 1; i <= 12; i++)
        months.AppendFormat("<option value='{0}'>{0}</option>", i);

    for (int i = beginYear; i <= endYear; i++)
        years.AppendFormat("<option value='{0}'>{0}</option>", i);

    daysList.InnerHtml = days.ToString();
    monthsList.InnerHtml = months.ToString();
    yearsList.InnerHtml = years.ToString();

    return MvcHtmlString.Create(String.Concat(daysList.ToString(), monthsList.ToString(), yearsList.ToString()));
}

而不是返回string而是返回MvcHtmlString

public static MvcHtmlString DatePickerDropDowns(this HtmlHelper html, string dayName, string monthName, string yearName)

声明:本站的技术帖子网页,遵循CC BY-SA 4.0协议,如果您需要转载,请注明本站网址或者原文地址。任何问题请咨询:yoyou2525@163.com.

 
粤ICP备18138465号  © 2020-2024 STACKOOM.COM