1

我正在尝试使用 jquery ui datepicker 为日期选择器创建一个强类型的 html 帮助器扩展。我创建了一个非强类型的扩展,它可以工作,但现在我正在尝试创建它是强类型的。

这是我所拥有的:

public static MvcHtmlString DatePicker(this HtmlHelper html, string name, object date)
    {
        var inputTag = new TagBuilder("input");
        inputTag.MergeAttribute("id", name);
        inputTag.MergeAttribute("name", name);
        inputTag.MergeAttribute("type", "text");

        if (date != null)
        {
            string dateValue = String.Empty;
            if ((date is DateTime? ||date is DateTime) && (DateTime)date != DateTime.MinValue)
            {
                dateValue = ((DateTime)date).ToShortDateString();
            }
            else if (date is string)
            {
                dateValue = (string)date;
            }

            inputTag.MergeAttribute("value", dateValue);
        }

        return MvcHtmlString.Create(inputTag.ToString());
    }

这有效并且将保持该值。这是我的强类型扩展。

public static MvcHtmlString DatePickerFor<TModel, TProperty>(this HtmlHelper<TModel> htmlHelper, Expression<Func<TModel, TProperty>> expression) where TModel : class
    {
        Func<TModel, TProperty> myFunc = expression.Compile();
        var value = myFunc(???);

        var inputName = ExpressionHelper.GetExpressionText(expression);
        return htmlHelper.DatePicker(inputName, value);
    }

如果我为值传递 null(值 = null),但在编辑时,日期选择器没有填充值,则此方法有效。

如何从模型中获取 DatePickerFor 扩展方法中的值。(我知道我可以通过另一个参数传入值,但我不希望这样做。另外这很有趣)

谢谢凯文

--EDIT------我的最终结果---------- 注意:这还没有经过全面测试,但现在似乎可以正常工作。

public static MvcHtmlString DatePicker(this HtmlHelper html, string name, object date)
    {
        var inputTag = new TagBuilder("input");
        inputTag.MergeAttribute("id", name);
        inputTag.MergeAttribute("name", name);
        inputTag.MergeAttribute("type", "text");
        inputTag.AddCssClass("jqueryDatePicker");

        if (date != null)
        {
            string dateValue = String.Empty;
            if ((date is DateTime? ||date is DateTime) && (DateTime)date != DateTime.MinValue)
            {
                dateValue = ((DateTime)date).ToShortDateString();
            }
            else if (date is string)
            {
                dateValue = (string)date;
            }

            inputTag.MergeAttribute("value", dateValue);
        }

        return MvcHtmlString.Create(inputTag.ToString());
    }

    public static MvcHtmlString DatePickerFor<TModel, TProperty>(this HtmlHelper<TModel> htmlHelper, Expression<Func<TModel, TProperty>> expression) where TModel : class
    {
        Func<TModel, TProperty> methodCall = expression.Compile();
        TProperty value = methodCall(htmlHelper.ViewData.Model);
        var inputName = ExpressionHelper.GetExpressionText(expression);

        return htmlHelper.DatePicker(inputName, value);
    }

这是使用 JQuery UI datepicker 脚本。什么是“jqueryDatePicker”,为什么将它作为一个类添加?我没有在每个页面上调用 $(#...).datepicker(),而是添加了这个类,并且有一些 javascript 会找到这个类并为你调用 .datepicker()。

4

1 回答 1

0

像下面这样的东西应该可以工作:

var input = myFunc(htmlHelper.ViewData.Model)
于 2010-07-20T18:40:48.860 回答