我正在尝试本地化Korzh组件EasyQuery。本地化ui消息时,我只完成了一半。但是实体名称、属性和操作符仍然是英文的。
这是我所做的(参考korzh.com上描述的步骤)
$(document).ready(function() {
var culture = $('#hidCulture').val();
if (culture.contains('nl')) {
EQ.core.texts = getDutchText();
} else if (culture.contains('fr')) {
EQ.core.texts = getFrenchText();
} else {
EQ.core.texts = getEnglishText();
}
});
文本资源来自另一个文件,看起来像这样:
getFrenchText = function() {
return {
Local: "fr",
AltMenuAttribute: "Attribute",
AltMenuAttribute: "Attribut",
...
StrAddColumns: "Ajouter des colonnes",
Entities: {
"Company": "Entreprise",
"Office": "Site",
...
},
Attribute: {
"Company.Name": "Nom",
...
},
Operators: {
"Equal": {
"caption": "Egal à",
"displayFormat": "{expr1} [[est égal à]] {expr2}"
}
};
}
有其他的解决方案使用资源或属性文件,但它不适合我的需要。据我所知,它不本地化实体名称。
这里结束了最后的尝试。有人遇到过同样的问题吗?
我无法使用javascript解决这个问题。
我首先想到使用随EasyQuery提供的数据模型编辑器用一种语言硬编码实体和属性标题。这种解决方案只允许我使用一种语言或一种语言的xml文件。在我看来,为每种语言生成不同的xml是一个非常糟糕的主意。
在查询生成器控制器中,有一个加载模型的方法。我只是添加了一个方法来递归地查找资源集中的标题。
[HttpPost]
public ActionResult GetModel(string modelName)
{
var dbModel = _eqService.GetModel(modelName);
var resources = EasyQueryModule.ResourceManager.GetResourceSet(
CultureInfo.CurrentUICulture, false, true
);
Translate(dbModel.EntityRoot.SubEntities, resources);
return Json(dbModel.SaveToDictionary());
}
private static void Translate(IEnumerable<Entity> entities, ResourceSet resources)
{
entities.ForEach(entity =>
{
entity.Name = resources.GetString(entity.Name) ?? entity.Name;
entity.Attributes.ForEach(attribute =>
attribute.Caption = resources.GetString(attribute.Caption) ?? attribute.Caption
);
Translate(entity.SubEntities, resources);
});
}
这可能不是最有效的本地化小部件的方法。我还没找到更好的。注意,我防止了在缺少资源项
的情况下出现错误。在我看来,本地化操作符很好,但不是强制性的。