php建立全局语言包,PHP内置的不错的语言包功能

近来随着i18n的逐渐标准化,我也来讲一讲在PHP中如何实现国际化支持。跟其他程序语言一样,在 PHP 也可以利用 gettext 套件写作 i18n 程序,实现 NLS(Native Language Support) 国际化支持,具体请参考官方文档( http://www.gnu.org/manual/gettext/index.html )。

实现流程:程序设计者在程序码中写入所要显示的信息,在运行程序时并不会直接显示程序设计师所写的信息,而会先去找一个所设置语系的信息档。如果未找到,才会去显示程式码中的信息。

一、安装设置gettext套件:

1. *NIX系统:

b. 编译PHP的时候加上“--with-gettext[=DIR]”,其中DIR为gettext安装的 目录,缺省为:/usr/local。

c. 保存,然后 restart server。

2.WIN32系统:

a. 需要将gnu_gettext.dll档拷贝到系统目录下面 (Ex: C:/WINNT/SYSTEM32 or C:/WINDOWS/SYSTEM32),PHP 4.2.3 之后文件名为 libintl-1.dll,可在 php4/dlls 下获得。

b. 打开php.ini档,查找extension=php_gettext.dll,去掉前面的“;”。

c. 保存,然后restart server。

若一切顺利,就可以在 phpinfo() 中看到 gettext 字样,至此已设置完毕。

二、php_gettext.dll套件里有好几个函式,具体请看相关的manual。在这里我们只用记住3个函式就行了。

如下:

string bindtextdomain ( string domain, string directory)

string textdomain ( string text_domain)

string gettext ( string message)

三、写作i18n程序:

<?php

// 常规的程序

echo "Hello World!");

?>

下面是 i18n 程序:hello.php

<?php

// I18N 程序范例开始

define('PACKAGE', 'hello'); // 定义要用的mo文件名称,常规来说,我们都把PACKAGE的

名称定义和程序名称相同。

putenv('LANG=zh_TW');

setlocale(LC_ALL, 'zh_TW'); // 指定要用的语系,如:en_US、zh_CN、zh_TW

bindtextdomain(PACKAGE, '/apache/htdocs/locale');

textdomain(PACKAGE);

// The .mo file searched is:

// /apache/htdocs/locale/en/LC_MESSAGES/hello.mo

echo gettext("Hello World!");

?>

在IE中输入:http://localhost/hello.php,输出结果为:“Hello World!”。

note:按照 GNU package 里面的习惯,可以使用 _(...) 来代替 gettext(...) ,这样就可以少打很多 gettext 了。

四、接下来设置gettext po档:

1.创建目录结构,如下所示:

bindtextdomain's dir

/language

/LC_MESSAGES

domain.po

domain.mo

其中 bindtextdomain's dir 为 bindtextdomain() 所用的目录,language 为要用的语系,domain 为 PACKAGE 名称。

以上面为例:

/locale

/zh_TW

/LC_MESSAGES

hello.po

hello.mo

2.创建PO档

xgettext -d [您定义的PACKAGE名称] [程序文件名]

