十年网站开发经验 + 多家企业客户 + 靠谱的建站团队
量身定制 + 运营维护+专业推广+无忧售后,网站问题一站解决
这篇文章将为大家详细讲解有关如何进行openstack horizon的国际化分析,文章内容质量较高,因此小编分享给大家做个参考,希望大家阅读完这篇文章后对相关知识有一定的了解。
10多年的可克达拉网站建设经验,针对设计、前端、开发、售后、文案、推广等六对一服务,响应快,48小时及时工作处理。成都全网营销推广的优势是能够根据用户设备显示端的尺寸不同,自动调整可克达拉建站的显示方式,使网站能够适用不同显示终端,在浏览器中调整网站的宽度,无论在任何一种浏览器上浏览网站,都能展现优雅布局与设计,从而大程度地提升浏览体验。成都创新互联公司从事“可克达拉网站设计”,“可克达拉网站推广”以来,每个客户项目都认真落实执行。
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 %} #启用i18nLearning Center {% trans "Welcome You" %}--Learn Center {% 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\S+?)/$', 'django.views.i18n.javascript_catalog'), #定义js上的i18n ]
html文件中
#引入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
编译完成后需要重启项目才能使多语言生效。
需要用数据库保存 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的国际化分析就分享到这里了,希望以上内容可以对大家有一定的帮助,可以学到更多知识。如果觉得文章不错,可以把它分享出去让更多的人看到。