您好,登錄后才能下訂單哦!
這篇文章將為大家詳細講解有關如何進行openstack horizon的國際化分析,文章內容質量較高,因此小編分享給大家做個參考,希望大家閱讀完這篇文章后對相關知識有一定的了解。
I18N 國際化,是”Internationalization” 的縮寫
G11N 全球化,是“Globalization” 的縮寫
L10N 本地化,是“Localization” 的縮寫
Django的翻譯機制是使用 GNU gettext (http://www.gnu.org/software/gettext/),具體為Python標準模塊 gettext 。
通過 gettext --version 驗證是否可用
openstack_dashboard\setting.py
MIDDLEWARE_CLASSES = ( 'django.contrib.sessions.middleware.SessionMiddleware', 'django.middleware.locale.LocaleMiddleware', #需要放在SessionMiddleware之后 'django.middleware.common.CommonMiddleware', ) TEMPLATE_CONTEXT_PROCESSORS = ( 'django.core.context_processors.i18n', #啟用i18n 'django.contrib.auth.context_processors.auth', ) LANGUAGES = ( ('en', 'English'), ('zh-cn', 'Simplified Chinese') ) LANGUAGE_CODE = 'zh-cn' #網站默認語言 LANGUAGE_COOKIE_NAME = 'horizon_language' USE_I18N = True #開啟i18n USE_L10N = True #開啟l10n LOCALE_PATHS = [ 'django_start/locale', ]
TEMPLATE_CONTEXT_PROCESSORS 加入django.core.context_processors.i18n
MIDDLEWARE_CLASSES中加入django.middleware.locale.LocaleMiddleware,注意:
它要放在SessionMiddleware和CacheMiddleware的后面,其他中間件的前面
LANGUAGE_CODE 設置缺省的網站語言,如 en, zh-cn,it, de-at, es, pt-br
LANGUAGES設置網站所支持的所有語言,如(('en', u'English'),('zh-cn',u'中文'))
USE_I18N 設置為True
{% load i18n %} #啟用i18n <title> Learning Center {% trans "Welcome You" %}--Learn Center</title> {% blocktrans %}This will have {{ value }} inside.{% endblocktrans %}
在 {% trans %} 中不允許使用模板中的變量,只能使用單引號或雙引號中的字符串。 如果翻譯時需要用到變量(占位符),可以使用 {% blocktrans %}
from django.utils.translation import ugettext_lazy as _ CONSUMER_CHOICES = ( ('back-end', _('back-end')), )
可參考:openstack_dashboard/api/cinder.py
urls.py文件
urlpatterns = [ url(r'^admin/', include(admin.site.urls)), url(r'^jsi18n/(?P<packages>\S+?)/$', 'django.views.i18n.javascript_catalog'), #定義js上的i18n ]
html文件中
<script type="text/javascript" src="/jsi18n/django_start+django_i18n"></script> #引入js文件,多個app用+分隔
js文件中
var i18njs = gettext('Welcome'); #直接使用全局的gettext即可
在django app目錄執行如下命令,將自動檢索需要翻譯的文件并生成對應的po文件
django-admin.py makemessages -l zh_CN # django-admin.py makemessages -d djangojs -l zh_CN
django.po和djangojs.po文件區別:
py、html文件中的需要翻譯的字符串運行上述命令會自動識別,并添加到django.po文件中
外部js文件中需要翻譯的字符串需要手動創建djangojs.po文件,并將翻譯字符串寫進去
語言翻譯完成后 , 通過如下命令將django.po和djangojs.po編譯為.mo文件
cd horizon && django-admin compilemessages cd openstack_dashboard && django-admin compilemessages
編譯完成后需要重啟項目才能使多語言生效。
<form action="{% url 'set_language' %}" method="post"> {% csrf_token %} <input name="next" type="hidden" value="{{ redirect_to }}" /> <select name="language"> {% get_language_info_list for LANGUAGES as languages %} {% for language in languages %} <option value="{{ language.code }}"{% if language.code == LANGUAGE_CODE %} selected="selected"{% endif %}> {{ language.name_local }} ({{ language.code }}) </option> {% endfor %} </select> <input type="submit" value="Go" /> </form>
需要用數據庫保存 session,在工程目錄中執行如下命令產生 django_session。
python manage.py syncdb
LocaleMiddleware 按照如下算法確定用戶的語言:
1、在當前用戶的 session 的中查找django_language鍵; 可以通過LANGUAGE_COOKIE_NAME改變,比如:LANGUAGE_COOKIE_NAME = 'horizon_language'
2、它會找尋一個cookie
3、還找不到的話,它會在 HTTP 請求頭部里查找Accept-Language, 該頭部是你的瀏覽器發送的,并且按優先順序告訴服務器你的語言偏好。
Django會嘗試頭部中的每一個語種直到它發現一個可用的翻譯。
4、以上都失敗了的話, 就使用全局的 LANGUAGE_CODE 設定值。
關于如何進行openstack horizon的國際化分析就分享到這里了,希望以上內容可以對大家有一定的幫助,可以學到更多知識。如果覺得文章不錯,可以把它分享出去讓更多的人看到。
免責聲明:本站發布的內容(圖片、視頻和文字)以原創、轉載和分享為主,文章觀點不代表本網站立場,如果涉及侵權請聯系站長郵箱:is@yisu.com進行舉報,并提供相關證據,一經查實,將立刻刪除涉嫌侵權內容。