Cakephp本地化和国际化详解
看过CakePHP的程序例子的程序员都会发现,在Controller或者View中,大多数输出都是用一个函数 __(”xxxx”) 来执的,
这个函数就相当与其他框架中的getText()函数,是根据key值和locale来动态获取相应的语言内容。
1)什 么是 i18n,l10n
首 先要先明白Localization & Internationalization两个单词,分别叫本地化和国际化. Localization 表示将 Web 应用转化以适应某种语言(或文化)的需求,而 Internationalization 表示 Web 应用可以被本地化的能力。Internationalization 和 localization 常被缩写为 i18n 和 l10n; 数字 18 和 10 是该单词的第一个字母到最后一个字母之间的字母数量
2)实现本地化语言文件
- //引用 L10n 类:
- App::import('Core', 'l10n');
- class ProductController extends AppController { //... }
- /app/locale/eng/LC_MESSAGES/default.po (English)
- /app/locale/fre/LC_MESSAGES/default.po (French)
- /app/locale/chi/LC_MESSAGES/default.po (Chinese)
含有本地化内容的文件夹放在 CakePHP 安装目录 /app/locale 下。每种语言对应不同的 3 个字母代码,该代码符合 ISO 639-2 标准。(更多信息,请参考 Library of Congress Website,http://www.loc.gov/standards/iso639-2/php/code_list.php)
一旦你创建了该文件,就可以编辑本地化的内容了。注意每个字符串的键值必须唯一,且包含对应值。下面是简单是例子, 英语语言 default.po 文件的内容:
[php] view plaincopy
- msgid "purchase" msgstr "Please purchase a ball by selecting its name ."
- msgid "search" msgstr "Click here to search our product database."
- msgid "purchase" msgstr "请通过选择名字来购买一个球。"
- msgid "search" msgstr "点击搜索我们的产品列表。"
[php] view plaincopy
3)设置应用的本地locale(此步可以省略,cakephp会根据用户的浏览器设置来使用相应的语言进行显示) 1、 在config/core.php中使用configure::write:
[php] view plaincopy
- Configure::write('Config.language' , "chi");
- $this->Session->write ("Config.language","chi");
- App::import('Core', 'L10n');
- $l10n = & new L10n();
- $l10n->get('chi'); //设置locale为中文
- //然后使用_()函数来实现本地化
- _('msgid');
4)实现本地化 在需要实现本地化的地方,调用_()函数
1、直接输出字符串,没有返回值:
[php] view plaincopy
- __("msgid"); 或者 _("msgid", false);
2、间接输出字符串,有返回值:
[php] view plaincopy
- __("msgid",true);
3、还有input要加个label来使他出现中文。
[php] view plaincopy
- echo $form->input('name',array('label'=>__('msgid',true)));
5)没有覆盖的内容 日期、货币格式的国际化可以直接用php中的setlocale函数来实现。
PHP之友评论