5

問題は、同じタイプの2つのコントロールをページに配置するときに、バインディングに異なるプレフィックスを指定する必要があることです。この場合、フォームの直後に生成された検証ルールは正しくありません。では、このケースでクライアント検証を機能させる方法は?:

ページに含まれるもの:

<%
    Html.RenderPartial(ViewLocations.Shared.PhoneEditPartial, new PhoneViewModel { Phone = person.PhonePhone, Prefix = "PhonePhone" });
    Html.RenderPartial(ViewLocations.Shared.PhoneEditPartial, new PhoneViewModel { Phone = person.FaxPhone, Prefix = "FaxPhone" });
%>

コントロールViewUserControl<PhoneViewModel>:

<%= Html.TextBox(Model.GetPrefixed("CountryCode"), Model.Phone.CountryCode) %>
<%= Html.ValidationMessage("Phone.CountryCode", new { id = Model.GetPrefixed("CountryCode"), name = Model.GetPrefixed("CountryCode") })%>

ここでModel.GetPrefixed("CountryCode")、プレフィックスに応じて「FaxPhone.CountryCode」または「PhonePhone.CountryCode」を返します。


フォームの後に生成される検証ルールは次のとおりです。これらは、フィールド名「Phone.CountryCode」に対して複製されます。望ましい結果は、FieldNames "FaxPhone.CountryCode"、 "PhonePhone.CountryCode" alt text http://www.freeimagehosting.net/uploads/37fbe720bf.pngごとに2つのルール(必須、番号)です。

質問は、Asp.Net MVC2クライアントサイド検証と重複IDの問題と多少重複 していますが、IDを手動で生成することは役に立ちません。

4

1 に答える 1

10

テキストボックスと検証の両方に同じプレフィックスを設定する正しい方法:

<% using (Html.BeginHtmlFieldPrefixScope(Model.Prefix)) { %>
   <%= Html.TextBoxFor(m => m.Address.PostCode) %>
   <%= Html.ValidationMessageFor(m => m.Address.PostCode) %>
<% } %>

どこ

public static class HtmlPrefixScopeExtensions
{
    public static IDisposable BeginHtmlFieldPrefixScope(this HtmlHelper html, string htmlFieldPrefix)
    {
        return new HtmlFieldPrefixScope(html.ViewData.TemplateInfo, htmlFieldPrefix);
    }

    private class HtmlFieldPrefixScope : IDisposable
    {
        private readonly TemplateInfo templateInfo;
        private readonly string previousHtmlFieldPrefix;

        public HtmlFieldPrefixScope(TemplateInfo templateInfo, string htmlFieldPrefix)
        {
            this.templateInfo = templateInfo;

            previousHtmlFieldPrefix = templateInfo.HtmlFieldPrefix;
            templateInfo.HtmlFieldPrefix = htmlFieldPrefix;
        }

        public void Dispose()
        {
            templateInfo.HtmlFieldPrefix = previousHtmlFieldPrefix;
        }
    }
}

(偶然、Steve Sandersonのブログhttp://blog.stevensanderson.com/2010/01/28/editing-a-variable-length-list-aspnet-mvc-2-style/のコードで解決策が見つかりました)

また、Html.EditorForアプローチは、ここで提案されているように機能するはずです:ASP.NET MVC 2-ViewModel Prefix

于 2010-05-05T01:11:24.770 に答える