ASP.NET Core Localization with help of SharedResources

前端 未结 3 630
余生分开走
余生分开走 2020-12-07 22:48

Hi I have a question about the SharedResources file. It is glanced over in the tutorial here: https://docs.microsoft.com/en-us/aspnet/core/fundamentals/localization, and I\'

相关标签:
3条回答
  • 2020-12-07 23:22

    I'd like to add the setup that's working for my team as well. It's based on the same principle as yours (of course), but I believe it allows some more flexibility on your files location, as it does not force you to put resource-related files in project root.

    My understanding is that IStringLocalizer<T> has the concept of a placeholder Type, whose fullname will be converted into a relative path and used to find the actual resource file. To do this conversion, it also uses info from LocalizationOptions.ResourcesPath, if any.

    Say you have:

    // in ProjectRoot\Startup.cs
    
    services.AddLocalization(opts =>
    {
      opts.ResourcesPath = "Localized";
    });
    
    // in ProjectRoot\Area\Whatever\SomeClass.cs
    
    namespace Com.Company.Project.Area.Whatever
    {
      public class SomeClass
      {
        public SomeClass(IStringLocalizer<SomeClass> localizer)
        {
          // ...
        }
      }
    }
    

    So here's what happens, step-by-step, just to give an idea:

    1. SomeClass fullname: Com.Company.Project.Area.Whatever.SomeClass
    2. convert that to .resx file path: Com\Company\Project\Area\Whatever\SomeClass.resx
    3. prefix that with ResourcesPath content: Localized\Com\Company\Project\Area\Whatever\SomeClass.resx

    That's the actual path where resource file(s) will be looked up.

    So, all in all, you can place your SharedResources.cs empty class wherever you want, as long as you replicate its fullname as a path under ResourcesPath folder under project root.

    In the example:

    \
    --Area
      --Whatever
        --SomeClass.cs
    --Localized
      --Com
        --Company
          --Project
            --Area
              --Whatever
                --SomeClass.resx
                --SomeClass.fr.resx
                --SomeClass.da.resx
    

    Under the cover, that directory tree is needed because classes generated out of resx file will take their namespace from the directory tree, and also because string localizer will not strip root namespace when prefixing placeholder type with ResourcesPath.

    0 讨论(0)
  • 2020-12-07 23:31

    Here is what worked for me (in ASP.NET Core 2.0):

    1. Place SharedResources.cs in a folder called Resources.
    2. Place SharedResources.xx-yy.resx resource files in Resources folder too.
    3. Call services.AddLocalization() with no ResourcesPath option.
    0 讨论(0)
  • 2020-12-07 23:44

    Okay, after some digging around and even more trial and error I've found answers to my questions and got everything to work. Here's what I found:

    I am supposed to create a SharedResources.cs class, but where should i put it and should it be empty or do I need to fill it with some data?

    ANSWER: SharedResources.cs can be placed in the root folder of project or in Resources folder, but the most important thing is that namespace should be set to the root of the project. In my case namespace Funkipedia. And it does not need to contain any data, just the class declaration.

    Same goes for the resource file, should I create a SharedResources.da.resx file and put all my shared strings there? Where should it go?

    ANSWER: Yes, you need to create a resource file called the same as the .cs file and it needs to be put in the Resources folder.

    And when I use IHtmlLocalizer<SharedResources> do I just write @using and point it to the namespace where SharedResources.cs resides?

    ANSWER: When it comes to using IHtmlLocalizer and/or IStringLocalizer in view you need to write this at the top of .cshtml file:

    @using Microsoft.AspNetCore.Mvc.Localization
    @using Microsoft.Extensions.Localization
    @inject IViewLocalizer Localizer
    @inject IStringLocalizer<SharedResources> SharedLocalizer
    @inject IHtmlLocalizer<SharedResources> SharedHtmlLocalizer
    

    Note that @using Microsoft.Extensions.Localization is only needed if you use IStringLocalizer

    I hope that this will help others who might be new to resource files and localization of ASP.NET Core applications.

    0 讨论(0)
提交回复
热议问题