Korzystam z blazor 3.1 w najnowszej wersji VS 2019.
do tej pory jestem w stanie zlokalizować etykiety stron (tytuł, pola tabeli itp.)
Na ListEmployee.razor
stronie jestem w stanie zlokalizować nagłówek tabeli itp., A na AddEmplyeeValidation.razor
stronie jestem w stanie zlokalizować etykiety formularzy, ale mam problem ze zlokalizowaniem komunikatu sprawdzającego poprawność.
dla wiadomości Employee.cs
sprawdzania poprawności dla wiadomości sprawdzania poprawności są zdefiniowane w tym pliku i Resources/Data
folderze o nazwie zdefiniowanej jako Data.Employee.ar.resx
i Data.Employee.ar.resx
to nie działa
using System.ComponentModel.DataAnnotations;
przestrzeń nazw BlazorSPA1.Data {public class Employee {[MaxLength (50)] public string Id {get; zestaw; }
[Required (ErrorMessage ="Name is RRRequired")]
[StringLength(20, ErrorMessage = "Name is too long.")]
public string Name { get; set; }
[Required]
[StringLength(20)]
public string Department { get; set; }
[MaxLength(100)]
public string Designation { get; set; }
[MaxLength(100)]
public string Company { get; set; }
[MaxLength(100)]
public string City { get; set; }
}
}
Jak mogę dowiedzieć się, w jaki sposób komunikat sprawdzania poprawności z plików zasobów w oparciu o język formularza Dodaj pracownika.
@page "/addemployeeValidation"
@inject NavigationManager NavigationManager
@inject IEmployeeService EmployeeService
@inject IStringLocalizer<AddEmployeeValidation> L
<h2>Create Employee</h2>
<hr />
<EditForm Model="@employee" OnValidSubmit="@CreateEmployee">
<DataAnnotationsValidator />
<ValidationSummary />
<div class="row">
<div class="col-md-8">
<div class="form-group">
<label for="Name" class="control-label">@L["Name"]</label>
<input for="Name" class="form-control" @bind="@employee.Name" />
<ValidationMessage For="@(()=> employee.Name)" />
</div>
<div class="form-group">
<label for="Department" class="control-label">@L["Department"]</label>
<input for="Department" class="form-control" @bind="@employee.Department" />
</div>
<div class="form-group">
<label for="Designation" class="control-label">@L["Designation"]</label>
<input for="Designation" class="form-control" @bind="@employee.Designation" />
</div>
<div class="form-group">
<label for="Company" class="control-label">@L["Company"]</label>
<input for="Company" class="form-control" @bind="@employee.Company" />
</div>
<div class="form-group">
<label for="City" class="control-label">@L["City"]</label>
<input for="City" class="form-control" @bind="@employee.City" />
</div>
</div>
</div>
<div class="row">
<div class="col-md-4">
<div class="form-group">
<input type="submit" class="btn btn-primary" value="Save" />
<input type="button" class="btn" @onclick="@Cancel" value="Cancel" />
</div>
</div>
</div>
</EditForm>
@code {
Employee employee = new Employee();
protected async Task CreateEmployee()
{
await EmployeeService.CreateEmployee(employee);
NavigationManager.NavigateTo("listemployees");
}
void Cancel()
{
NavigationManager.NavigateTo("listemployees");
}
}
Przeczytałem kilka artykułów i próbowałem kilku rzeczy, ale wydaje się, że nic nie działa
Kod w Startup.cs`
services.AddServerSideBlazor (options => options.DetailedErrors = true);
services.AddLocalization(options => options.ResourcesPath = "Resources");
var supportedCultures = new List<CultureInfo> { new CultureInfo("en"), new CultureInfo("ar") };
services.Configure<RequestLocalizationOptions>(options =>
{
options.DefaultRequestCulture = new Microsoft.AspNetCore.Localization.RequestCulture("en");
options.SupportedUICultures = supportedCultures;
});
Korzystam z następującego przykładu dla lokalizacji, nie pokazuje, jak zlokalizować komunikat o błędzie https://www.c-sharpcorner.com/article/localization-in-blazor-server/
Obraz struktury folderów do odwołania
Przykład pliku zasobów dla wersji angielskiej w taki sam sposób, jak mam plik arabski
Na poniższym zrzucie ekranu nazwa pola jest pobierana z pliku zasobów, ale w przypadku walidacji komunikat jest wyświetlany tylko w języku angielskim, ponieważ nie działa
Zostało to zadane wcześniej:
Jak dodać lokalizację ViewModel do Blazora?
Zasugerowałem, że lepszym rozwiązaniem byłoby użycie FluentValidation. Oto link do mojego repozytorium Github, który pokazuje, jak to może działać:
https://github.com/conficient/BlazorValidationLocalization
źródło
Nie wypróbowałem tego!
W oficjalnych dokumentach asp.net core znajduje się sekcja jak zlokalizować
DataAnnotations
Być może znajdziesz tam jakieś wskazówki .źródło