cakephp里面在Controller或者View中,输出都是用一个函数 __(”xxxx”) 来执行。
- 本地化和国际化Localization 表示将 Web 应用转化以适应某种语言(或文化)的需求,而Internationalization 表示 Web 应用可以被本地化的能力。Internationalization 和 localization 常被缩写为 i18n 和 l10n; 数字 18 和 10 是该单词的第一个字母到最后一个字母之间的字母数量。
- 含有本地化内容的文件夹放在 CakePHP 安装目录 /app/locale 下。每种语言对应不同的 3 个字母代码,该代码符合 ISO 639-2 标准。一旦你创建了该文件,就可以编辑本地化的内容了。注意每个字符串的键值必须唯一,且包含对应值。下面是简单是例子, 英语语言 default.po 文件的内容:
msgid "search" msgstr "Click here to search our product database."
其中,msgid用来标识字符串,在不同的语言文件中应该保持一致,而msgstr则为对应语言的内容。po 文件应用 UTF-8 编码,每个 msmstr 值须限定在 1014 个字符之内。
- 设置应用的本地locale(此步可以省略,cakephp会根据用户的浏览器设置来使用相应的语言进行显示)
- 在config/core.php中使用configure::write:chi代表中文,英文应为eng
Configure::write('Config.language' , "chi");
- 在php文件程序开始前中写入(例如在beforeFilter中根据用户的语言环境来设置相应的语言):
$this->Session->write ("Config.language","chi");
- 使用以下代码来进行设置
App::import('Core', 'L10n'); $l10n = & new L10n(); $l10n->get('chi'); //设置locale为中文 //然后使用_()函数来实现本地化 _('msgid');
- 在config/core.php中使用configure::write:chi代表中文,英文应为eng
- 实现本地化
在需要实现本地化的地方,调用_()函数
- 直接输出字符串,没有返回值:
__("msgid"); 或者 _("msgid", false);
- 间接输出字符串,有返回值:
__("msgid",true);
- 直接输出字符串,没有返回值: