包详细信息

@byhuz/i18next-browser-languagedetector

i18next9MIT4.2.2

language detector used in browser environment for i18next

i18next, i18next-languageDetector

自述文件

Introduction

npm version Bower David

This is a i18next language detection plugin use to detect user language in the browser with support for:

  • cookie (set cookie i18next=LANGUAGE)
  • localStorage (set key i18nextLng=LANGUAGE)
  • navigator (set browser language)
  • querystring (append ?lng=LANGUAGE to URL)
  • htmlTag (add html language tag <html lang="LANGUAGE" ...)
  • path (http://my.site.com/LANGUAGE/...)
  • subdomain (http://LANGUAGE.site.com/...)

Getting started

Source can be loaded via npm, bower or downloaded from this repo.

# npm package
$ npm install i18next-browser-languagedetector

# bower
$ bower install i18next-browser-languagedetector
  • If you don't use a module loader it will be added to window.i18nextBrowserLanguageDetector

Wiring up:

import i18next from 'i18next';
import LanguageDetector from 'i18next-browser-languagedetector';

i18next
  .use(LanguageDetector)
  .init(i18nextOptions);

As with all modules you can either pass the constructor function (class) to the i18next.use or a concrete instance.

Detector Options

{
  // order and from where user language should be detected
  order: ['querystring', 'cookie', 'localStorage', 'navigator', 'htmlTag', 'path', 'subdomain'],

  // keys or params to lookup language from
  lookupQuerystring: 'lng',
  lookupCookie: 'i18next',
  lookupLocalStorage: 'i18nextLng',
  lookupFromPathIndex: 0,
  lookupFromSubdomainIndex: 0,

  // cache user language on
  caches: ['localStorage', 'cookie'],
  excludeCacheFor: ['cimode'], // languages to not persist (cookie, localStorage)

  // optional expire and domain for set cookie
  cookieMinutes: 10,
  cookieDomain: 'myDomain',

  // optional htmlTag with lang attribute, the default is:
  htmlTag: document.documentElement,

  // only detect languages that are in the whitelist
  checkWhitelist: true,

  // fallback to a similar whitelist language
  // Example 1: Browser language is 'es'
  // if 'es' is not found in whitelist, first fallback to any whitelist language that starts with 'es-', then fallback to fallbackLng ('es' -> 'es-*' -> fallbackLng)
  // Example 2: Browser language is 'es-MX'
  // if 'es-MX' is not found in whitelist, first fallback to 'es', then fallback to 'es-*', then fallback to fallbackLng ('es-MX' -> 'es' -> 'es-*' -> fallbackLng)
  checkForSimilarInWhitelist: false,

  // optional set cookie options, reference:[MDN Set-Cookie docs](https://developer.mozilla.org/en-US/docs/Web/HTTP/Headers/Set-Cookie)
  cookieOptions: {path:'/'}
}

Options can be passed in:

preferred - by setting options.detection in i18next.init:

import i18next from 'i18next';
import LanguageDetector from 'i18next-browser-languagedetector';

i18next
  .use(LanguageDetector)
  .init({
    detection: options
  });

on construction:

  import LanguageDetector from 'i18next-browser-languagedetector';
  const languageDetector = new LanguageDetector(null, options);

via calling init:

  import LanguageDetector from 'i18next-browser-languagedetector';
  const languageDetector = new LanguageDetector();
  lngDetector.init(options);

Adding own detection functionality

interface

export default {
  name: 'myDetectorsName',

  lookup(options) {
    // options -> are passed in options
    return 'en';
  },

  cacheUserLanguage(lng, options) {
    // options -> are passed in options
    // lng -> current language, will be called after init and on changeLanguage

    // store it
  }
};

adding it

  import LanguageDetector from 'i18next-browser-languagedetector';
  const languageDetector = new LanguageDetector();
  languageDetector.addDetector(myDetector);

  i18next
    .use(languageDetector)
    .init({
      detection: options
    });

Don't forget: You have to add the name of your detector (myDetectorsName in this case) to the order array in your options object. Without that, your detector won't be used. See the Detector Options section for more.


Gold Sponsors

更新日志

4.2.0

  • Add config option checkForSimilarInWhitelist 211

4.1.1

  • fix: pass cookieOptions with the cacheUserLang 205

4.1.0

  • feat: add cookieOptions for setting cookies 203

4.0.2

  • update index file to reflect build changes done in 4.0.0

4.0.1

  • typescript: Use updated ts export default from i18next 194

4.0.0

  • removes deprecated jsnext:main from package.json
  • Bundle all entry points with rollup bringing it up to same standard as xhr-backend
  • note: dist/es -> dist/esm, dist/commonjs -> dist/cjs (individual files -> one bundled file)
  • removes bower finally

v3.1.1

  • add default checkWhitelist: true

v3.1.0

  • Added option to prevent checking whitelist for detected languages checkWhitelist: true 190

v3.0.3

  • Remove clutter from npm package 181

v3.0.2

  • typescript: Fix types for use() module 180

v3.0.1

  • typescript: fix types 165

v3.0.0

  • typescript: add types 164

v2.2.4

v2.2.3

v2.2.2

  • Lang by path: skip if language not found 159

v2.2.1

  • fixes option validation in path lookup 158
  • fixes lookup from href for subdomain 157

v2.2.0

  • add detector for path and subdomain PR153 and PR152

v2.1.1

  • support for fallback language in form of object 151

v2.1.0

  • add .js for browser import implementation PR147

v2.0.0

  • [BREAKING] options.excludeCacheFor (array of language codes; default ['cimode']): if a language maps a value in that list the language will not be written to cache (eg. localStorage, cookie). If you use lng cimode in your tests and require it to be cached set the option to false or empty array