WIN32下面的xgettext、msgfmt程序档可以从 ( http://www.sourceforge.net ) 下载,需要 libiconv.dll,、libintl.dll 的支持。

以上面hello.php档为例:

$ xgettext -d hello hello.php

运行后将产生一个hello.po档,内容如下:

# SOME DESCRIPTIVE TITLE.

# Copyright ? YEAR Free Software Foundation, Inc.

# FIRST AUTHOR , YEAR.

#

#, fuzzy

msgid ""

msgstr ""

"Project-Id-Version: PACKAGE VERSION/n"

"POT-Creation-Date: 2003-04-21 22:31+0800/n"

"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE/n"

"Last-Translator: FULL NAME /n"

"Language-Team: LANGUAGE /n"

"MIME-Version: 1.0/n"

"Content-Type: text/plain; charset=CHARSET/n"

"Content-Transfer-Encoding: 8bit/n"

#: hello.php:14

msgid "Hello World!"

msgstr ""

里面列出 hello.php 档里所有调用 gettext 函式的字符串,翻译的时候只需将 msgid 值翻译填入 msgstr 即可,如翻译成中文。

# SOME DESCRIPTIVE TITLE.

# Copyright ? 2003 Ptker All Right Reserved.

# FIRST AUTHOR , 2003.

#

#, fuzzy

msgid ""

msgstr ""

"Project-Id-Version: 0.1/n"

"POT-Creation-Date: 2003-04-21 22:31+0800/n"

"PO-Revision-Date: YEAR-MO-DA HO:MI+ZONE/n"

"Last-Translator: Ptker /n"

"Language-Team: zh_TW /n"

"MIME-Version: 1.0/n"

"Content-Type: text/plain; charset=BIG5/n"

"Content-Transfer-Encoding: 8bit/n"

#: hello.php:14

msgid "Hello World!"

msgstr "世界,您好!"

3.创建MO档

msgfmt -o hello.mo hello.po

运行后将产生一个hello.mo二进制档。

4.最后将 hello.po、hello.mo 拷贝到相关语系的目录下即可。

五、在IE中输入: http://localhost/hello.php ,现在的结果就是:“世界,您好!”

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
UniApp的国际化语言包支持一键全局切换语言的功能。以下是具体步骤: 1. 在UniApp项目中创建一个lang文件夹,用于存放语言包。 2. 在lang文件夹中创建一个index.js文件,用于定义语言包和默认语言。 3. 在index.js文件中定义语言包,例如: ``` export default { en: { hello: 'Hello', world: 'World' }, zh: { hello: '你好', world: '世界' } } ``` 4. 在index.js文件中定义默认语言: ``` export const DEFAULT_LANG = 'en'; ``` 5. 在App.vue中引入语言包和默认语言: ``` <template> <div> <p>{{ $t('hello') }}</p> <p>{{ $t('world') }}</p> </div> </template> <script> import lang from '@/lang'; import { DEFAULT_LANG } from '@/lang/index'; export default { computed: { lang() { return lang[this.$store.state.lang || DEFAULT_LANG]; } }, methods: { setLang(lang) { this.$store.commit('setLang', lang); uni.setStorageSync('lang', lang); } }, watch: { '$store.state.lang'(newVal) { uni.setNavigationBarTitle({ title: this.lang.title }); } }, created() { this.$store.commit('initLang', uni.getStorageSync('lang')); } } </script> ``` 6. 在main.js中定义语言切换方法: ``` import Vue from 'vue' import App from './App' import store from './store' import lang from '@/lang' import { DEFAULT_LANG } from '@/lang/index' Vue.config.productionTip = false Vue.prototype.$t = function(key) { const langType = store.state.lang || uni.getStorageSync('lang') || DEFAULT_LANG; const value = lang[langType][key] || lang[DEFAULT_LANG][key] || ''; return value; } App.mpType = 'app' const app = new Vue({ store, ...App }) app.$mount() ``` 7. 在store.js中定义语言切换方法: ``` import Vue from 'vue' import Vuex from 'vuex' import { DEFAULT_LANG } from '@/lang/index' Vue.use(Vuex) export default new Vuex.Store({ state: { lang: '' }, mutations: { initLang(state, lang) { state.lang = lang || DEFAULT_LANG; }, setLang(state, lang) { state.lang = lang; } }, actions: {}, modules: {} }) ``` 8. 在页面中添加语言切换按钮: ``` <template> <div> <button @click="setLang('en')">English</button> <button @click="setLang('zh')">中文</button> </div> </template> <script> export default { methods: { setLang(lang) { this.$store.commit('setLang', lang); uni.setStorageSync('lang', lang); } } } </script> ``` 这样就可以实现UniApp的国际化语言包一键全局切换语言的功能了。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值