定制 milqmedia/mq-locale 二次开发

按需修改功能、优化性能、对接业务系统,提供一站式技术支持

邮箱:yvsm@zunyunkeji.com | QQ:316430983 | 微信:yvsm316

milqmedia/mq-locale

最新稳定版本:0.1

Composer 安装命令:

composer require milqmedia/mq-locale

包简介

Automatic detection of locales for Zend Framework 3

README 文档

README

Build Status

A slimmed down version of a SlmLocal fork.

Introduction

MQLocale is a Zend Framework 2 module to automatically detect a locale for your application. It uses a variety of pluggable strategies to search for a valid locale. MQLocale features a default locale, a set of supported locales and locale aliases.

MQLocale supports out of the box several strategies to search for a locale. Through interfaces, other strategies could be created. The set of default strategy is:

  1. A part of the domain name (either the TLD or a subdomain)
  2. The first segment of the path of an uri

Furthermore, it provides a set of additional localisation features:

  1. A default locale, used as fallback
  2. A set of aliases, so you can map .com as "en-US" in the hostname strategy
  3. View helper and controller plugin to retrieve the current language
  4. Doctrine Language entity to provide a reusable language object in projects

Installation

Add "milqmedia/mq-locale" to your composer.json file and update your dependencies. Enable MQLocale in your application.config.php.

If you do not have a composer.json file in the root of your project, copy the contents below and put that into a file called composer.json and save it in the root of your project:

{
    "require": {
        "milqmedia/mq-locale": "dev-master"
    }
}

Then execute the following commands in a CLI:

curl -s http://getcomposer.org/installer | php
php composer.phar install

Now you should have a vendor directory, including a milqmedia/mq-locale. In your bootstrap code, make sure you include the vendor/autoload.php file to properly load the MQLocale module.

Usage

Set your default locale in the configuration:

'mq_locale' => array(
    'default' => 'nl-NL',
),

Set all your supported locales in the configuration:

'mq_locale' => array(
    'supported' => array('en-US', 'en-GB'),
),

And enable a strategy. The naming is made via the following list:

  • host: MQLocale\Strategy\HostStrategy
  • url: MQLocale\Strategy\UrlStrategy
'mq_locale' => array(
    'strategy' => 'host'
),

At this moment, the locale should be detected. The locale is stored inside php's Locale object. Retrieve the locale with Locale::getDefault(). This is also automated inside Zend Framework 2 translator objects and i18n view helpers (so you do not need to set the locale yourself there).

Set the locale's language in html

It is common to provide the html with the used locale. This can be set for example in the html tag:

<html lang="en">

Inject the detected language here with the following code:

<html lang="<?= Locale::getPrimaryLanguage(Locale::getDefault())?>">

Use the view helper or controller plugin

$locale = $this->parseDefaultLanguage();
echo $locale; #nl-NL

$language = $this->getCurrentLanguage(); // Returns a Application\Entity\Language object
echo $language->getDescription(); // Dutch

Contributing

  1. Fork it ( https://github.com/milqmedia/mq-locale/fork )
  2. Create your feature branch (git checkout -b my-new-feature)
  3. Commit your changes (git commit -am 'Add some feature')
  4. Push to the branch (git push origin my-new-feature)
  5. Create a new Pull Request

统计信息

  • 总下载量: 1.48k
  • 月度下载量: 0
  • 日度下载量: 0
  • 收藏数: 0
  • 点击次数: 0
  • 依赖项目数: 0
  • 推荐数: 0

GitHub 信息

  • Stars: 0
  • Watchers: 6
  • Forks: 0
  • 开发语言: PHP

其他信息

  • 授权协议: BSD-3-Clause
  • 更新时间: 2014-12-01