# 多语言开发
## 概述
ThinkCMF已经默认开启了多语言的支持,后台以语言包形式实现多语言,前台以语言包和多模板的形式实现多语言.
######语言包
ThinkCMF开启的语言有三个,分别是zh-cn,en-us,zh-tw,此项配置在application/Common/Conf/config.php配置文件下,可以通过更改`LANG_LIST`的值增加语言.
语言包分为框架核心语言包(在simplewind/Core/Lang目录下)和应用语言包(在每个应用的Lang目录下,如application/Portal/Lang),根据你设置的语言列表,在这些地方增加相应的语言包,就实现了多语言.
应用语言包具体位置说明:
| 语言包 | 文件位置 | 加载时间|
| ---------- | ------------- | ---------------|
| 应用公共语言包 | application/Common/Lang/语言.php | 都加载 |
| 应用语言包 | application/应用名/Lang/语言.php | 只在访问应用时加载|
| 应用控制器语言包 | application/应用名/Lang/语言目录/语言.php| 只在访问控制器下方法时加载
| 应用控制器后台菜单语言包| application/应用名/Lang/语言目录/admin_menu.php| 登录后台首页,和访问后台控制器时加载|
######语言文件定义
1.语言文件格式为PHP返回数组形式,如:
```php
return array(
'ADMIN_CENTER' => 'Admin Center',
'WELCOME_USER' => 'Welcome, {$username}!',
'REFRESH_CURRENT_PAGE' => 'Refresh Current Page',
'WEBSITE_HOME_PAGE' => 'Website Home Page'
);
```
2.也可以在代码中动态设置
```php
L('ADMIN_CENTER','后台管理中心');
$lang_admin_center = L('ADMIN_CENTER');
```
######变量传入支持
1.在定义语言包时也支持变量,如:
```php
return array(
'WELCOME_USER' => 'Welcome, {$username}!',
);
```
2.在使用 L 方法获取时,可以传入$username 变量,如:
```php
$lang_welcome_user = L('WELCOME_USER',array('username'=>'无敌小夏'));
echo $lang_welcome_user; // 这里输出的字符串就是:Welcome,无敌小夏!
```
######获取语言包设置的值
1.在PHP代码里使用 L 方法,如:
```php
$lang_admin_center = L('ADMIN_CENTER');
echo $lang_admin_center; // 这里输出的值是:Admin Center
```
2.在模板里使用 L 方法,如:
```php
<!--以下输出的字符串也是:Admin Center-->
{:L('ADMIN_CENTER')}
<!--以下输出的字符串也是:Welcome,无敌小夏!-->
{:L('WELCOME_USER',array('username'=>'无敌小夏'))}
```
### 前台模板多语言
ThinkCMF前台模板多语言是使用多模板的方式来实现的,如:当前模板是`simplebootx`,如果想开启英文前台模板的话,就只要加一个模板名为 `simplebootx_en-us`模板就可以了;
###### 前台模板多语言实现原理:
ThinkCMF在前台控制器加载模板文件时,会根据当前用户的浏览器语言或者用户指定的语言来加载模板文件,如果是中文用户就加载 simplebootx 里的模板文件,如果是英文用户就加载 simplebootx_en-us 里的模板文件;每个模板里数据调用是独立的,你可以在不同模板里做不同的配置,以调用不同的语言的内容;
###### 为什么选用多模板形式实现前台多语言?
很多用户会疑问,这不是会增加维护的难度吗?为什么不用语言包的形式呢?
维护难度当然会增加,做一个模板和做两个模板是不一样的时间,但你想英文模板和中文模板无论从内容还风格都有可能会不同,一个模板,你要考虑很多布局上兼容的问题,同时,如果想对不同语言的用户做不同的体验上的界面设计,一个模板肯定无法满足,所以多模板形式才是前台多语言最好的选择,当然你在模板里也可以使用应用里设置的语言包.
- 介绍
- 序言
- 关于ThinkCMF
- 关于BootStrap
- 基础
- 开发规范
- 调试模式
- 应用
- 如何获取
- 环境要求
- 安装使用
- 配置
- 控制器
- URL生成
- AJAX返回
- 跳转和重定向
- 输入变量
- 请求类型
- 空操作
- 空控制器
- 视图
- 模板定义
- 模板主题
- 模板赋值
- 获取内容
- 模板渲染
- 模型
- 模型定义
- 模型实例化
- 连接数据库
- 更多模型用法
- 系统函数
- 生成评论组件
- 添加钩子
- URL美化函数
- 获取文件相对路径
- 用户权限验证
- 字符串解密
- 字符串加密
- 获取当前语言包
- 手机验证码验证
- 检查用户操作
- 图片验证码验证
- 清除系统缓存
- 文本内容分页
- 密码比较
- 获取文件访问地址
- 获取CMF设置
- 获取评论
- 获取当前登录管理员id
- 获取当前主题名
- 获取当前登录用户信息
- 获取当前登录用户ID
- 获取收藏安全Key
- 获取文件下载链接
- 获取文件扩展名
- 获取系统域名
- 获取图片预览地址
- 获取图片访问地址
- 生成前台导航
- 获取插件类名
- 获取插件配置
- 获取URL相对路径
- 获取前台模板根目录地址
- 获取用户头像地址
- 获取用户列表
- 获取广告
- 获取幻灯片
- 判断是否为手机访问
- 获取HTML内容中的图片
- 判断用户是否登录
- 判断是否为微信访问
- 解析字符串标签
- 生成密码
- 插件URL生成
- 生成随意字符串
- 遍历目录
- 发送邮件
- 更新动态配置
- 设置系统配置
- 更新当前登录用户
- 系统扩展
- 应用开发流程
- 后台隐藏的后台菜单管理功能
- 几个重要基类
- 引入第三方库
- 模板
- 基础
- 全局变量
- 模板结构
- 模板注释
- 模板常量
- 前台模板多语言
- 变量输出
- 使用函数
- 默认值输出
- 使用运算符
- 三元运算
- 包含文件
- 原样输出
- 模板标签
- tc\_include
- foreach
- volist
- php
- if else
- for
- switch
- 比较标签
- 范围判断标签
- Present标签
- Empty标签
- Defined标签
- Assign标签
- Define标签
- 标签嵌套
- 前端组件
- js-count-btn
- js-favorite-btn
- js-ajax-dialog-btn
- js-ajax-delete
- js-date
- js-datetime
- js-ajax-form
- 公共模板
- 菜单导航制作
- 幻灯片制作
- 广告位制作
- 友情链接制作
- 添加留言控件
- 如何收藏
- 点赞组件
- 最新评论组件制作
- 最新加入组件制作
- 本站用户登录模板制作
- 本站用户注册模板制作
- 忘记密码模板制作
- 密码重置模板制作
- 评论组件
- 进阶
- 七牛图片处理
- 门户应用
- 基础
- 主程序结构
- 模板结构
- 函数库
- 指定分类下的所有子分类
- 获取面包屑数据
- 查询文章列表,不分页
- 获取指定ID的文章
- 获取指定ID的分类
- 获取分类列表
- 获取指定分类下的子分类
- 获取文章列表,分页
- 获取指定 ID 的页面
- 获取指定分类下所有文章,包括子类的
- 获取指定分类下所有文章,包括子类的,分页
- 门户模板制作
- 文章列表页制作
- 文章内页制作
- 页面制作
- 获取文章的各种方式
- 热门文章组件制作
- seo优化
- 文章相册制作
- 文章列表推荐功能制作
- 文章列表置顶功能制作
- 插件
- 插件钩子
- 插件配置文件
- 插件类主文件
- 插件开发流程
- 插件控制器
- 插件数据库模型
- 插件后台管理控制器
- 插件多语言
- 后台管理
- SMTP配置
- 忘记后台密码?
- 后台地址是啥?
- 后台菜单管理
- 管理员权限管理
- 第三方登录配置
- 专题
- 多语言开发
- Restful Api
- 数据分页
- 缓存
- 安全
- SESSION支持
- Cookie支持
- 文件上传
- 验证码
- 部署
- 迁移到正式环境
- URL重写