扫码订阅《 》或入驻星球,即可阅读文章!

GOLANG ROADMAP

阅读模式

  • 沉浸
  • 自动
  • 日常
首页
Go友会
  • 城市
  • 校园
Go学院
  • Go小课
  • Go小考
  • Go实战
  • 精品课
Go求职
  • 求职辅导🔥
  • Offer收割社群
  • 企业题库
  • 面试宝典
Go宝典
  • 在线宝典
  • B站精选
  • 推荐图书
  • 每日博文
Go仓库
实验区
  • Go周边
  • Go下载
  • Go月刊
消息
更多
  • 用户中心

    • 我的信息
    • 推广返利
  • 玩转星球

    • 星球介绍
    • 角色体系
    • 星主权益
  • 支持与服务

    • 联系星主
    • 成长记录
    • 常见问题
    • 吐槽专区
  • 合作交流

    • 渠道合作
    • 课程入驻
    • 友情链接
author-avatar

GOLANG ROADMAP


首页
Go友会
  • 城市
  • 校园
Go学院
  • Go小课
  • Go小考
  • Go实战
  • 精品课
Go求职
  • 求职辅导🔥
  • Offer收割社群
  • 企业题库
  • 面试宝典
Go宝典
  • 在线宝典
  • B站精选
  • 推荐图书
  • 每日博文
Go仓库
实验区
  • Go周边
  • Go下载
  • Go月刊
消息
更多
  • 用户中心

    • 我的信息
    • 推广返利
  • 玩转星球

    • 星球介绍
    • 角色体系
    • 星主权益
  • 支持与服务

    • 联系星主
    • 成长记录
    • 常见问题
    • 吐槽专区
  • 合作交流

    • 渠道合作
    • 课程入驻
    • 友情链接
  • Go语言Web编程

    • 课程介绍
  • Web基础

  • 表单

  • 访问数据库

  • session和数据存储

  • 文本处理

  • Web服务

  • 安全与加密

  • 国际化和本地化

  • 错误处理,调试和测试

  • 部署与维护

  • 如何设计一个Web框架

  • 扩展Web框架

    • 第1节:扩展 Web 框架
    • 第2节: 静态文件支持
    • 第3节:Session 支持
    • 第4节:表单及验证支持
    • 第5节:用户认证
    • 第6节:多语言支持
    • 第7节:pprof 支持
    • 第8节:小结

扫码订阅《 》或入驻星球,即可阅读文章!

第6节:多语言支持


ASTA谢

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

# i18n 集成

beego中设置全局变量如下:

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

初始化多语言函数:

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

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

beegoTplFuncMap["Trans"] = i18n.I18nT
beegoTplFuncMap["TransDate"] = i18n.I18nTimeDate
beegoTplFuncMap["TransMoney"] = i18n.I18nMoney

func I18nT(args ...interface{}) string {
    ok := false
    var s string
    if len(args) == 1 {
        s, ok = args[0].(string)
    }
    if !ok {
        s = fmt.Sprint(args...)
    }
    return beego.Translation.Translate(s)
}

func I18nTimeDate(args ...interface{}) string {
    ok := false
    var s string
    if len(args) == 1 {
        s, ok = args[0].(string)
    }
    if !ok {
        s = fmt.Sprint(args...)
    }
    return beego.Translation.Time(s)
}

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

# 多语言开发使用

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

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

# zh.json

{
"zh": {
    "submit": "提交",
    "create": "创建"
    }
}

# en.json

{
"en": {
    "submit": "Submit",
    "create": "Create"
    }
}
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
  1. 使用语言包

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

func (this *MainController) Get() {
	this.Data["create"] = beego.Translation.Translate("create")
	this.TplNames = "index.tpl"
}
1
2
3
4
我们也可以在模板中直接调用响应的翻译函数:
// 直接文本翻译
{{.create | Trans}}

// 时间翻译
{{.time | TransDate}}

// 货币翻译
{{.money | TransMoney}}
1
2
3
4
5
6
7
8
  • i18n 集成
  • 多语言开发使用