14.5 多语言支持

我们在第十章介绍过国际化和本地化,开发了一个go-i18n库,这小节我们将把该库集成到beego框架里面来,使得我们的框架支持国际化和本地化。

i18n集成

beego中设置全局变量如下:

  1. Translation i18n.IL
  2. Lang string //设置语言包,zh、en
  3. LangPath string //设置语言包所在位置

初始化多语言函数:

  1. func InitLang(){
  2. beego.Translation:=i18n.NewLocale()
  3. beego.Translation.LoadPath(beego.LangPath)
  4. beego.Translation.SetLocale(beego.Lang)
  5. }

为了方便在模板中直接调用多语言包,我们设计了三个函数来处理响应的多语言:

  1. beegoTplFuncMap["Trans"] = i18n.I18nT
  2. beegoTplFuncMap["TransDate"] = i18n.I18nTimeDate
  3. beegoTplFuncMap["TransMoney"] = i18n.I18nMoney
  4. func I18nT(args ...interface{}) string {
  5. ok := false
  6. var s string
  7. if len(args) == 1 {
  8. s, ok = args[0].(string)
  9. }
  10. if !ok {
  11. s = fmt.Sprint(args...)
  12. }
  13. return beego.Translation.Translate(s)
  14. }
  15. func I18nTimeDate(args ...interface{}) string {
  16. ok := false
  17. var s string
  18. if len(args) == 1 {
  19. s, ok = args[0].(string)
  20. }
  21. if !ok {
  22. s = fmt.Sprint(args...)
  23. }
  24. return beego.Translation.Time(s)
  25. }
  26. func I18nMoney(args ...interface{}) string {
  27. ok := false
  28. var s string
  29. if len(args) == 1 {
  30. s, ok = args[0].(string)
  31. }
  32. if !ok {
  33. s = fmt.Sprint(args...)
  34. }
  35. return beego.Translation.Money(s)
  36. }

多语言开发使用

  1. 设置语言以及语言包所在位置,然后初始化i18n对象:
  1. beego.Lang = "zh"
  2. beego.LangPath = "views/lang"
  3. beego.InitLang()
  1. 设计多语言包

上面讲了如何初始化多语言包,现在设计多语言包,多语言包是json文件,如第十章介绍的一样,我们需要把设计的文件放在LangPath下面,例如zh.json或者en.json

  1. # zh.json
  2. {
  3. "zh": {
  4. "submit": "提交",
  5. "create": "创建"
  6. }
  7. }
  8. # en.json
  9. {
  10. "en": {
  11. "submit": "Submit",
  12. "create": "Create"
  13. }
  14. }
  1. 使用语言包

    我们可以在controller中调用翻译获取响应的翻译语言,如下所示:

  1. func (this *MainController) Get() {
  2. this.Data["create"] = beego.Translation.Translate("create")
  3. this.TplNames = "index.tpl"
  4. }

我们也可以在模板中直接调用响应的翻译函数:

  1. //直接文本翻译
  2. {{.create | Trans}}
  3. //时间翻译
  4. {{.time | TransDate}}
  5. //货币翻译
  6. {{.money | TransMoney}}