Dies ist eine alte Frage, aber ich denke, dies ist ein sehr häufiges Problem, und hier ist meine Lösung in MVC 3.
Erstens wird eine T4-Vorlage benötigt, um Konstanten zu generieren, um unangenehme Zeichenfolgen zu vermeiden. Wir haben eine Ressourcendatei 'Labels.resx', die alle Beschriftungszeichenfolgen enthält. Daher verwendet die T4-Vorlage die Ressourcendatei direkt.
<#@ template debug="True" hostspecific="True" language="C#" #>
<#@ output extension=".cs" #>
<#@ Assembly Name="C:\Project\trunk\Resources\bin\Development\Resources.dll" #>
<#@ import namespace="System.Collections.Generic" #>
<#@ import namespace="System.Collections" #>
<#@ import namespace="System.Globalization" #>
<#@ import namespace="System" #>
<#@ import namespace="System.Resources" #>
<#
var resourceStrings = new List<string>();
var manager = Resources.Labels.ResourceManager;
IDictionaryEnumerator enumerator = manager.GetResourceSet(CultureInfo.CurrentCulture, true, true)
.GetEnumerator();
while (enumerator.MoveNext())
{
resourceStrings.Add(enumerator.Key.ToString());
}
#>
// This file is generated automatically. Do NOT modify any content inside.
namespace Lib.Const{
public static class LabelNames{
<#
foreach (String label in resourceStrings){
#>
public const string <#=label#> = "<#=label#>";
<#
}
#>
}
}
Anschließend wird eine Erweiterungsmethode erstellt, um den 'Anzeigenamen' zu lokalisieren.
using System.ComponentModel.DataAnnotations;
using Resources;
namespace Web.Extensions.ValidationAttributes
{
public static class ValidationAttributeHelper
{
public static ValidationContext LocalizeDisplayName(this ValidationContext context)
{
context.DisplayName = Labels.ResourceManager.GetString(context.DisplayName) ?? context.DisplayName;
return context;
}
}
}
Das Attribut 'DisplayName' wird durch das Attribut 'DisplayLabel' ersetzt, um automatisch aus 'Labels.resx' zu lesen.
namespace Web.Extensions.ValidationAttributes
{
public class DisplayLabelAttribute :System.ComponentModel.DisplayNameAttribute
{
private readonly string _propertyLabel;
public DisplayLabelAttribute(string propertyLabel)
{
_propertyLabel = propertyLabel;
}
public override string DisplayName
{
get
{
return _propertyLabel;
}
}
}
}
Nach all diesen Vorbereitungsarbeiten ist es Zeit, diese Standardvalidierungsattribute zu berühren. Ich verwende das Attribut 'Erforderlich' als Beispiel.
using System.ComponentModel.DataAnnotations;
using Resources;
namespace Web.Extensions.ValidationAttributes
{
public class RequiredAttribute : System.ComponentModel.DataAnnotations.RequiredAttribute
{
public RequiredAttribute()
{
ErrorMessageResourceType = typeof (Errors);
ErrorMessageResourceName = "Required";
}
protected override ValidationResult IsValid(object value, ValidationContext validationContext)
{
return base.IsValid(value, validationContext.LocalizeDisplayName());
}
}
}
Jetzt können wir diese Attribute in unserem Modell anwenden.
using Web.Extensions.ValidationAttributes;
namespace Web.Areas.Foo.Models
{
public class Person
{
[DisplayLabel(Lib.Const.LabelNames.HowOldAreYou)]
public int Age { get; set; }
[Required]
public string Name { get; set; }
}
}
Standardmäßig wird der Eigenschaftsname als Schlüssel zum Nachschlagen von 'Label.resx' verwendet. Wenn Sie ihn jedoch über 'DisplayLabel' festlegen, wird er stattdessen verwendet.