博客
关于我
[Go] GO语言实战-gin框架项目实现中英文切换
阅读量:663 次
发布时间:2019-03-15

本文共 2148 字,大约阅读时间需要 7 分钟。

如果项目中需要有多语言的展示,类似网站中英文切换,可以使用下面这个方法来实现

主要思路就是,页面html内容展示的时候,不能固定写死在页面上,需要从控制器部分分配过来变量,展示输出这个变量

这个变量的内容来自一个结构体的成员,该结构体在创建实例的时候,可以根据传递参数的不同,实例的成员内容不同

 

实际展示的地址是:

http://gofly.sopans.com/

 

 

 

控制器部分就是分配变量,在这里是通过get传递lang这个参数cn就是中文,en就是英文

engine.GET("/index", tmpl.PageIndex)
//首页func PageIndex(c *gin.Context) {    lang := c.Query("lang")    if lang == "" ||lang!="cn"{        lang = "en"    }    language:=config.CreateLanguage(lang)    c.HTML(http.StatusOK, "index.html", gin.H{        "Copyright":language.WebCopyRight,        "WebDesc":language.MainIntro,        "SubIntro":language.IndexSubIntro,        "Document":language.IndexDocument,        "VisitorBtn":language.IndexVisitors,        "AgentBtn":language.IndexAgent,        "OnlineChat":language.IndexOnlineChat,        "IndexSend":language.Send,        "Lang":lang,    })}

langguage这个结构体部分,根据不同的参数,创建不同的实例成员

package configtype Language struct {    WebCopyRight string    MainIntro string    Send string    Notice string    IndexSubIntro,IndexVisitors,IndexAgent,IndexDocument,IndexOnlineChat string}func CreateLanguage(lang string)*Language{    var language *Language    if lang=="en"{        language=&Language{            WebCopyRight: "TaoShihan",            MainIntro: "Simple and Powerful Go language online customer chat system",            IndexSubIntro: "GO-FLY, a Vue 2.0-based online customer service instant messaging system for PHP engineers and Golang engineers",            IndexDocument:"API Documents",            IndexVisitors:"Visitors Here",            IndexAgent:"Agents Here",            IndexOnlineChat:"Let’s chat. - We're online",            Send:"Send",            Notice:"Hello and welcome to go-fly - how can we help?",        }    }    if lang=="cn"{        language=&Language{            WebCopyRight: "陶士涵的菜地版权所有",            MainIntro:"极简强大的Go语言在线客服系统",            IndexSubIntro:"GO-FLY,一套为PHP工程师、Golang工程师准备的基于 Vue 2.0的在线客服即时通讯系统",            IndexVisitors:"访客入口",            IndexAgent:"客服入口",            IndexDocument:"接口文档",            IndexOnlineChat:"在线咨询",            Send:"发送",            Notice:"欢迎您访问go-fly!有什么我能帮助您的?",        }    }    return language}

 

  

 

 

转载地址:http://hjimz.baihongyu.com/

你可能感兴趣的文章
MySQL 是怎样运行的 - InnoDB数据页结构
查看>>
mysql 更新子表_mysql 在update中实现子查询的方式
查看>>
MySQL 有什么优点?
查看>>
mysql 权限整理记录
查看>>
mysql 权限登录问题:ERROR 1045 (28000): Access denied for user ‘root‘@‘localhost‘ (using password: YES)
查看>>
MYSQL 查看最大连接数和修改最大连接数
查看>>
MySQL 查看有哪些表
查看>>
mysql 查看锁_阿里/美团/字节面试官必问的Mysql锁机制,你真的明白吗
查看>>
MySql 查询以逗号分隔的字符串的方法(正则)
查看>>
MySQL 查询优化:提速查询效率的13大秘籍(避免使用SELECT 、分页查询的优化、合理使用连接、子查询的优化)(上)
查看>>
mysql 查询数据库所有表的字段信息
查看>>
【Java基础】什么是面向对象?
查看>>
mysql 查询,正数降序排序,负数升序排序
查看>>
MySQL 树形结构 根据指定节点 获取其下属的所有子节点(包含路径上的枝干节点和叶子节点)...
查看>>
mysql 死锁 Deadlock found when trying to get lock; try restarting transaction
查看>>
mysql 死锁(先delete 后insert)日志分析
查看>>
MySQL 死锁了,怎么办?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 深度分页性能急剧下降,该如何优化?
查看>>
MySQL 添加列,修改列,删除列
查看>>