配置与扩展
配置文件
通过文件可以配置多个本地化管理器,通过更换 default 的值即可实现无缝切换。配置文件如下:
- .Net Framework 下的 app.config 或 web.config 文件
<?xml version="1.0" encoding="utf-8" ?>
<configuration>
<configSections>
<sectionGroup name="fireasy">
<section name="stringLocalizers" type="Fireasy.Common.Localization.Configuration.StringLocalizerConfigurationSectionHandler, Fireasy.Common" />
</sectionGroup>
</configSections>
<fireasy>
<stringLocalizers default="xml">
<localizer name="xml" type="Fireasy.Common.Localization.XmlStringLocalizerManager, Fireasy.Common" />
<localizer name="demo" type="demo.StringLocalizerManager, demo" />
</stringLocalizers>
</fireasy>
</configuration>
- .Net Core 下的 appsettings.json 文件
{
"fireasy": {
"stringLocalizers": {
"default": "xml",
"settings": {
"xml": {
"type": "Fireasy.Common.Localization.XmlStringLocalizerManager, Fireasy.Common"
},
"demo": {
"type": "demo.StringLocalizerManager, demo"
}
}
}
}
}
StringLocalizerFactory
工厂类可以根据配置创建一个 IStringLocalizerManager
实例。如下所示:
[TestMethod]
public void TestCreateManager()
{
var manager1 = StringLocalizerFactory.CreateManager();
Assert.IsNotNull(manager1); // xml
var manager2 = StringLocalizerFactory.CreateManager("demo");
Assert.IsNotNull(manager2); // demo
}
在使用 IOC
的环境中,通过构造注入或属性注入得到的 IStringLocalizerManager
的实例对应的是指向 default 的配置项。